1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- <!-- Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/ -->
- <script setup lang="ts">
- import { computed } from 'vue'
- import { EnumTicketStateColorCode } from '#shared/graphql/types.ts'
- export interface Props {
- colorCode: EnumTicketStateColorCode
- label: string
- pill?: boolean
- }
- const props = withDefaults(defineProps<Props>(), {
- pill: false,
- })
- const textClass = computed(() => {
- switch (props.colorCode) {
- case EnumTicketStateColorCode.Closed:
- return 'text-green'
- case EnumTicketStateColorCode.Pending:
- return 'text-gray'
- case EnumTicketStateColorCode.Escalating:
- return 'text-red-bright'
- case EnumTicketStateColorCode.Open:
- default:
- return 'text-yellow'
- }
- })
- const backgroundClass = computed(() => {
- if (!props.pill) return
- switch (props.colorCode) {
- case EnumTicketStateColorCode.Closed:
- return 'bg-green-highlight'
- case EnumTicketStateColorCode.Pending:
- return 'bg-gray-highlight'
- case EnumTicketStateColorCode.Escalating:
- return 'bg-red-dark'
- case EnumTicketStateColorCode.Open:
- default:
- return 'bg-yellow-highlight'
- }
- })
- </script>
- <template>
- <div
- :class="[
- textClass,
- backgroundClass,
- {
- 'rounded py-1 ltr:pl-1 ltr:pr-1.5 rtl:pl-1.5 rtl:pr-1': pill,
- },
- ]"
- class="flex select-none items-center"
- role="group"
- >
- <CommonIcon
- :size="pill ? 'tiny' : 'base'"
- :label="$t('(state: %s)', $t(label))"
- name="ticket-state-circle"
- />
- <div
- v-if="pill"
- class="text-xs uppercase leading-[14px] ltr:ml-[2px] rtl:mr-[2px]"
- aria-hidden="true"
- >
- {{ $t(label) }}
- </div>
- </div>
- </template>
|