@ammarkhalidfarooq/dashboard-package 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +38 -0
- package/dist/index.cjs.js +600 -0
- package/dist/index.cjs.js.map +1 -0
- package/dist/index.d.js +2 -0
- package/dist/index.es.js +593 -0
- package/dist/index.es.js.map +1 -0
- package/package.json +61 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.cjs.js","sources":["../src/config/customTheme.js","../src/components/MetricSelector.jsx","../src/components/RevenueChart.jsx","../src/components/Dashboard.jsx","../src/config/customColors.js"],"sourcesContent":["import { createTheme } from \"@mui/material/styles\";\r\n\r\nexport const theme = createTheme({\r\n cssVariables: true, // Enable CSS variables for better SSR support\r\n typography: {\r\n fontFamily: [\r\n \"var(--font-league-spartan)\",\r\n \"var(--font-noto-sans-arabic)\", // Added as a fallback for Arabic text\r\n \"-apple-system\",\r\n \"BlinkMacSystemFont\",\r\n \"Segoe UI\",\r\n \"Roboto\",\r\n \"Helvetica Neue\",\r\n \"Arial\",\r\n \"sans-serif\",\r\n \"Apple Color Emoji\",\r\n \"Segoe UI Emoji\",\r\n \"Segoe UI Symbol\",\r\n ].join(\",\"),\r\n },\r\n palette: {\r\n primary: {\r\n main: \"#6363E6\",\r\n mainLight: \"#F7F7FF\",\r\n light: \"#FFFFFF\",\r\n gray: \"#A1A1A8\",\r\n lightGreen: \"#E1FBF2\",\r\n green: \"#0CAB72\",\r\n red: \"#E61D1D\",\r\n lightRed: \"#FFEDED\",\r\n lightGray: \"#E9E9EB\",\r\n darkGray: \"#606062\",\r\n dark: \"#090909\",\r\n },\r\n text: { primary: \"#666666\" },\r\n secondary: {\r\n main: \"#E0C2FF\",\r\n light: \"#F5EBFF\",\r\n // dark: will be calculated from palette.secondary.main,\r\n contrastText: \"#47008F\",\r\n },\r\n white: {\r\n main: \"#FFFFFF\",\r\n light: \"#F8F8F8\",\r\n },\r\n\r\n gradients: {\r\n primary: \"linear-gradient(90deg, #6363E6 0.05%, #59C9F9 99.96%)\",\r\n secondary: \"linear-gradient(180deg, #E9E9FF 0%, #C9EEFF 100%)\",\r\n // You can add more gradients if needed\r\n },\r\n },\r\n});\r\n","import React from 'react';\nimport { Button, Menu, MenuItem, Box } from '@mui/material';\nimport { MoreHoriz as MoreHorizIcon } from '@mui/icons-material';\n\nconst MetricSelector = ({ metric, onMetricChange, options = ['Revenue', 'Donations'] }) => {\n const [anchorEl, setAnchorEl] = React.useState(null);\n const open = Boolean(anchorEl);\n\n const handleClick = (event) => {\n setAnchorEl(event.currentTarget);\n };\n\n const handleClose = (value) => {\n if (typeof value === 'string') {\n onMetricChange(value);\n }\n setAnchorEl(null);\n };\n\n return (\n <Box sx={{ display: 'flex', gap: 1 }}>\n <Button\n id=\"metric-button\"\n aria-controls={open ? 'metric-menu' : undefined}\n aria-haspopup=\"true\"\n aria-expanded={open ? 'true' : undefined}\n onClick={handleClick}\n variant=\"outlined\"\n sx={{ \n borderRadius: '8px', \n borderColor: '#E9E9EB', \n color: '#000', \n textTransform: 'none',\n fontWeight: 600,\n px: 2,\n height: '40px',\n '&:hover': {\n borderColor: 'primary.main',\n bgcolor: 'rgba(99, 99, 230, 0.04)'\n }\n }}\n >\n Metric: {metric}\n </Button>\n <Menu\n id=\"metric-menu\"\n anchorEl={anchorEl}\n open={open}\n onClose={() => handleClose()}\n MenuListProps={{\n 'aria-labelledby': 'metric-button',\n }}\n PaperProps={{\n sx: {\n borderRadius: '8px',\n mt: 1,\n boxShadow: '0 4px 12px rgba(0,0,0,0.1)',\n minWidth: '150px'\n }\n }}\n >\n {options.map((option) => (\n <MenuItem \n key={option} \n onClick={() => handleClose(option)} \n sx={{ fontWeight: metric === option ? 700 : 400 }}\n >\n {option}\n </MenuItem>\n ))}\n </Menu>\n </Box>\n );\n};\n\nexport default MetricSelector;\n","import React from 'react';\nimport Chart from 'react-apexcharts';\nimport { useTheme } from '@mui/material/styles';\n\nconst RevenueChart = ({ metric, data, series, categories, height = 350, stacked = false }) => {\n const theme = useTheme();\n\n const chartOptions = {\n chart: {\n id: 'revenue-chart',\n stacked: stacked,\n toolbar: {\n show: false\n },\n sparkline: {\n enabled: false\n }\n },\n stroke: {\n curve: 'straight',\n width: 2\n },\n fill: {\n type: 'gradient',\n gradient: {\n shadeIntensity: 1,\n opacityFrom: 0.8,\n opacityTo: 0.4,\n stops: [0, 100]\n }\n },\n xaxis: {\n categories: categories,\n axisBorder: {\n show: false\n },\n axisTicks: {\n show: false\n },\n labels: {\n style: {\n colors: '#A1A1A8',\n fontSize: '12px'\n }\n }\n },\n yaxis: {\n show: true,\n labels: {\n style: {\n colors: '#A1A1A8',\n fontSize: '12px'\n },\n formatter: (value) => metric === 'Revenue' ? `$${value}` : value\n }\n },\n grid: {\n show: true,\n borderColor: '#f1f1f1',\n strokeDashArray: 4,\n position: 'back'\n },\n // Use primary main and a darker version of it for differentiation\n colors: [theme.palette.primary.main, '#4B4BC2'],\n dataLabels: {\n enabled: false\n },\n tooltip: {\n theme: 'light',\n y: {\n formatter: (value) => metric === 'Revenue' ? `$${value}` : value\n }\n },\n legend: {\n show: stacked,\n position: 'top',\n horizontalAlign: 'left'\n }\n };\n\n const chartSeries = series || [\n {\n name: metric,\n data: data,\n },\n ];\n\n return (\n <Chart\n options={chartOptions}\n series={chartSeries}\n type=\"area\"\n height={height}\n width=\"100%\"\n />\n );\n};\n\nexport default RevenueChart;\n","import React from 'react';\nimport { Box, Typography, Card, CardContent, ThemeProvider, IconButton, Grid } from '@mui/material';\nimport { MoreHoriz as MoreHorizIcon } from '@mui/icons-material';\nimport { theme } from '../config/customTheme';\nimport MetricSelector from './MetricSelector';\nimport RevenueChart from './RevenueChart';\n\nconst Dashboard = ({ \n title = \"Overview\",\n initialMetric = 'Revenue',\n revenueData = [3000, 4500, 4200, 5800, 5200, 7100, 8500, 9200, 5000],\n donationsData = [15, 22, 18, 30, 25, 35, 42, 45, 28],\n categories = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep']\n}) => {\n const [metric, setMetric] = React.useState(initialMetric);\n\n const currentData = metric === 'Revenue' ? revenueData : donationsData;\n\n const primaryCharts = [\n { \n label: 'Total Revenue', \n value: '$9,200.00',\n subValue: 'Total Donations: 215',\n data: currentData,\n categories: categories,\n showSelector: true\n },\n { \n label: 'First installments', \n value: '$510.00', \n data: currentData.slice(-7),\n categories: categories.slice(-7)\n },\n { \n label: 'One-time donations', \n value: '$7,100.00',\n data: currentData,\n categories: categories\n }\n ];\n\n const secondaryCharts = [\n { \n label: 'New vs Returning Donors', \n series: [\n { name: 'New Donors', data: [10, 15, 12, 20, 18, 25, 30, 35, 20] },\n { name: 'Returning', data: [5, 7, 6, 10, 7, 10, 12, 10, 8] }\n ],\n categories: categories,\n stacked: true,\n footer: { left: 'New donors: 195', right: 'Returning donors: 20' }\n },\n { \n label: 'Average Donation Amount', \n value: '$42.80',\n data: currentData.map(v => v * 0.5),\n categories: categories\n },\n { \n label: 'Tip Amount', \n value: '$1,250.00',\n subValue: 'Number of Tips: 110',\n data: currentData.map(v => v * 0.2),\n categories: categories\n }\n ];\n\n const tertiaryCharts = [\n { \n label: 'Conversion Rate', \n value: '2%',\n data: [1.5, 1.8, 1.7, 2.1, 2.0, 1.9, 2.2, 2.5, 2.0],\n categories: categories\n },\n { \n label: 'Organic vs Paid Traffic', \n series: [\n { name: 'Organic', data: [500, 600, 550, 700, 800, 750, 900, 1000, 950] },\n { name: 'Paid', data: [200, 250, 220, 300, 350, 320, 400, 450, 420] }\n ],\n categories: categories,\n stacked: true\n },\n { \n label: 'Organic Donations', \n value: '120',\n data: [8, 12, 10, 15, 14, 18, 22, 20, 12],\n categories: categories\n }\n ];\n\n const quaternaryCharts = [\n { \n label: 'Email Marketing', \n value: '56',\n data: [45, 48, 52, 50, 56, 54, 58, 60, 56],\n categories: categories\n },\n { \n label: 'Traffic source', \n value: '23%',\n data: [18, 22, 20, 25, 23, 21, 24, 26, 23],\n categories: categories\n },\n { \n label: 'URL', \n value: '10%',\n data: [8, 9, 11, 10, 10, 12, 9, 11, 10],\n categories: categories\n }\n ];\n\n const renderChartCard = (item, index, isPrimary = false) => (\n <Grid item xs={12} md={4} key={item.label + index} sx={{ display: 'flex' }}>\n <Card sx={{ width: '100%', display: 'flex', flexDirection: 'column', boxShadow: '0 4px 24px rgba(0,0,0,0.06)', borderRadius: 4, border: '1px solid #f0f0f0' }}>\n <CardContent sx={{ p: 3, flexGrow: 1, display: 'flex', flexDirection: 'column' }}>\n <Box sx={{ display: 'flex', justifyContent: 'space-between', alignItems: 'flex-start', mb: 2 }}>\n <Box sx={{ textAlign: 'left' }}>\n <Typography variant=\"subtitle2\" sx={{ color: '#000000', fontWeight: 600, textTransform: 'uppercase', letterSpacing: '0.5px', mb: 0.5 }}>\n {item.label}\n </Typography>\n {item.value && (\n <Typography variant=\"subtitle2\" sx={{ fontWeight: 600, color: '#000000', mb: 0.5 }}>\n {item.value}\n </Typography>\n )}\n {item.subValue && (\n <Typography variant=\"subtitle2\" sx={{ color: '#000000', fontWeight: 600 }}>\n {item.subValue}\n </Typography>\n )}\n </Box>\n \n <Box sx={{ display: 'flex', gap: 1 }}>\n {item.showSelector && (\n <MetricSelector \n metric={metric} \n onMetricChange={setMetric} \n options={['Revenue', 'Donations']} \n />\n )}\n <IconButton \n sx={{ \n border: '1px solid #E9E9EB', \n borderRadius: '8px',\n color: '#000',\n height: '40px',\n width: '40px',\n '&:hover': {\n borderColor: 'primary.main',\n bgcolor: 'rgba(99, 99, 230, 0.04)'\n }\n }}\n >\n <MoreHorizIcon sx={{ fontSize: '1.2rem' }} />\n </IconButton>\n </Box>\n </Box>\n \n <Box sx={{ flexGrow: 1, minHeight: isPrimary ? '250px' : '200px' }}>\n <RevenueChart \n metric={item.label.includes('Rate') || item.label.includes('Performance') || item.label.includes('source') || item.label === 'URL' ? 'Percent' : (item.stacked ? (item.label.includes('Traffic') ? 'Visitors' : 'Donors') : metric)} \n data={item.data} \n series={item.series}\n categories={item.categories} \n height={isPrimary ? 250 : 200}\n stacked={item.stacked}\n />\n </Box>\n\n {item.footer && (\n <Box sx={{ display: 'flex', justifyContent: 'space-between', mt: 2, pt: 2, borderTop: '1px solid #f0f0f0' }}>\n <Typography variant=\"caption\" sx={{ color: '#606062', fontWeight: 600 }}>\n {item.footer.left}\n </Typography>\n <Typography variant=\"caption\" sx={{ color: '#606062', fontWeight: 600 }}>\n {item.footer.right}\n </Typography>\n </Box>\n )}\n </CardContent>\n </Card>\n </Grid>\n );\n\n return (\n <ThemeProvider theme={theme}>\n <Box sx={{ p: 4, bgcolor: 'primary.mainLight', minHeight: '100vh', display: 'flex', flexDirection: 'column', alignItems: 'stretch' }}>\n <Typography variant=\"h4\" gutterBottom sx={{ fontWeight: 'bold', color: 'primary.main', mb: 4 }}>\n {title}\n </Typography>\n \n {/* Row 1 */}\n <Grid container spacing={3} sx={{ mb: 1 }}>\n {primaryCharts.map((item, index) => renderChartCard(item, index, true))}\n </Grid>\n\n {/* Row 2 */}\n <Grid container spacing={3} sx={{ mt: 1 }}>\n {secondaryCharts.map((item, index) => renderChartCard(item, index, false))}\n </Grid>\n\n {/* Row 3 */}\n <Grid container spacing={3} sx={{ mt: 1 }}>\n {tertiaryCharts.map((item, index) => renderChartCard(item, index, false))}\n </Grid>\n\n {/* Row 4 */}\n <Grid container spacing={3} sx={{ mt: 1 }}>\n {quaternaryCharts.map((item, index) => renderChartCard(item, index, false))}\n </Grid>\n </Box>\n </ThemeProvider>\n );\n};\n\nexport default Dashboard;\nexport { MetricSelector, RevenueChart };\n","/**\r\n * Theme colors for server components\r\n *\r\n * These are plain JavaScript objects that can be safely imported\r\n * in both server and client components without triggering\r\n * client-only code in server components.\r\n *\r\n * For client components, use the full theme from @/config/customTheme\r\n */\r\n\r\nexport const themeColors = {\r\n primary: {\r\n main: \"#6363E6\",\r\n mainLight: \"#F7F7FF\",\r\n light: \"#FFFFFF\",\r\n gray: \"#A1A1A8\",\r\n lightGreen: \"#E1FBF2\",\r\n green: \"#0CAB72\",\r\n red: \"#E61D1D\",\r\n lightRed: \"#FFEDED\",\r\n lightGray: \"#E9E9EB\",\r\n darkGray: \"#606062\",\r\n dark: \"#090909\",\r\n },\r\n text: {\r\n primary: \"#666666\",\r\n },\r\n secondary: {\r\n main: \"#E0C2FF\",\r\n light: \"#F5EBFF\",\r\n contrastText: \"#47008F\",\r\n },\r\n white: {\r\n main: \"#FFFFFF\",\r\n light: \"#F8F8F8\",\r\n },\r\n gradients: {\r\n primary: \"linear-gradient(90deg, #6363E6 0.05%, #59C9F9 99.96%)\",\r\n secondary: \"linear-gradient(180deg, #E9E9FF 0%, #C9EEFF 100%)\",\r\n },\r\n};\r\n\r\n// Typography settings for server components\r\nexport const themeTypography = {\r\n fontFamily: [\r\n \"var(--font-league-spartan)\",\r\n \"var(--font-noto-sans-arabic)\",\r\n \"-apple-system\",\r\n \"BlinkMacSystemFont\",\r\n \"Segoe UI\",\r\n \"Roboto\",\r\n \"Helvetica Neue\",\r\n \"Arial\",\r\n \"sans-serif\",\r\n \"Apple Color Emoji\",\r\n \"Segoe UI Emoji\",\r\n \"Segoe UI Symbol\",\r\n ].join(\",\"),\r\n};\r\n"],"names":["theme","createTheme","cssVariables","typography","fontFamily","join","palette","primary","main","mainLight","light","gray","lightGreen","green","red","lightRed","lightGray","darkGray","dark","text","secondary","contrastText","white","gradients","MetricSelector","_ref","metric","onMetricChange","_ref$options","options","_React$useState","React","useState","_React$useState2","_slicedToArray","anchorEl","setAnchorEl","open","Boolean","handleClick","event","currentTarget","handleClose","value","createElement","Box","sx","display","gap","Button","id","undefined","onClick","variant","borderRadius","borderColor","color","textTransform","fontWeight","px","height","bgcolor","Menu","onClose","MenuListProps","PaperProps","mt","boxShadow","minWidth","map","option","MenuItem","key","RevenueChart","data","series","categories","_ref$height","_ref$stacked","stacked","useTheme","chartOptions","chart","toolbar","show","sparkline","enabled","stroke","curve","width","fill","type","gradient","shadeIntensity","opacityFrom","opacityTo","stops","xaxis","axisBorder","axisTicks","labels","style","colors","fontSize","yaxis","formatter","concat","grid","strokeDashArray","position","dataLabels","tooltip","y","legend","horizontalAlign","chartSeries","name","Chart","Dashboard","_ref$title","title","_ref$initialMetric","initialMetric","_ref$revenueData","revenueData","_ref$donationsData","donationsData","_ref$categories","setMetric","currentData","primaryCharts","label","subValue","showSelector","slice","secondaryCharts","footer","left","right","v","tertiaryCharts","quaternaryCharts","renderChartCard","item","index","isPrimary","arguments","length","Grid","xs","md","Card","flexDirection","border","CardContent","p","flexGrow","justifyContent","alignItems","mb","textAlign","Typography","letterSpacing","IconButton","MoreHorizIcon","minHeight","includes","pt","borderTop","ThemeProvider","gutterBottom","container","spacing","themeColors","themeTypography"],"mappings":"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"}
|
package/dist/index.d.js
ADDED
package/dist/index.es.js
ADDED
|
@@ -0,0 +1,593 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Box, Button, Menu, MenuItem, ThemeProvider, Typography, Grid, Card, CardContent, IconButton } from '@mui/material';
|
|
3
|
+
import { MoreHoriz } from '@mui/icons-material';
|
|
4
|
+
import { createTheme, useTheme } from '@mui/material/styles';
|
|
5
|
+
import Chart from 'react-apexcharts';
|
|
6
|
+
|
|
7
|
+
function _arrayLikeToArray(r, a) {
|
|
8
|
+
(null == a || a > r.length) && (a = r.length);
|
|
9
|
+
for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];
|
|
10
|
+
return n;
|
|
11
|
+
}
|
|
12
|
+
function _arrayWithHoles(r) {
|
|
13
|
+
if (Array.isArray(r)) return r;
|
|
14
|
+
}
|
|
15
|
+
function _iterableToArrayLimit(r, l) {
|
|
16
|
+
var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"];
|
|
17
|
+
if (null != t) {
|
|
18
|
+
var e,
|
|
19
|
+
n,
|
|
20
|
+
i,
|
|
21
|
+
u,
|
|
22
|
+
a = [],
|
|
23
|
+
f = true,
|
|
24
|
+
o = false;
|
|
25
|
+
try {
|
|
26
|
+
if (i = (t = t.call(r)).next, 0 === l) ; else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0);
|
|
27
|
+
} catch (r) {
|
|
28
|
+
o = true, n = r;
|
|
29
|
+
} finally {
|
|
30
|
+
try {
|
|
31
|
+
if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return;
|
|
32
|
+
} finally {
|
|
33
|
+
if (o) throw n;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
return a;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
function _nonIterableRest() {
|
|
40
|
+
throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
|
41
|
+
}
|
|
42
|
+
function _slicedToArray(r, e) {
|
|
43
|
+
return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest();
|
|
44
|
+
}
|
|
45
|
+
function _unsupportedIterableToArray(r, a) {
|
|
46
|
+
if (r) {
|
|
47
|
+
if ("string" == typeof r) return _arrayLikeToArray(r, a);
|
|
48
|
+
var t = {}.toString.call(r).slice(8, -1);
|
|
49
|
+
return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
var theme = createTheme({
|
|
54
|
+
cssVariables: true,
|
|
55
|
+
// Enable CSS variables for better SSR support
|
|
56
|
+
typography: {
|
|
57
|
+
fontFamily: ["var(--font-league-spartan)", "var(--font-noto-sans-arabic)",
|
|
58
|
+
// Added as a fallback for Arabic text
|
|
59
|
+
"-apple-system", "BlinkMacSystemFont", "Segoe UI", "Roboto", "Helvetica Neue", "Arial", "sans-serif", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol"].join(",")
|
|
60
|
+
},
|
|
61
|
+
palette: {
|
|
62
|
+
primary: {
|
|
63
|
+
main: "#6363E6",
|
|
64
|
+
mainLight: "#F7F7FF",
|
|
65
|
+
light: "#FFFFFF",
|
|
66
|
+
gray: "#A1A1A8",
|
|
67
|
+
lightGreen: "#E1FBF2",
|
|
68
|
+
green: "#0CAB72",
|
|
69
|
+
red: "#E61D1D",
|
|
70
|
+
lightRed: "#FFEDED",
|
|
71
|
+
lightGray: "#E9E9EB",
|
|
72
|
+
darkGray: "#606062",
|
|
73
|
+
dark: "#090909"
|
|
74
|
+
},
|
|
75
|
+
text: {
|
|
76
|
+
primary: "#666666"
|
|
77
|
+
},
|
|
78
|
+
secondary: {
|
|
79
|
+
main: "#E0C2FF",
|
|
80
|
+
light: "#F5EBFF",
|
|
81
|
+
// dark: will be calculated from palette.secondary.main,
|
|
82
|
+
contrastText: "#47008F"
|
|
83
|
+
},
|
|
84
|
+
white: {
|
|
85
|
+
main: "#FFFFFF",
|
|
86
|
+
light: "#F8F8F8"
|
|
87
|
+
},
|
|
88
|
+
gradients: {
|
|
89
|
+
primary: "linear-gradient(90deg, #6363E6 0.05%, #59C9F9 99.96%)",
|
|
90
|
+
secondary: "linear-gradient(180deg, #E9E9FF 0%, #C9EEFF 100%)"
|
|
91
|
+
// You can add more gradients if needed
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
var MetricSelector = function MetricSelector(_ref) {
|
|
97
|
+
var metric = _ref.metric,
|
|
98
|
+
onMetricChange = _ref.onMetricChange,
|
|
99
|
+
_ref$options = _ref.options,
|
|
100
|
+
options = _ref$options === void 0 ? ['Revenue', 'Donations'] : _ref$options;
|
|
101
|
+
var _React$useState = React.useState(null),
|
|
102
|
+
_React$useState2 = _slicedToArray(_React$useState, 2),
|
|
103
|
+
anchorEl = _React$useState2[0],
|
|
104
|
+
setAnchorEl = _React$useState2[1];
|
|
105
|
+
var open = Boolean(anchorEl);
|
|
106
|
+
var handleClick = function handleClick(event) {
|
|
107
|
+
setAnchorEl(event.currentTarget);
|
|
108
|
+
};
|
|
109
|
+
var handleClose = function handleClose(value) {
|
|
110
|
+
if (typeof value === 'string') {
|
|
111
|
+
onMetricChange(value);
|
|
112
|
+
}
|
|
113
|
+
setAnchorEl(null);
|
|
114
|
+
};
|
|
115
|
+
return /*#__PURE__*/React.createElement(Box, {
|
|
116
|
+
sx: {
|
|
117
|
+
display: 'flex',
|
|
118
|
+
gap: 1
|
|
119
|
+
}
|
|
120
|
+
}, /*#__PURE__*/React.createElement(Button, {
|
|
121
|
+
id: "metric-button",
|
|
122
|
+
"aria-controls": open ? 'metric-menu' : undefined,
|
|
123
|
+
"aria-haspopup": "true",
|
|
124
|
+
"aria-expanded": open ? 'true' : undefined,
|
|
125
|
+
onClick: handleClick,
|
|
126
|
+
variant: "outlined",
|
|
127
|
+
sx: {
|
|
128
|
+
borderRadius: '8px',
|
|
129
|
+
borderColor: '#E9E9EB',
|
|
130
|
+
color: '#000',
|
|
131
|
+
textTransform: 'none',
|
|
132
|
+
fontWeight: 600,
|
|
133
|
+
px: 2,
|
|
134
|
+
height: '40px',
|
|
135
|
+
'&:hover': {
|
|
136
|
+
borderColor: 'primary.main',
|
|
137
|
+
bgcolor: 'rgba(99, 99, 230, 0.04)'
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
}, "Metric: ", metric), /*#__PURE__*/React.createElement(Menu, {
|
|
141
|
+
id: "metric-menu",
|
|
142
|
+
anchorEl: anchorEl,
|
|
143
|
+
open: open,
|
|
144
|
+
onClose: function onClose() {
|
|
145
|
+
return handleClose();
|
|
146
|
+
},
|
|
147
|
+
MenuListProps: {
|
|
148
|
+
'aria-labelledby': 'metric-button'
|
|
149
|
+
},
|
|
150
|
+
PaperProps: {
|
|
151
|
+
sx: {
|
|
152
|
+
borderRadius: '8px',
|
|
153
|
+
mt: 1,
|
|
154
|
+
boxShadow: '0 4px 12px rgba(0,0,0,0.1)',
|
|
155
|
+
minWidth: '150px'
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
}, options.map(function (option) {
|
|
159
|
+
return /*#__PURE__*/React.createElement(MenuItem, {
|
|
160
|
+
key: option,
|
|
161
|
+
onClick: function onClick() {
|
|
162
|
+
return handleClose(option);
|
|
163
|
+
},
|
|
164
|
+
sx: {
|
|
165
|
+
fontWeight: metric === option ? 700 : 400
|
|
166
|
+
}
|
|
167
|
+
}, option);
|
|
168
|
+
})));
|
|
169
|
+
};
|
|
170
|
+
|
|
171
|
+
var RevenueChart = function RevenueChart(_ref) {
|
|
172
|
+
var metric = _ref.metric,
|
|
173
|
+
data = _ref.data,
|
|
174
|
+
series = _ref.series,
|
|
175
|
+
categories = _ref.categories,
|
|
176
|
+
_ref$height = _ref.height,
|
|
177
|
+
height = _ref$height === void 0 ? 350 : _ref$height,
|
|
178
|
+
_ref$stacked = _ref.stacked,
|
|
179
|
+
stacked = _ref$stacked === void 0 ? false : _ref$stacked;
|
|
180
|
+
var theme = useTheme();
|
|
181
|
+
var chartOptions = {
|
|
182
|
+
chart: {
|
|
183
|
+
id: 'revenue-chart',
|
|
184
|
+
stacked: stacked,
|
|
185
|
+
toolbar: {
|
|
186
|
+
show: false
|
|
187
|
+
},
|
|
188
|
+
sparkline: {
|
|
189
|
+
enabled: false
|
|
190
|
+
}
|
|
191
|
+
},
|
|
192
|
+
stroke: {
|
|
193
|
+
curve: 'straight',
|
|
194
|
+
width: 2
|
|
195
|
+
},
|
|
196
|
+
fill: {
|
|
197
|
+
type: 'gradient',
|
|
198
|
+
gradient: {
|
|
199
|
+
shadeIntensity: 1,
|
|
200
|
+
opacityFrom: 0.8,
|
|
201
|
+
opacityTo: 0.4,
|
|
202
|
+
stops: [0, 100]
|
|
203
|
+
}
|
|
204
|
+
},
|
|
205
|
+
xaxis: {
|
|
206
|
+
categories: categories,
|
|
207
|
+
axisBorder: {
|
|
208
|
+
show: false
|
|
209
|
+
},
|
|
210
|
+
axisTicks: {
|
|
211
|
+
show: false
|
|
212
|
+
},
|
|
213
|
+
labels: {
|
|
214
|
+
style: {
|
|
215
|
+
colors: '#A1A1A8',
|
|
216
|
+
fontSize: '12px'
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
},
|
|
220
|
+
yaxis: {
|
|
221
|
+
show: true,
|
|
222
|
+
labels: {
|
|
223
|
+
style: {
|
|
224
|
+
colors: '#A1A1A8',
|
|
225
|
+
fontSize: '12px'
|
|
226
|
+
},
|
|
227
|
+
formatter: function formatter(value) {
|
|
228
|
+
return metric === 'Revenue' ? "$".concat(value) : value;
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
},
|
|
232
|
+
grid: {
|
|
233
|
+
show: true,
|
|
234
|
+
borderColor: '#f1f1f1',
|
|
235
|
+
strokeDashArray: 4,
|
|
236
|
+
position: 'back'
|
|
237
|
+
},
|
|
238
|
+
// Use primary main and a darker version of it for differentiation
|
|
239
|
+
colors: [theme.palette.primary.main, '#4B4BC2'],
|
|
240
|
+
dataLabels: {
|
|
241
|
+
enabled: false
|
|
242
|
+
},
|
|
243
|
+
tooltip: {
|
|
244
|
+
theme: 'light',
|
|
245
|
+
y: {
|
|
246
|
+
formatter: function formatter(value) {
|
|
247
|
+
return metric === 'Revenue' ? "$".concat(value) : value;
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
},
|
|
251
|
+
legend: {
|
|
252
|
+
show: stacked,
|
|
253
|
+
position: 'top',
|
|
254
|
+
horizontalAlign: 'left'
|
|
255
|
+
}
|
|
256
|
+
};
|
|
257
|
+
var chartSeries = series || [{
|
|
258
|
+
name: metric,
|
|
259
|
+
data: data
|
|
260
|
+
}];
|
|
261
|
+
return /*#__PURE__*/React.createElement(Chart, {
|
|
262
|
+
options: chartOptions,
|
|
263
|
+
series: chartSeries,
|
|
264
|
+
type: "area",
|
|
265
|
+
height: height,
|
|
266
|
+
width: "100%"
|
|
267
|
+
});
|
|
268
|
+
};
|
|
269
|
+
|
|
270
|
+
var Dashboard = function Dashboard(_ref) {
|
|
271
|
+
var _ref$title = _ref.title,
|
|
272
|
+
title = _ref$title === void 0 ? "Overview" : _ref$title,
|
|
273
|
+
_ref$initialMetric = _ref.initialMetric,
|
|
274
|
+
initialMetric = _ref$initialMetric === void 0 ? 'Revenue' : _ref$initialMetric,
|
|
275
|
+
_ref$revenueData = _ref.revenueData,
|
|
276
|
+
revenueData = _ref$revenueData === void 0 ? [3000, 4500, 4200, 5800, 5200, 7100, 8500, 9200, 5000] : _ref$revenueData,
|
|
277
|
+
_ref$donationsData = _ref.donationsData,
|
|
278
|
+
donationsData = _ref$donationsData === void 0 ? [15, 22, 18, 30, 25, 35, 42, 45, 28] : _ref$donationsData,
|
|
279
|
+
_ref$categories = _ref.categories,
|
|
280
|
+
categories = _ref$categories === void 0 ? ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep'] : _ref$categories;
|
|
281
|
+
var _React$useState = React.useState(initialMetric),
|
|
282
|
+
_React$useState2 = _slicedToArray(_React$useState, 2),
|
|
283
|
+
metric = _React$useState2[0],
|
|
284
|
+
setMetric = _React$useState2[1];
|
|
285
|
+
var currentData = metric === 'Revenue' ? revenueData : donationsData;
|
|
286
|
+
var primaryCharts = [{
|
|
287
|
+
label: 'Total Revenue',
|
|
288
|
+
value: '$9,200.00',
|
|
289
|
+
subValue: 'Total Donations: 215',
|
|
290
|
+
data: currentData,
|
|
291
|
+
categories: categories,
|
|
292
|
+
showSelector: true
|
|
293
|
+
}, {
|
|
294
|
+
label: 'First installments',
|
|
295
|
+
value: '$510.00',
|
|
296
|
+
data: currentData.slice(-7),
|
|
297
|
+
categories: categories.slice(-7)
|
|
298
|
+
}, {
|
|
299
|
+
label: 'One-time donations',
|
|
300
|
+
value: '$7,100.00',
|
|
301
|
+
data: currentData,
|
|
302
|
+
categories: categories
|
|
303
|
+
}];
|
|
304
|
+
var secondaryCharts = [{
|
|
305
|
+
label: 'New vs Returning Donors',
|
|
306
|
+
series: [{
|
|
307
|
+
name: 'New Donors',
|
|
308
|
+
data: [10, 15, 12, 20, 18, 25, 30, 35, 20]
|
|
309
|
+
}, {
|
|
310
|
+
name: 'Returning',
|
|
311
|
+
data: [5, 7, 6, 10, 7, 10, 12, 10, 8]
|
|
312
|
+
}],
|
|
313
|
+
categories: categories,
|
|
314
|
+
stacked: true,
|
|
315
|
+
footer: {
|
|
316
|
+
left: 'New donors: 195',
|
|
317
|
+
right: 'Returning donors: 20'
|
|
318
|
+
}
|
|
319
|
+
}, {
|
|
320
|
+
label: 'Average Donation Amount',
|
|
321
|
+
value: '$42.80',
|
|
322
|
+
data: currentData.map(function (v) {
|
|
323
|
+
return v * 0.5;
|
|
324
|
+
}),
|
|
325
|
+
categories: categories
|
|
326
|
+
}, {
|
|
327
|
+
label: 'Tip Amount',
|
|
328
|
+
value: '$1,250.00',
|
|
329
|
+
subValue: 'Number of Tips: 110',
|
|
330
|
+
data: currentData.map(function (v) {
|
|
331
|
+
return v * 0.2;
|
|
332
|
+
}),
|
|
333
|
+
categories: categories
|
|
334
|
+
}];
|
|
335
|
+
var tertiaryCharts = [{
|
|
336
|
+
label: 'Conversion Rate',
|
|
337
|
+
value: '2%',
|
|
338
|
+
data: [1.5, 1.8, 1.7, 2.1, 2.0, 1.9, 2.2, 2.5, 2.0],
|
|
339
|
+
categories: categories
|
|
340
|
+
}, {
|
|
341
|
+
label: 'Organic vs Paid Traffic',
|
|
342
|
+
series: [{
|
|
343
|
+
name: 'Organic',
|
|
344
|
+
data: [500, 600, 550, 700, 800, 750, 900, 1000, 950]
|
|
345
|
+
}, {
|
|
346
|
+
name: 'Paid',
|
|
347
|
+
data: [200, 250, 220, 300, 350, 320, 400, 450, 420]
|
|
348
|
+
}],
|
|
349
|
+
categories: categories,
|
|
350
|
+
stacked: true
|
|
351
|
+
}, {
|
|
352
|
+
label: 'Organic Donations',
|
|
353
|
+
value: '120',
|
|
354
|
+
data: [8, 12, 10, 15, 14, 18, 22, 20, 12],
|
|
355
|
+
categories: categories
|
|
356
|
+
}];
|
|
357
|
+
var quaternaryCharts = [{
|
|
358
|
+
label: 'Email Marketing',
|
|
359
|
+
value: '56',
|
|
360
|
+
data: [45, 48, 52, 50, 56, 54, 58, 60, 56],
|
|
361
|
+
categories: categories
|
|
362
|
+
}, {
|
|
363
|
+
label: 'Traffic source',
|
|
364
|
+
value: '23%',
|
|
365
|
+
data: [18, 22, 20, 25, 23, 21, 24, 26, 23],
|
|
366
|
+
categories: categories
|
|
367
|
+
}, {
|
|
368
|
+
label: 'URL',
|
|
369
|
+
value: '10%',
|
|
370
|
+
data: [8, 9, 11, 10, 10, 12, 9, 11, 10],
|
|
371
|
+
categories: categories
|
|
372
|
+
}];
|
|
373
|
+
var renderChartCard = function renderChartCard(item, index) {
|
|
374
|
+
var isPrimary = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
|
|
375
|
+
return /*#__PURE__*/React.createElement(Grid, {
|
|
376
|
+
item: true,
|
|
377
|
+
xs: 12,
|
|
378
|
+
md: 4,
|
|
379
|
+
key: item.label + index,
|
|
380
|
+
sx: {
|
|
381
|
+
display: 'flex'
|
|
382
|
+
}
|
|
383
|
+
}, /*#__PURE__*/React.createElement(Card, {
|
|
384
|
+
sx: {
|
|
385
|
+
width: '100%',
|
|
386
|
+
display: 'flex',
|
|
387
|
+
flexDirection: 'column',
|
|
388
|
+
boxShadow: '0 4px 24px rgba(0,0,0,0.06)',
|
|
389
|
+
borderRadius: 4,
|
|
390
|
+
border: '1px solid #f0f0f0'
|
|
391
|
+
}
|
|
392
|
+
}, /*#__PURE__*/React.createElement(CardContent, {
|
|
393
|
+
sx: {
|
|
394
|
+
p: 3,
|
|
395
|
+
flexGrow: 1,
|
|
396
|
+
display: 'flex',
|
|
397
|
+
flexDirection: 'column'
|
|
398
|
+
}
|
|
399
|
+
}, /*#__PURE__*/React.createElement(Box, {
|
|
400
|
+
sx: {
|
|
401
|
+
display: 'flex',
|
|
402
|
+
justifyContent: 'space-between',
|
|
403
|
+
alignItems: 'flex-start',
|
|
404
|
+
mb: 2
|
|
405
|
+
}
|
|
406
|
+
}, /*#__PURE__*/React.createElement(Box, {
|
|
407
|
+
sx: {
|
|
408
|
+
textAlign: 'left'
|
|
409
|
+
}
|
|
410
|
+
}, /*#__PURE__*/React.createElement(Typography, {
|
|
411
|
+
variant: "subtitle2",
|
|
412
|
+
sx: {
|
|
413
|
+
color: '#000000',
|
|
414
|
+
fontWeight: 600,
|
|
415
|
+
textTransform: 'uppercase',
|
|
416
|
+
letterSpacing: '0.5px',
|
|
417
|
+
mb: 0.5
|
|
418
|
+
}
|
|
419
|
+
}, item.label), item.value && /*#__PURE__*/React.createElement(Typography, {
|
|
420
|
+
variant: "subtitle2",
|
|
421
|
+
sx: {
|
|
422
|
+
fontWeight: 600,
|
|
423
|
+
color: '#000000',
|
|
424
|
+
mb: 0.5
|
|
425
|
+
}
|
|
426
|
+
}, item.value), item.subValue && /*#__PURE__*/React.createElement(Typography, {
|
|
427
|
+
variant: "subtitle2",
|
|
428
|
+
sx: {
|
|
429
|
+
color: '#000000',
|
|
430
|
+
fontWeight: 600
|
|
431
|
+
}
|
|
432
|
+
}, item.subValue)), /*#__PURE__*/React.createElement(Box, {
|
|
433
|
+
sx: {
|
|
434
|
+
display: 'flex',
|
|
435
|
+
gap: 1
|
|
436
|
+
}
|
|
437
|
+
}, item.showSelector && /*#__PURE__*/React.createElement(MetricSelector, {
|
|
438
|
+
metric: metric,
|
|
439
|
+
onMetricChange: setMetric,
|
|
440
|
+
options: ['Revenue', 'Donations']
|
|
441
|
+
}), /*#__PURE__*/React.createElement(IconButton, {
|
|
442
|
+
sx: {
|
|
443
|
+
border: '1px solid #E9E9EB',
|
|
444
|
+
borderRadius: '8px',
|
|
445
|
+
color: '#000',
|
|
446
|
+
height: '40px',
|
|
447
|
+
width: '40px',
|
|
448
|
+
'&:hover': {
|
|
449
|
+
borderColor: 'primary.main',
|
|
450
|
+
bgcolor: 'rgba(99, 99, 230, 0.04)'
|
|
451
|
+
}
|
|
452
|
+
}
|
|
453
|
+
}, /*#__PURE__*/React.createElement(MoreHoriz, {
|
|
454
|
+
sx: {
|
|
455
|
+
fontSize: '1.2rem'
|
|
456
|
+
}
|
|
457
|
+
})))), /*#__PURE__*/React.createElement(Box, {
|
|
458
|
+
sx: {
|
|
459
|
+
flexGrow: 1,
|
|
460
|
+
minHeight: isPrimary ? '250px' : '200px'
|
|
461
|
+
}
|
|
462
|
+
}, /*#__PURE__*/React.createElement(RevenueChart, {
|
|
463
|
+
metric: item.label.includes('Rate') || item.label.includes('Performance') || item.label.includes('source') || item.label === 'URL' ? 'Percent' : item.stacked ? item.label.includes('Traffic') ? 'Visitors' : 'Donors' : metric,
|
|
464
|
+
data: item.data,
|
|
465
|
+
series: item.series,
|
|
466
|
+
categories: item.categories,
|
|
467
|
+
height: isPrimary ? 250 : 200,
|
|
468
|
+
stacked: item.stacked
|
|
469
|
+
})), item.footer && /*#__PURE__*/React.createElement(Box, {
|
|
470
|
+
sx: {
|
|
471
|
+
display: 'flex',
|
|
472
|
+
justifyContent: 'space-between',
|
|
473
|
+
mt: 2,
|
|
474
|
+
pt: 2,
|
|
475
|
+
borderTop: '1px solid #f0f0f0'
|
|
476
|
+
}
|
|
477
|
+
}, /*#__PURE__*/React.createElement(Typography, {
|
|
478
|
+
variant: "caption",
|
|
479
|
+
sx: {
|
|
480
|
+
color: '#606062',
|
|
481
|
+
fontWeight: 600
|
|
482
|
+
}
|
|
483
|
+
}, item.footer.left), /*#__PURE__*/React.createElement(Typography, {
|
|
484
|
+
variant: "caption",
|
|
485
|
+
sx: {
|
|
486
|
+
color: '#606062',
|
|
487
|
+
fontWeight: 600
|
|
488
|
+
}
|
|
489
|
+
}, item.footer.right)))));
|
|
490
|
+
};
|
|
491
|
+
return /*#__PURE__*/React.createElement(ThemeProvider, {
|
|
492
|
+
theme: theme
|
|
493
|
+
}, /*#__PURE__*/React.createElement(Box, {
|
|
494
|
+
sx: {
|
|
495
|
+
p: 4,
|
|
496
|
+
bgcolor: 'primary.mainLight',
|
|
497
|
+
minHeight: '100vh',
|
|
498
|
+
display: 'flex',
|
|
499
|
+
flexDirection: 'column',
|
|
500
|
+
alignItems: 'stretch'
|
|
501
|
+
}
|
|
502
|
+
}, /*#__PURE__*/React.createElement(Typography, {
|
|
503
|
+
variant: "h4",
|
|
504
|
+
gutterBottom: true,
|
|
505
|
+
sx: {
|
|
506
|
+
fontWeight: 'bold',
|
|
507
|
+
color: 'primary.main',
|
|
508
|
+
mb: 4
|
|
509
|
+
}
|
|
510
|
+
}, title), /*#__PURE__*/React.createElement(Grid, {
|
|
511
|
+
container: true,
|
|
512
|
+
spacing: 3,
|
|
513
|
+
sx: {
|
|
514
|
+
mb: 1
|
|
515
|
+
}
|
|
516
|
+
}, primaryCharts.map(function (item, index) {
|
|
517
|
+
return renderChartCard(item, index, true);
|
|
518
|
+
})), /*#__PURE__*/React.createElement(Grid, {
|
|
519
|
+
container: true,
|
|
520
|
+
spacing: 3,
|
|
521
|
+
sx: {
|
|
522
|
+
mt: 1
|
|
523
|
+
}
|
|
524
|
+
}, secondaryCharts.map(function (item, index) {
|
|
525
|
+
return renderChartCard(item, index, false);
|
|
526
|
+
})), /*#__PURE__*/React.createElement(Grid, {
|
|
527
|
+
container: true,
|
|
528
|
+
spacing: 3,
|
|
529
|
+
sx: {
|
|
530
|
+
mt: 1
|
|
531
|
+
}
|
|
532
|
+
}, tertiaryCharts.map(function (item, index) {
|
|
533
|
+
return renderChartCard(item, index, false);
|
|
534
|
+
})), /*#__PURE__*/React.createElement(Grid, {
|
|
535
|
+
container: true,
|
|
536
|
+
spacing: 3,
|
|
537
|
+
sx: {
|
|
538
|
+
mt: 1
|
|
539
|
+
}
|
|
540
|
+
}, quaternaryCharts.map(function (item, index) {
|
|
541
|
+
return renderChartCard(item, index, false);
|
|
542
|
+
}))));
|
|
543
|
+
};
|
|
544
|
+
|
|
545
|
+
/**
|
|
546
|
+
* Theme colors for server components
|
|
547
|
+
*
|
|
548
|
+
* These are plain JavaScript objects that can be safely imported
|
|
549
|
+
* in both server and client components without triggering
|
|
550
|
+
* client-only code in server components.
|
|
551
|
+
*
|
|
552
|
+
* For client components, use the full theme from @/config/customTheme
|
|
553
|
+
*/
|
|
554
|
+
|
|
555
|
+
var themeColors = {
|
|
556
|
+
primary: {
|
|
557
|
+
main: "#6363E6",
|
|
558
|
+
mainLight: "#F7F7FF",
|
|
559
|
+
light: "#FFFFFF",
|
|
560
|
+
gray: "#A1A1A8",
|
|
561
|
+
lightGreen: "#E1FBF2",
|
|
562
|
+
green: "#0CAB72",
|
|
563
|
+
red: "#E61D1D",
|
|
564
|
+
lightRed: "#FFEDED",
|
|
565
|
+
lightGray: "#E9E9EB",
|
|
566
|
+
darkGray: "#606062",
|
|
567
|
+
dark: "#090909"
|
|
568
|
+
},
|
|
569
|
+
text: {
|
|
570
|
+
primary: "#666666"
|
|
571
|
+
},
|
|
572
|
+
secondary: {
|
|
573
|
+
main: "#E0C2FF",
|
|
574
|
+
light: "#F5EBFF",
|
|
575
|
+
contrastText: "#47008F"
|
|
576
|
+
},
|
|
577
|
+
white: {
|
|
578
|
+
main: "#FFFFFF",
|
|
579
|
+
light: "#F8F8F8"
|
|
580
|
+
},
|
|
581
|
+
gradients: {
|
|
582
|
+
primary: "linear-gradient(90deg, #6363E6 0.05%, #59C9F9 99.96%)",
|
|
583
|
+
secondary: "linear-gradient(180deg, #E9E9FF 0%, #C9EEFF 100%)"
|
|
584
|
+
}
|
|
585
|
+
};
|
|
586
|
+
|
|
587
|
+
// Typography settings for server components
|
|
588
|
+
var themeTypography = {
|
|
589
|
+
fontFamily: ["var(--font-league-spartan)", "var(--font-noto-sans-arabic)", "-apple-system", "BlinkMacSystemFont", "Segoe UI", "Roboto", "Helvetica Neue", "Arial", "sans-serif", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol"].join(",")
|
|
590
|
+
};
|
|
591
|
+
|
|
592
|
+
export { Dashboard, theme as DashboardTheme, MetricSelector, RevenueChart, themeColors, themeTypography };
|
|
593
|
+
//# sourceMappingURL=index.es.js.map
|