ECommerceTotalRevenue.vue 1.71 KB
<script setup lang="ts">
import { useTheme } from 'vuetify'

const vuetifyTheme = useTheme()

const series = [
  {
    data: [28, 58, 40, 68],
  },
]

const chartOptions = computed(() => {
  const currentTheme = vuetifyTheme.current.value.colors

  return {
    grid: {
      show: false,
      padding: {
        left: -2,
        top: -10,
      },
    },
    chart: {
      parentHeightOffset: 0,
      type: 'line',
      dropShadow: {
        enabled: true,
        top: 10,
        blur: 4,
        color: currentTheme.primary,
        opacity: 0.09,
      },
      toolbar: {
        show: false,
      },
    },
    markers: {
      size: 6,
      colors: 'transparent',
      strokeColors: 'transparent',
      strokeWidth: 4,
      discrete: [
        {
          seriesIndex: 0,
          dataPointIndex: series[0].data.length - 1,
          fillColor: currentTheme.surface,
          strokeColor: currentTheme.primary,
          size: 6,
        },
      ],
      hover: {
        size: 7,
      },
    },
    stroke: {
      width: 5,
      curve: 'smooth',
      lineCap: 'round',
    },
    xaxis: {
      axisBorder: {
        show: false,
      },
      axisTicks: {
        show: false,
      },
      labels: {
        show: false,
      },
    },
    yaxis: {
      labels: {
        show: false,
      },
    },
    tooltip: {
      enabled: false,
    },

    colors: [currentTheme.primary],
  }
})
</script>

<template>
  <VCard>
    <VCardText>
      <h4 class="text-h4">
        $35.4k
      </h4>
      <VueApexCharts
        :options="chartOptions"
        :series="series"
        :height="110"
      />

      <h6 class="text-h6 text-center">
        Total Revenue
      </h6>
    </VCardText>
  </VCard>
</template>