LogisticsVehicleOverview.vue 3.38 KB
<script setup lang="ts">
const vehicleData = [
  { icon: 'ri-car-line', title: 'On the way', time: '2hr 10min', percentage: 39.7, color: { bg: 'rgba(var(--v-theme-on-surface), var(--v-hover-opacity))', text: 'rgba(var(--v-theme-on-surface), var(--v-high-emphasis-opacity))' } },
  { icon: 'ri-download-cloud-2-line', title: 'Unloading', time: '3hr 15min', percentage: 28.3, color: { bg: 'rgb(var(--v-theme-primary))', text: 'rgb(var(--v-theme-on-primary))' } },
  { icon: 'ri-upload-line', title: 'Loading', time: '1hr 24min', percentage: 17.4, color: { bg: 'rgb(var(--v-theme-info))', text: 'rgb(var(--v-theme-on-primary))' } },
  { icon: 'ri-timer-line', title: 'Waiting', time: '5hr 19min', percentage: 14.6, color: { bg: 'rgb(var(--v-tooltip-background))', text: 'rgba(var(--v-theme-surface))' } },
]
</script>

<template>
  <VCard>
    <VCardItem title="Vehicles Overview">
      <template #append>
        <MoreBtn />
      </template>
    </VCardItem>
    <VCardText>
      <div class="d-flex mb-6">
        <div
          v-for="(item, index) in vehicleData"
          :key="item.title"
          :style="`inline-size: ${item.percentage}%;`"
        >
          <div class="vehicle-progress-label position-relative mb-4 text-body-1 d-none d-sm-block">
            {{ item.title }}
          </div>
          <VProgressLinear
            :color="item.color.bg"
            model-value="100"
            height="46"
            :class="index === 0 ? 'rounded-s' : index === vehicleData.length - 1 ? 'rounded-e' : ''"
          >
            <p
              class="text-sm font-weight-medium mb-0"
              :style="`color: ${item.color.text}`"
            >
              {{ item.percentage }}%
            </p>
          </VProgressLinear>
        </div>
      </div>
      <VTable class="text-no-wrap">
        <tbody>
          <tr
            v-for="(vehicle, index) in vehicleData"
            :key="index"
          >
            <td
              width="70%"
              class="ps-0"
            >
              <div class="d-flex align-center text-high-emphasis">
                <VIcon
                  :icon="vehicle.icon"
                  size="24"
                  class="me-2"
                />
                <h6 class="text-h6 font-weight-regular">
                  {{ vehicle.title }}
                </h6>
              </div>
            </td>
            <td>
              <h6 class="text-h6">
                {{ vehicle.time }}
              </h6>
            </td>
            <td>
              <span class="text-body-1">{{ vehicle.percentage }}%</span>
            </td>
          </tr>
        </tbody>
      </VTable>
    </VCardText>
  </VCard>
</template>

<style lang="scss" scoped>
.vehicle-progress-label {
  padding-block-end: 1rem;

  &::after {
    position: absolute;
    display: inline-block;
    background-color: rgba(var(--v-theme-on-surface), var(--v-border-opacity));
    block-size: 10px;
    content: "";
    inline-size: 2px;
    inset-block-end: 0;
    inset-inline-start: 0;

    [dir="rtl"] & {
      inset-inline: unset 0;
    }
  }
}
</style>

<style lang="scss">
.v-progress-linear__content {
  justify-content: start;
  padding-inline-start: 1rem;
}

@media (max-width: 1080px) {
  .v-progress-linear__content {
    padding-inline-start: 0.75rem !important;
  }
}

@media (max-width: 576px) {
  .v-progress-linear__content {
    padding-inline-start: 0.3rem !important;
  }
}
</style>