mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-01 19:48:08 +00:00
- 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>
76 lines
1.8 KiB
Vue
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>
|