Files
chatwoot/app/javascript/superadmin_pages/views/dashboard/Index.vue
Vishnu Narayanan ee02923ace chore: fix circleci on vite build (#10214)
- Switch to pnpm based build
- Switch circleci from docker to machine to have more memory
- Fix frontend and backend tests

Fixes
https://linear.app/chatwoot/issue/CW-3610/fix-circle-ci-for-vite-build
---------

Co-authored-by: Shivam Mishra <scm.mymail@gmail.com>
Co-authored-by: Pranav <pranavrajs@gmail.com>
Co-authored-by: Pranav <pranav@chatwoot.com>
2024-10-07 15:27:41 +05:30

76 lines
1.8 KiB
Vue

<script setup>
import { computed } from 'vue';
import BarChart from 'shared/components/charts/BarChart.vue';
const props = defineProps({
componentData: {
type: Object,
default: () => ({}),
},
});
const prepareData = sourceData => {
var labels = [];
var data = [];
sourceData.forEach(item => {
labels.push(item[0]);
data.push(item[1]);
});
return {
labels,
datasets: [
{
type: 'bar',
backgroundColor: 'rgb(31, 147, 255)',
yAxisID: 'y',
label: 'Conversations',
data: data,
},
],
};
};
const chartData = computed(() => {
return prepareData(props.componentData.chartData);
});
const { accountsCount, usersCount, inboxesCount, conversationsCount } =
props.componentData;
</script>
<template>
<div class="w-full h-full">
<header class="main-content__header" role="banner">
<h1 id="page-title" class="main-content__page-title">
{{ 'Admin Dashboard' }}
</h1>
</header>
<section class="main-content__body main-content__body--flush">
<div class="report--list">
<div class="report-card">
<div class="metric">{{ accountsCount }}</div>
<div>{{ 'Accounts' }}</div>
</div>
<div class="report-card">
<div class="metric">{{ usersCount }}</div>
<div>{{ 'Users' }}</div>
</div>
<div class="report-card">
<div class="metric">{{ inboxesCount }}</div>
<div>{{ 'Inboxes' }}</div>
</div>
<div class="report-card">
<div class="metric">{{ conversationsCount }}</div>
<div>{{ 'Conversations' }}</div>
</div>
</div>
</section>
<!-- eslint-disable vue/no-static-inline-styles -->
<BarChart
class="p-8 w-full"
:collection="chartData"
style="max-height: 500px"
/>
</div>
</template>