1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- <!-- Copyright (C) 2012-2024 Zammad Foundation, https://zammad-foundation.org/ -->
- <script setup lang="ts">
- import { useVModel } from '@vueuse/core'
- import { shallowRef } from 'vue'
- export interface CommonInputSearchProps {
- modelValue?: string
- noBorder?: boolean
- wrapperClass?: string
- placeholder?: string
- }
- export interface CommonInputSearchEmits {
- (e: 'update:modelValue', filter: string): void
- }
- export interface CommonInputSearchExpose {
- focus(): void
- }
- const props = withDefaults(defineProps<CommonInputSearchProps>(), {
- placeholder: __('Search…'),
- })
- const emit = defineEmits<CommonInputSearchEmits>()
- const filter = useVModel(props, 'modelValue', emit)
- const filterInput = shallowRef<HTMLInputElement>()
- const focus = () => {
- filterInput.value?.focus()
- }
- defineExpose({ focus })
- const clearFilter = () => {
- filter.value = ''
- focus()
- }
- </script>
- <script lang="ts">
- export default {
- inheritAttrs: false,
- }
- </script>
- <template>
- <div
- class="relative flex w-full items-center self-stretch"
- :class="wrapperClass"
- >
- <CommonIcon
- class="text-gray absolute shrink-0 ltr:left-2 rtl:right-2"
- size="base"
- name="search"
- decorative
- />
- <input
- ref="filterInput"
- v-model="filter"
- v-bind="$attrs"
- :placeholder="i18n.t(placeholder)"
- class="placeholder:text-gray h-12 w-full grow rounded-xl bg-gray-500 px-9 text-base focus:shadow-none focus:outline-none focus:ring-0"
- :class="{
- 'focus:border-white focus:ring-0': !noBorder,
- 'focus:border-transparent': noBorder,
- }"
- :aria-label="$t('Search…')"
- type="text"
- role="searchbox"
- />
- <div class="absolute flex shrink-0 items-center ltr:right-2 rtl:left-2">
- <slot name="controls" />
- <CommonIcon
- v-if="filter && filter.length"
- :aria-label="i18n.t('Clear Search')"
- class="text-gray"
- size="base"
- name="input-cancel"
- @click.stop="clearFilter"
- />
- </div>
- </div>
- </template>
|