@vuetify/nightly 3.1.2-next-20230113.0 → 3.1.2
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/CHANGELOG.md +15 -2
- package/dist/json/importMap.json +56 -56
- package/dist/vuetify-labs.css +178 -177
- package/dist/vuetify-labs.d.ts +40 -3
- package/dist/vuetify-labs.esm.js +158 -90
- package/dist/vuetify-labs.esm.js.map +1 -1
- package/dist/vuetify-labs.js +158 -90
- package/dist/vuetify-labs.min.css +2 -2
- package/dist/vuetify.css +203 -202
- package/dist/vuetify.d.ts +56 -19
- package/dist/vuetify.esm.js +105 -74
- package/dist/vuetify.esm.js.map +1 -1
- package/dist/vuetify.js +105 -74
- package/dist/vuetify.js.map +1 -1
- package/dist/vuetify.min.css +2 -2
- package/dist/vuetify.min.js +52 -52
- package/dist/vuetify.min.js.map +1 -1
- package/lib/components/VAutocomplete/VAutocomplete.mjs +1 -0
- package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
- package/lib/components/VBtn/VBtn.mjs +9 -3
- package/lib/components/VBtn/VBtn.mjs.map +1 -1
- package/lib/components/VCard/VCard.mjs +5 -2
- package/lib/components/VCard/VCard.mjs.map +1 -1
- package/lib/components/VCard/index.d.ts +8 -2
- package/lib/components/VCombobox/VCombobox.mjs +2 -1
- package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
- package/lib/components/VFileInput/VFileInput.css +1 -0
- package/lib/components/VFileInput/VFileInput.sass +1 -0
- package/lib/components/VList/VListItem.css +1 -1
- package/lib/components/VList/VListItem.mjs +5 -1
- package/lib/components/VList/VListItem.mjs.map +1 -1
- package/lib/components/VList/VListItem.sass +1 -1
- package/lib/components/VList/index.d.ts +20 -1
- package/lib/components/VProgressLinear/VProgressLinear.mjs +13 -1
- package/lib/components/VProgressLinear/VProgressLinear.mjs.map +1 -1
- package/lib/components/VProgressLinear/index.d.ts +18 -0
- package/lib/components/VSelect/VSelect.mjs +1 -0
- package/lib/components/VSelect/VSelect.mjs.map +1 -1
- package/lib/components/VSlider/VSliderThumb.mjs +5 -1
- package/lib/components/VSlider/VSliderThumb.mjs.map +1 -1
- package/lib/components/index.d.ts +40 -3
- package/lib/composables/filter.mjs +3 -3
- package/lib/composables/filter.mjs.map +1 -1
- package/lib/entry-bundler.mjs +1 -1
- package/lib/entry-bundler.mjs.map +1 -1
- package/lib/framework.mjs +1 -1
- package/lib/framework.mjs.map +1 -1
- package/lib/index.d.ts +16 -16
- package/lib/labs/VDataTable/VDataTable.mjs +4 -1
- package/lib/labs/VDataTable/VDataTable.mjs.map +1 -1
- package/lib/labs/VDataTable/VDataTableGroupHeaderRow.mjs +3 -3
- package/lib/labs/VDataTable/VDataTableGroupHeaderRow.mjs.map +1 -1
- package/lib/labs/VDataTable/VDataTableRows.mjs +36 -8
- package/lib/labs/VDataTable/VDataTableRows.mjs.map +1 -1
- package/lib/labs/VDataTable/VDataTableVirtual.mjs +4 -1
- package/lib/labs/VDataTable/VDataTableVirtual.mjs.map +1 -1
- package/lib/labs/VDataTable/composables/group.mjs +9 -4
- package/lib/labs/VDataTable/composables/group.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -217,6 +217,7 @@ export const VAutocomplete = genericComponent()({
|
|
|
217
217
|
"activator": "parent",
|
|
218
218
|
"contentClass": "v-autocomplete__content",
|
|
219
219
|
"eager": props.eager,
|
|
220
|
+
"maxHeight": 310,
|
|
220
221
|
"openOnClick": false,
|
|
221
222
|
"closeOnContentClick": false,
|
|
222
223
|
"transition": props.transition,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VAutocomplete.mjs","names":["makeSelectProps","VCheckboxBtn","VChip","VDefaultsProvider","VList","VListItem","VMenu","VTextField","forwardRefs","makeFilterProps","useFilter","makeTransitionProps","useForm","useItems","useLocale","useProxiedModel","computed","mergeProps","nextTick","ref","watch","genericComponent","omit","useRender","wrapInArray","filterVTextFieldProps","makeVTextFieldProps","highlightResult","text","matches","length","Array","isArray","Error","substr","VAutocomplete","name","props","search","String","filterKeys","modelValue","transition","emits","val","setup","slots","t","vTextFieldRef","isFocused","isPristine","menu","items","transformIn","transformOut","model","v","transformed","multiple","form","filteredItems","getMatches","value","undefined","selections","map","find","item","valueComparator","displayItems","hideSelected","filter","filteredItem","some","s","selected","selection","listRef","onClear","e","openOnClear","onClickControl","hideNoData","readonly","isReadonly","onKeydown","includes","key","preventDefault","focus","onInput","target","onAfterLeave","onFocusin","onFocusout","relatedTarget","isSelecting","select","index","findIndex","splice","title","at","hasChips","chips","chip","hasList","prepend","append","textFieldProps","externalValue","menuIcon","default","eager","menuProps","noDataText","onClick","isSelected","onChipClose","stopPropagation","slotProps","closable","closableChips","size"],"sources":["../../../src/components/VAutocomplete/VAutocomplete.tsx"],"sourcesContent":["// Styles\nimport './VAutocomplete.sass'\n\n// Components\nimport { makeSelectProps } from '@/components/VSelect/VSelect'\nimport { VCheckboxBtn } from '@/components/VCheckbox'\nimport { VChip } from '@/components/VChip'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VList, VListItem } from '@/components/VList'\nimport { VMenu } from '@/components/VMenu'\nimport { VTextField } from '@/components/VTextField'\n\n// Composables\nimport { forwardRefs } from '@/composables/forwardRefs'\nimport { makeFilterProps, useFilter } from '@/composables/filter'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { useForm } from '@/composables/form'\nimport { useItems } from '@/composables/items'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utility\nimport { computed, mergeProps, nextTick, ref, watch } from 'vue'\nimport { genericComponent, omit, useRender, wrapInArray } from '@/util'\nimport { filterVTextFieldProps, makeVTextFieldProps } from '../VTextField/VTextField'\n\n// Types\nimport type { FilterMatch } from '@/composables/filter'\nimport type { InternalItem } from '@/composables/items'\nimport type { MakeSlots, SlotsToProps } from '@/util'\nimport type { VFieldSlots } from '@/components/VField/VField'\nimport type { VInputSlots } from '@/components/VInput/VInput'\n\nfunction highlightResult (text: string, matches: FilterMatch | undefined, length: number) {\n if (matches == null) return text\n\n if (Array.isArray(matches)) throw new Error('Multiple matches is not implemented')\n\n return typeof matches === 'number' && ~matches\n ? (\n <>\n <span class=\"v-autocomplete__unmask\">{ text.substr(0, matches) }</span>\n <span class=\"v-autocomplete__mask\">{ text.substr(matches, length) }</span>\n <span class=\"v-autocomplete__unmask\">{ text.substr(matches + length) }</span>\n </>\n )\n : text\n}\n\ntype Primitive = string | number | boolean | symbol\n\ntype Val <T, ReturnObject extends boolean> = T extends Primitive\n ? T\n : (ReturnObject extends true ? T : any)\n\ntype Value <T, ReturnObject extends boolean, Multiple extends boolean> =\n Multiple extends true\n ? readonly Val<T, ReturnObject>[]\n : Val<T, ReturnObject>\n\nexport const VAutocomplete = genericComponent<new <\n T,\n ReturnObject extends boolean = false,\n Multiple extends boolean = false,\n V extends Value<T, ReturnObject, Multiple> = Value<T, ReturnObject, Multiple>\n>() => {\n $props: {\n items?: readonly T[]\n returnObject?: ReturnObject\n multiple?: Multiple\n modelValue?: V\n 'onUpdate:modelValue'?: (val: V) => void\n } & SlotsToProps<\n Omit<VInputSlots & VFieldSlots, 'default'> & MakeSlots<{\n item: [{ item: InternalItem<T>, index: number, props: Record<string, unknown> }]\n chip: [{ item: InternalItem<T>, index: number, props: Record<string, unknown> }]\n selection: [{ item: InternalItem<T>, index: number }]\n 'prepend-item': []\n 'append-item': []\n 'no-data': []\n }>\n >\n}>()({\n name: 'VAutocomplete',\n\n props: {\n // TODO: implement post keyboard support\n // autoSelectFirst: Boolean,\n search: String,\n\n ...makeFilterProps({ filterKeys: ['title'] }),\n ...makeSelectProps(),\n ...omit(makeVTextFieldProps({\n modelValue: null,\n }), ['validationValue', 'dirty', 'appendInnerIcon']),\n ...makeTransitionProps({ transition: false }),\n },\n\n emits: {\n 'update:search': (val: any) => true,\n 'update:modelValue': (val: any) => true,\n 'update:menu': (val: boolean) => true,\n },\n\n setup (props, { slots }) {\n const { t } = useLocale()\n const vTextFieldRef = ref()\n const isFocused = ref(false)\n const isPristine = ref(true)\n const menu = useProxiedModel(props, 'menu')\n const { items, transformIn, transformOut } = useItems(props)\n const search = useProxiedModel(props, 'search', '')\n const model = useProxiedModel(\n props,\n 'modelValue',\n [],\n v => transformIn(wrapInArray(v)),\n v => {\n const transformed = transformOut(v)\n return props.multiple ? transformed : (transformed[0] ?? null)\n }\n )\n const form = useForm()\n const { filteredItems, getMatches } = useFilter(props, items, computed(() => isPristine.value ? undefined : search.value))\n const selections = computed(() => {\n return model.value.map(v => {\n return items.value.find(item => props.valueComparator(item.value, v.value)) || v\n })\n })\n\n const displayItems = computed(() => {\n if (props.hideSelected) {\n return filteredItems.value.filter(filteredItem => !selections.value.some(s => s.value === filteredItem.value))\n }\n return filteredItems.value\n })\n\n const selected = computed(() => selections.value.map(selection => selection.props.value))\n const listRef = ref<VList>()\n\n function onClear (e: MouseEvent) {\n model.value = []\n\n if (props.openOnClear) {\n menu.value = true\n }\n\n search.value = ''\n }\n function onClickControl () {\n if (\n (props.hideNoData && !items.value.length) ||\n props.readonly || form?.isReadonly.value\n ) return\n\n menu.value = true\n }\n function onKeydown (e: KeyboardEvent) {\n if (props.readonly || form?.isReadonly.value) return\n\n if (['Enter', 'ArrowDown'].includes(e.key)) {\n menu.value = true\n }\n\n if (['Escape'].includes(e.key)) {\n menu.value = false\n }\n\n if (['Enter', 'Escape', 'Tab'].includes(e.key)) {\n isPristine.value = true\n }\n\n if (e.key === 'ArrowDown') {\n e.preventDefault()\n listRef.value?.focus('next')\n } else if (e.key === 'ArrowUp') {\n e.preventDefault()\n listRef.value?.focus('prev')\n }\n }\n\n function onInput (e: InputEvent) {\n search.value = (e.target as HTMLInputElement).value\n }\n\n function onAfterLeave () {\n if (isFocused.value) isPristine.value = true\n }\n\n function onFocusin (e: FocusEvent) {\n isFocused.value = true\n }\n\n function onFocusout (e: FocusEvent) {\n if (e.relatedTarget == null) {\n vTextFieldRef.value?.focus()\n }\n }\n\n const isSelecting = ref(false)\n\n function select (item: InternalItem) {\n if (props.multiple) {\n const index = selected.value.findIndex(selection => props.valueComparator(selection, item.value))\n\n if (index === -1) {\n model.value = [...model.value, item]\n search.value = ''\n } else {\n const value = [...model.value]\n value.splice(index, 1)\n model.value = value\n }\n } else {\n model.value = [item]\n\n isSelecting.value = true\n\n if (!slots.selection) {\n search.value = item.title\n }\n\n menu.value = false\n isPristine.value = true\n\n nextTick(() => (isSelecting.value = false))\n }\n }\n\n watch(isFocused, val => {\n if (val) {\n isSelecting.value = true\n search.value = props.multiple || !!slots.selection ? '' : String(selections.value.at(-1)?.props.title ?? '')\n isPristine.value = true\n\n nextTick(() => isSelecting.value = false)\n } else {\n menu.value = false\n search.value = ''\n }\n })\n\n watch(search, val => {\n if (!isFocused.value || isSelecting.value) return\n\n if (val) menu.value = true\n\n isPristine.value = !val\n })\n\n useRender(() => {\n const hasChips = !!(props.chips || slots.chip)\n const hasList = !!((!props.hideNoData || displayItems.value.length) || slots.prepend || slots.append || slots['no-data'])\n const [textFieldProps] = filterVTextFieldProps(props)\n\n return (\n <VTextField\n ref={ vTextFieldRef }\n { ...textFieldProps }\n modelValue={ search.value }\n onUpdate:modelValue={ v => { if (v == null) model.value = [] } }\n validationValue={ model.externalValue }\n dirty={ model.value.length > 0 }\n onInput={ onInput }\n class={[\n 'v-autocomplete',\n {\n 'v-autocomplete--active-menu': menu.value,\n 'v-autocomplete--chips': !!props.chips,\n [`v-autocomplete--${props.multiple ? 'multiple' : 'single'}`]: true,\n 'v-autocomplete--selection-slot': !!slots.selection,\n },\n ]}\n appendInnerIcon={ props.menuIcon }\n readonly={ props.readonly }\n onClick:clear={ onClear }\n onClick:control={ onClickControl }\n onClick:input={ onClickControl }\n onFocus={ () => isFocused.value = true }\n onBlur={ () => isFocused.value = false }\n onKeydown={ onKeydown }\n >\n {{\n ...slots,\n default: () => (\n <>\n <VMenu\n v-model={ menu.value }\n activator=\"parent\"\n contentClass=\"v-autocomplete__content\"\n eager={ props.eager }\n openOnClick={ false }\n closeOnContentClick={ false }\n transition={ props.transition }\n onAfterLeave={ onAfterLeave }\n { ...props.menuProps }\n >\n { hasList && (\n <VList\n ref={ listRef }\n selected={ selected.value }\n selectStrategy={ props.multiple ? 'independent' : 'single-independent' }\n onMousedown={ (e: MouseEvent) => e.preventDefault() }\n onFocusin={ onFocusin }\n onFocusout={ onFocusout }\n >\n { !displayItems.value.length && !props.hideNoData && (slots['no-data']?.() ?? (\n <VListItem title={ t(props.noDataText) } />\n )) }\n\n { slots['prepend-item']?.() }\n\n { displayItems.value.map((item, index) => slots.item?.({\n item,\n index,\n props: mergeProps(item.props, { onClick: () => select(item) }),\n }) ?? (\n <VListItem\n key={ index }\n { ...item.props }\n onClick={ () => select(item) }\n >\n {{\n prepend: ({ isSelected }) => props.multiple && !props.hideSelected ? (\n <VCheckboxBtn modelValue={ isSelected } ripple={ false } />\n ) : undefined,\n title: () => {\n return isPristine.value\n ? item.title\n : highlightResult(item.title, getMatches(item)?.title, search.value?.length ?? 0)\n },\n }}\n </VListItem>\n )) }\n\n { slots['append-item']?.() }\n </VList>\n ) }\n </VMenu>\n\n { selections.value.map((item, index) => {\n function onChipClose (e: Event) {\n e.stopPropagation()\n e.preventDefault()\n\n select(item)\n }\n\n const slotProps = {\n 'onClick:close': onChipClose,\n modelValue: true,\n 'onUpdate:modelValue': undefined,\n }\n\n return (\n <div key={ item.value } class=\"v-autocomplete__selection\">\n { hasChips ? (\n <VDefaultsProvider\n defaults={{\n VChip: {\n closable: props.closableChips,\n size: 'small',\n text: item.title,\n },\n }}\n >\n { slots.chip\n ? slots.chip({ item, index, props: slotProps })\n : (<VChip { ...slotProps } />)\n }\n </VDefaultsProvider>\n ) : (\n slots.selection\n ? slots.selection({ item, index })\n : (\n <span class=\"v-autocomplete__selection-text\">\n { item.title }\n { props.multiple && (index < selections.value.length - 1) && (\n <span class=\"v-autocomplete__selection-comma\">,</span>\n ) }\n </span>\n )\n )}\n </div>\n )\n }) }\n </>\n ),\n }}\n </VTextField>\n )\n })\n\n return forwardRefs({\n isFocused,\n isPristine,\n menu,\n search,\n filteredItems,\n select,\n }, vTextFieldRef)\n },\n})\n\nexport type VAutocomplete = InstanceType<typeof VAutocomplete>\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"VAutocomplete.mjs","names":["makeSelectProps","VCheckboxBtn","VChip","VDefaultsProvider","VList","VListItem","VMenu","VTextField","forwardRefs","makeFilterProps","useFilter","makeTransitionProps","useForm","useItems","useLocale","useProxiedModel","computed","mergeProps","nextTick","ref","watch","genericComponent","omit","useRender","wrapInArray","filterVTextFieldProps","makeVTextFieldProps","highlightResult","text","matches","length","Array","isArray","Error","substr","VAutocomplete","name","props","search","String","filterKeys","modelValue","transition","emits","val","setup","slots","t","vTextFieldRef","isFocused","isPristine","menu","items","transformIn","transformOut","model","v","transformed","multiple","form","filteredItems","getMatches","value","undefined","selections","map","find","item","valueComparator","displayItems","hideSelected","filter","filteredItem","some","s","selected","selection","listRef","onClear","e","openOnClear","onClickControl","hideNoData","readonly","isReadonly","onKeydown","includes","key","preventDefault","focus","onInput","target","onAfterLeave","onFocusin","onFocusout","relatedTarget","isSelecting","select","index","findIndex","splice","title","at","hasChips","chips","chip","hasList","prepend","append","textFieldProps","externalValue","menuIcon","default","eager","menuProps","noDataText","onClick","isSelected","onChipClose","stopPropagation","slotProps","closable","closableChips","size"],"sources":["../../../src/components/VAutocomplete/VAutocomplete.tsx"],"sourcesContent":["// Styles\nimport './VAutocomplete.sass'\n\n// Components\nimport { makeSelectProps } from '@/components/VSelect/VSelect'\nimport { VCheckboxBtn } from '@/components/VCheckbox'\nimport { VChip } from '@/components/VChip'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VList, VListItem } from '@/components/VList'\nimport { VMenu } from '@/components/VMenu'\nimport { VTextField } from '@/components/VTextField'\n\n// Composables\nimport { forwardRefs } from '@/composables/forwardRefs'\nimport { makeFilterProps, useFilter } from '@/composables/filter'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { useForm } from '@/composables/form'\nimport { useItems } from '@/composables/items'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\n\n// Utility\nimport { computed, mergeProps, nextTick, ref, watch } from 'vue'\nimport { genericComponent, omit, useRender, wrapInArray } from '@/util'\nimport { filterVTextFieldProps, makeVTextFieldProps } from '../VTextField/VTextField'\n\n// Types\nimport type { FilterMatch } from '@/composables/filter'\nimport type { InternalItem } from '@/composables/items'\nimport type { MakeSlots, SlotsToProps } from '@/util'\nimport type { VFieldSlots } from '@/components/VField/VField'\nimport type { VInputSlots } from '@/components/VInput/VInput'\n\nfunction highlightResult (text: string, matches: FilterMatch | undefined, length: number) {\n if (matches == null) return text\n\n if (Array.isArray(matches)) throw new Error('Multiple matches is not implemented')\n\n return typeof matches === 'number' && ~matches\n ? (\n <>\n <span class=\"v-autocomplete__unmask\">{ text.substr(0, matches) }</span>\n <span class=\"v-autocomplete__mask\">{ text.substr(matches, length) }</span>\n <span class=\"v-autocomplete__unmask\">{ text.substr(matches + length) }</span>\n </>\n )\n : text\n}\n\ntype Primitive = string | number | boolean | symbol\n\ntype Val <T, ReturnObject extends boolean> = T extends Primitive\n ? T\n : (ReturnObject extends true ? T : any)\n\ntype Value <T, ReturnObject extends boolean, Multiple extends boolean> =\n Multiple extends true\n ? readonly Val<T, ReturnObject>[]\n : Val<T, ReturnObject>\n\nexport const VAutocomplete = genericComponent<new <\n T,\n ReturnObject extends boolean = false,\n Multiple extends boolean = false,\n V extends Value<T, ReturnObject, Multiple> = Value<T, ReturnObject, Multiple>\n>() => {\n $props: {\n items?: readonly T[]\n returnObject?: ReturnObject\n multiple?: Multiple\n modelValue?: V\n 'onUpdate:modelValue'?: (val: V) => void\n } & SlotsToProps<\n Omit<VInputSlots & VFieldSlots, 'default'> & MakeSlots<{\n item: [{ item: InternalItem<T>, index: number, props: Record<string, unknown> }]\n chip: [{ item: InternalItem<T>, index: number, props: Record<string, unknown> }]\n selection: [{ item: InternalItem<T>, index: number }]\n 'prepend-item': []\n 'append-item': []\n 'no-data': []\n }>\n >\n}>()({\n name: 'VAutocomplete',\n\n props: {\n // TODO: implement post keyboard support\n // autoSelectFirst: Boolean,\n search: String,\n\n ...makeFilterProps({ filterKeys: ['title'] }),\n ...makeSelectProps(),\n ...omit(makeVTextFieldProps({\n modelValue: null,\n }), ['validationValue', 'dirty', 'appendInnerIcon']),\n ...makeTransitionProps({ transition: false }),\n },\n\n emits: {\n 'update:search': (val: any) => true,\n 'update:modelValue': (val: any) => true,\n 'update:menu': (val: boolean) => true,\n },\n\n setup (props, { slots }) {\n const { t } = useLocale()\n const vTextFieldRef = ref()\n const isFocused = ref(false)\n const isPristine = ref(true)\n const menu = useProxiedModel(props, 'menu')\n const { items, transformIn, transformOut } = useItems(props)\n const search = useProxiedModel(props, 'search', '')\n const model = useProxiedModel(\n props,\n 'modelValue',\n [],\n v => transformIn(wrapInArray(v)),\n v => {\n const transformed = transformOut(v)\n return props.multiple ? transformed : (transformed[0] ?? null)\n }\n )\n const form = useForm()\n const { filteredItems, getMatches } = useFilter(props, items, computed(() => isPristine.value ? undefined : search.value))\n const selections = computed(() => {\n return model.value.map(v => {\n return items.value.find(item => props.valueComparator(item.value, v.value)) || v\n })\n })\n\n const displayItems = computed(() => {\n if (props.hideSelected) {\n return filteredItems.value.filter(filteredItem => !selections.value.some(s => s.value === filteredItem.value))\n }\n return filteredItems.value\n })\n\n const selected = computed(() => selections.value.map(selection => selection.props.value))\n const listRef = ref<VList>()\n\n function onClear (e: MouseEvent) {\n model.value = []\n\n if (props.openOnClear) {\n menu.value = true\n }\n\n search.value = ''\n }\n function onClickControl () {\n if (\n (props.hideNoData && !items.value.length) ||\n props.readonly || form?.isReadonly.value\n ) return\n\n menu.value = true\n }\n function onKeydown (e: KeyboardEvent) {\n if (props.readonly || form?.isReadonly.value) return\n\n if (['Enter', 'ArrowDown'].includes(e.key)) {\n menu.value = true\n }\n\n if (['Escape'].includes(e.key)) {\n menu.value = false\n }\n\n if (['Enter', 'Escape', 'Tab'].includes(e.key)) {\n isPristine.value = true\n }\n\n if (e.key === 'ArrowDown') {\n e.preventDefault()\n listRef.value?.focus('next')\n } else if (e.key === 'ArrowUp') {\n e.preventDefault()\n listRef.value?.focus('prev')\n }\n }\n\n function onInput (e: InputEvent) {\n search.value = (e.target as HTMLInputElement).value\n }\n\n function onAfterLeave () {\n if (isFocused.value) isPristine.value = true\n }\n\n function onFocusin (e: FocusEvent) {\n isFocused.value = true\n }\n\n function onFocusout (e: FocusEvent) {\n if (e.relatedTarget == null) {\n vTextFieldRef.value?.focus()\n }\n }\n\n const isSelecting = ref(false)\n\n function select (item: InternalItem) {\n if (props.multiple) {\n const index = selected.value.findIndex(selection => props.valueComparator(selection, item.value))\n\n if (index === -1) {\n model.value = [...model.value, item]\n search.value = ''\n } else {\n const value = [...model.value]\n value.splice(index, 1)\n model.value = value\n }\n } else {\n model.value = [item]\n\n isSelecting.value = true\n\n if (!slots.selection) {\n search.value = item.title\n }\n\n menu.value = false\n isPristine.value = true\n\n nextTick(() => (isSelecting.value = false))\n }\n }\n\n watch(isFocused, val => {\n if (val) {\n isSelecting.value = true\n search.value = props.multiple || !!slots.selection ? '' : String(selections.value.at(-1)?.props.title ?? '')\n isPristine.value = true\n\n nextTick(() => isSelecting.value = false)\n } else {\n menu.value = false\n search.value = ''\n }\n })\n\n watch(search, val => {\n if (!isFocused.value || isSelecting.value) return\n\n if (val) menu.value = true\n\n isPristine.value = !val\n })\n\n useRender(() => {\n const hasChips = !!(props.chips || slots.chip)\n const hasList = !!((!props.hideNoData || displayItems.value.length) || slots.prepend || slots.append || slots['no-data'])\n const [textFieldProps] = filterVTextFieldProps(props)\n\n return (\n <VTextField\n ref={ vTextFieldRef }\n { ...textFieldProps }\n modelValue={ search.value }\n onUpdate:modelValue={ v => { if (v == null) model.value = [] } }\n validationValue={ model.externalValue }\n dirty={ model.value.length > 0 }\n onInput={ onInput }\n class={[\n 'v-autocomplete',\n {\n 'v-autocomplete--active-menu': menu.value,\n 'v-autocomplete--chips': !!props.chips,\n [`v-autocomplete--${props.multiple ? 'multiple' : 'single'}`]: true,\n 'v-autocomplete--selection-slot': !!slots.selection,\n },\n ]}\n appendInnerIcon={ props.menuIcon }\n readonly={ props.readonly }\n onClick:clear={ onClear }\n onClick:control={ onClickControl }\n onClick:input={ onClickControl }\n onFocus={ () => isFocused.value = true }\n onBlur={ () => isFocused.value = false }\n onKeydown={ onKeydown }\n >\n {{\n ...slots,\n default: () => (\n <>\n <VMenu\n v-model={ menu.value }\n activator=\"parent\"\n contentClass=\"v-autocomplete__content\"\n eager={ props.eager }\n maxHeight={ 310 }\n openOnClick={ false }\n closeOnContentClick={ false }\n transition={ props.transition }\n onAfterLeave={ onAfterLeave }\n { ...props.menuProps }\n >\n { hasList && (\n <VList\n ref={ listRef }\n selected={ selected.value }\n selectStrategy={ props.multiple ? 'independent' : 'single-independent' }\n onMousedown={ (e: MouseEvent) => e.preventDefault() }\n onFocusin={ onFocusin }\n onFocusout={ onFocusout }\n >\n { !displayItems.value.length && !props.hideNoData && (slots['no-data']?.() ?? (\n <VListItem title={ t(props.noDataText) } />\n )) }\n\n { slots['prepend-item']?.() }\n\n { displayItems.value.map((item, index) => slots.item?.({\n item,\n index,\n props: mergeProps(item.props, { onClick: () => select(item) }),\n }) ?? (\n <VListItem\n key={ index }\n { ...item.props }\n onClick={ () => select(item) }\n >\n {{\n prepend: ({ isSelected }) => props.multiple && !props.hideSelected ? (\n <VCheckboxBtn modelValue={ isSelected } ripple={ false } />\n ) : undefined,\n title: () => {\n return isPristine.value\n ? item.title\n : highlightResult(item.title, getMatches(item)?.title, search.value?.length ?? 0)\n },\n }}\n </VListItem>\n )) }\n\n { slots['append-item']?.() }\n </VList>\n ) }\n </VMenu>\n\n { selections.value.map((item, index) => {\n function onChipClose (e: Event) {\n e.stopPropagation()\n e.preventDefault()\n\n select(item)\n }\n\n const slotProps = {\n 'onClick:close': onChipClose,\n modelValue: true,\n 'onUpdate:modelValue': undefined,\n }\n\n return (\n <div key={ item.value } class=\"v-autocomplete__selection\">\n { hasChips ? (\n <VDefaultsProvider\n defaults={{\n VChip: {\n closable: props.closableChips,\n size: 'small',\n text: item.title,\n },\n }}\n >\n { slots.chip\n ? slots.chip({ item, index, props: slotProps })\n : (<VChip { ...slotProps } />)\n }\n </VDefaultsProvider>\n ) : (\n slots.selection\n ? slots.selection({ item, index })\n : (\n <span class=\"v-autocomplete__selection-text\">\n { item.title }\n { props.multiple && (index < selections.value.length - 1) && (\n <span class=\"v-autocomplete__selection-comma\">,</span>\n ) }\n </span>\n )\n )}\n </div>\n )\n }) }\n </>\n ),\n }}\n </VTextField>\n )\n })\n\n return forwardRefs({\n isFocused,\n isPristine,\n menu,\n search,\n filteredItems,\n select,\n }, vTextFieldRef)\n },\n})\n\nexport type VAutocomplete = InstanceType<typeof VAutocomplete>\n"],"mappings":"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"}
|
|
@@ -116,8 +116,14 @@ export const VBtn = defineComponent({
|
|
|
116
116
|
const group = useGroupItem(props, props.symbol, false);
|
|
117
117
|
const link = useLink(props, attrs);
|
|
118
118
|
const isActive = computed(() => {
|
|
119
|
-
|
|
120
|
-
|
|
119
|
+
if (props.active !== undefined) {
|
|
120
|
+
return props.active;
|
|
121
|
+
}
|
|
122
|
+
if (link.isLink.value) {
|
|
123
|
+
var _link$isActive;
|
|
124
|
+
return (_link$isActive = link.isActive) == null ? void 0 : _link$isActive.value;
|
|
125
|
+
}
|
|
126
|
+
return group == null ? void 0 : group.isSelected.value;
|
|
121
127
|
});
|
|
122
128
|
const isDisabled = computed(() => (group == null ? void 0 : group.disabled.value) || props.disabled);
|
|
123
129
|
const isElevated = computed(() => {
|
|
@@ -127,7 +133,7 @@ export const VBtn = defineComponent({
|
|
|
127
133
|
useRender(() => {
|
|
128
134
|
var _slots$prepend, _slots$default, _slots$append, _slots$loader;
|
|
129
135
|
const Tag = link.isLink.value ? 'a' : props.tag;
|
|
130
|
-
const hasColor = !group ||
|
|
136
|
+
const hasColor = !group || isActive.value;
|
|
131
137
|
const hasPrepend = !!(props.prependIcon || slots.prepend);
|
|
132
138
|
const hasAppend = !!(props.appendIcon || slots.append);
|
|
133
139
|
const hasIcon = !!(props.icon && props.icon !== true);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VBtn.mjs","names":["VBtnToggleSymbol","VDefaultsProvider","VIcon","VProgressCircular","Ripple","genOverlays","makeVariantProps","useVariant","IconValue","makeBorderProps","useBorder","makeDensityProps","useDensity","makeDimensionProps","useDimension","makeElevationProps","useElevation","makeGroupItemProps","useGroupItem","makeLoaderProps","useLoader","makeLocationProps","useLocation","makePositionProps","usePosition","makeRoundedProps","useRounded","makeRouterProps","useLink","makeSizeProps","useSize","makeTagProps","makeThemeProps","provideTheme","useSelectLink","computed","defineComponent","useRender","VBtn","name","directives","props","active","type","Boolean","default","undefined","symbol","flat","icon","String","Function","Object","prependIcon","appendIcon","block","stacked","ripple","tag","variant","emits","val","setup","attrs","slots","themeClasses","borderClasses","colorClasses","colorStyles","variantClasses","densityClasses","dimensionStyles","elevationClasses","loaderClasses","locationStyles","positionClasses","roundedClasses","sizeClasses","sizeStyles","group","link","isActive","value","isSelected","isDisabled","disabled","isElevated","border","select","Tag","isLink","hasColor","hasPrepend","prepend","hasAppend","append","hasIcon","selectedClass","loading","href","e","navigate","toggle","loader"],"sources":["../../../src/components/VBtn/VBtn.tsx"],"sourcesContent":["// Styles\nimport './VBtn.sass'\n\n// Components\nimport { VBtnToggleSymbol } from '@/components/VBtnToggle/VBtnToggle'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VIcon } from '@/components/VIcon'\nimport { VProgressCircular } from '@/components/VProgressCircular'\n\n// Directives\nimport { Ripple } from '@/directives/ripple'\n\n// Composables\nimport { genOverlays, makeVariantProps, useVariant } from '@/composables/variant'\nimport { IconValue } from '@/composables/icons'\nimport { makeBorderProps, useBorder } from '@/composables/border'\nimport { makeDensityProps, useDensity } from '@/composables/density'\nimport { makeDimensionProps, useDimension } from '@/composables/dimensions'\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeGroupItemProps, useGroupItem } from '@/composables/group'\nimport { makeLoaderProps, useLoader } from '@/composables/loader'\nimport { makeLocationProps, useLocation } from '@/composables/location'\nimport { makePositionProps, usePosition } from '@/composables/position'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeRouterProps, useLink } from '@/composables/router'\nimport { makeSizeProps, useSize } from '@/composables/size'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { useSelectLink } from '@/composables/selectLink'\n\n// Utilities\nimport { computed } from 'vue'\nimport { defineComponent, useRender } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\n\nexport const VBtn = defineComponent({\n name: 'VBtn',\n\n directives: { Ripple },\n\n props: {\n active: {\n type: Boolean,\n default: undefined,\n },\n symbol: {\n type: null,\n default: VBtnToggleSymbol,\n },\n flat: Boolean,\n icon: [Boolean, String, Function, Object] as PropType<boolean | IconValue>,\n prependIcon: IconValue,\n appendIcon: IconValue,\n\n block: Boolean,\n stacked: Boolean,\n\n ripple: {\n type: Boolean,\n default: true,\n },\n\n ...makeBorderProps(),\n ...makeRoundedProps(),\n ...makeDensityProps(),\n ...makeDimensionProps(),\n ...makeElevationProps(),\n ...makeGroupItemProps(),\n ...makeLoaderProps(),\n ...makeLocationProps(),\n ...makePositionProps(),\n ...makeRouterProps(),\n ...makeSizeProps(),\n ...makeTagProps({ tag: 'button' }),\n ...makeThemeProps(),\n ...makeVariantProps({ variant: 'elevated' } as const),\n },\n\n emits: {\n 'group:selected': (val: { value: boolean }) => true,\n },\n\n setup (props, { attrs, slots }) {\n const { themeClasses } = provideTheme(props)\n const { borderClasses } = useBorder(props)\n const { colorClasses, colorStyles, variantClasses } = useVariant(props)\n const { densityClasses } = useDensity(props)\n const { dimensionStyles } = useDimension(props)\n const { elevationClasses } = useElevation(props)\n const { loaderClasses } = useLoader(props)\n const { locationStyles } = useLocation(props)\n const { positionClasses } = usePosition(props)\n const { roundedClasses } = useRounded(props)\n const { sizeClasses, sizeStyles } = useSize(props)\n const group = useGroupItem(props, props.symbol, false)\n const link = useLink(props, attrs)\n\n const isActive = computed(() =>\n props.active !== false &&\n (props.active || link.isActive?.value || group?.isSelected.value)\n )\n const isDisabled = computed(() => group?.disabled.value || props.disabled)\n const isElevated = computed(() => {\n return props.variant === 'elevated' && !(props.disabled || props.flat || props.border)\n })\n\n useSelectLink(link, group?.select)\n\n useRender(() => {\n const Tag = (link.isLink.value) ? 'a' : props.tag\n const hasColor = !group || group.isSelected.value\n const hasPrepend = !!(props.prependIcon || slots.prepend)\n const hasAppend = !!(props.appendIcon || slots.append)\n const hasIcon = !!(props.icon && props.icon !== true)\n\n return (\n <Tag\n type={ Tag === 'a' ? undefined : 'button' }\n class={[\n 'v-btn',\n group?.selectedClass.value,\n {\n 'v-btn--active': isActive.value,\n 'v-btn--block': props.block,\n 'v-btn--disabled': isDisabled.value,\n 'v-btn--elevated': isElevated.value,\n 'v-btn--flat': props.flat,\n 'v-btn--icon': !!props.icon,\n 'v-btn--loading': props.loading,\n 'v-btn--stacked': props.stacked,\n },\n themeClasses.value,\n borderClasses.value,\n hasColor ? colorClasses.value : undefined,\n densityClasses.value,\n elevationClasses.value,\n loaderClasses.value,\n positionClasses.value,\n roundedClasses.value,\n sizeClasses.value,\n variantClasses.value,\n ]}\n style={[\n hasColor ? colorStyles.value : undefined,\n dimensionStyles.value,\n locationStyles.value,\n sizeStyles.value,\n ]}\n disabled={ isDisabled.value || undefined }\n href={ link.href.value }\n v-ripple={[\n !isDisabled.value && props.ripple,\n null,\n props.icon ? ['center'] : null,\n ]}\n onClick={ (e: MouseEvent) => {\n if (isDisabled.value) return\n\n link.navigate?.(e)\n group?.toggle()\n } }\n >\n { genOverlays(true, 'v-btn') }\n\n { !props.icon && hasPrepend && (\n <VDefaultsProvider\n key=\"prepend\"\n defaults={{\n VIcon: {\n icon: props.prependIcon,\n },\n }}\n >\n <span class=\"v-btn__prepend\">\n { slots.prepend?.() ?? (<VIcon />) }\n </span>\n </VDefaultsProvider>\n ) }\n\n <span class=\"v-btn__content\" data-no-activator=\"\">\n <VDefaultsProvider\n key=\"content\"\n defaults={{\n VIcon: {\n icon: hasIcon ? props.icon : undefined,\n },\n }}\n >\n { slots.default?.() ?? (\n hasIcon && (\n <VIcon key=\"icon\" />\n )\n ) }\n </VDefaultsProvider>\n </span>\n\n { !props.icon && hasAppend && (\n <VDefaultsProvider\n key=\"append\"\n defaults={{\n VIcon: {\n icon: props.appendIcon,\n },\n }}\n >\n <span class=\"v-btn__append\">\n { slots.append?.() ?? (<VIcon />) }\n </span>\n </VDefaultsProvider>\n ) }\n\n { !!props.loading && (\n <span key=\"loader\" class=\"v-btn__loader\">\n { slots.loader?.() ?? (\n <VProgressCircular\n color={ typeof props.loading === 'boolean' ? undefined : props.loading }\n indeterminate\n size=\"23\"\n width=\"2\"\n />\n ) }\n </span>\n ) }\n </Tag>\n )\n })\n\n return {}\n },\n})\n\nexport type VBtn = InstanceType<typeof VBtn>\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"VBtn.mjs","names":["VBtnToggleSymbol","VDefaultsProvider","VIcon","VProgressCircular","Ripple","genOverlays","makeVariantProps","useVariant","IconValue","makeBorderProps","useBorder","makeDensityProps","useDensity","makeDimensionProps","useDimension","makeElevationProps","useElevation","makeGroupItemProps","useGroupItem","makeLoaderProps","useLoader","makeLocationProps","useLocation","makePositionProps","usePosition","makeRoundedProps","useRounded","makeRouterProps","useLink","makeSizeProps","useSize","makeTagProps","makeThemeProps","provideTheme","useSelectLink","computed","defineComponent","useRender","VBtn","name","directives","props","active","type","Boolean","default","undefined","symbol","flat","icon","String","Function","Object","prependIcon","appendIcon","block","stacked","ripple","tag","variant","emits","val","setup","attrs","slots","themeClasses","borderClasses","colorClasses","colorStyles","variantClasses","densityClasses","dimensionStyles","elevationClasses","loaderClasses","locationStyles","positionClasses","roundedClasses","sizeClasses","sizeStyles","group","link","isActive","isLink","value","isSelected","isDisabled","disabled","isElevated","border","select","Tag","hasColor","hasPrepend","prepend","hasAppend","append","hasIcon","selectedClass","loading","href","e","navigate","toggle","loader"],"sources":["../../../src/components/VBtn/VBtn.tsx"],"sourcesContent":["// Styles\nimport './VBtn.sass'\n\n// Components\nimport { VBtnToggleSymbol } from '@/components/VBtnToggle/VBtnToggle'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VIcon } from '@/components/VIcon'\nimport { VProgressCircular } from '@/components/VProgressCircular'\n\n// Directives\nimport { Ripple } from '@/directives/ripple'\n\n// Composables\nimport { genOverlays, makeVariantProps, useVariant } from '@/composables/variant'\nimport { IconValue } from '@/composables/icons'\nimport { makeBorderProps, useBorder } from '@/composables/border'\nimport { makeDensityProps, useDensity } from '@/composables/density'\nimport { makeDimensionProps, useDimension } from '@/composables/dimensions'\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeGroupItemProps, useGroupItem } from '@/composables/group'\nimport { makeLoaderProps, useLoader } from '@/composables/loader'\nimport { makeLocationProps, useLocation } from '@/composables/location'\nimport { makePositionProps, usePosition } from '@/composables/position'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeRouterProps, useLink } from '@/composables/router'\nimport { makeSizeProps, useSize } from '@/composables/size'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\nimport { useSelectLink } from '@/composables/selectLink'\n\n// Utilities\nimport { computed } from 'vue'\nimport { defineComponent, useRender } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\n\nexport const VBtn = defineComponent({\n name: 'VBtn',\n\n directives: { Ripple },\n\n props: {\n active: {\n type: Boolean,\n default: undefined,\n },\n symbol: {\n type: null,\n default: VBtnToggleSymbol,\n },\n flat: Boolean,\n icon: [Boolean, String, Function, Object] as PropType<boolean | IconValue>,\n prependIcon: IconValue,\n appendIcon: IconValue,\n\n block: Boolean,\n stacked: Boolean,\n\n ripple: {\n type: Boolean,\n default: true,\n },\n\n ...makeBorderProps(),\n ...makeRoundedProps(),\n ...makeDensityProps(),\n ...makeDimensionProps(),\n ...makeElevationProps(),\n ...makeGroupItemProps(),\n ...makeLoaderProps(),\n ...makeLocationProps(),\n ...makePositionProps(),\n ...makeRouterProps(),\n ...makeSizeProps(),\n ...makeTagProps({ tag: 'button' }),\n ...makeThemeProps(),\n ...makeVariantProps({ variant: 'elevated' } as const),\n },\n\n emits: {\n 'group:selected': (val: { value: boolean }) => true,\n },\n\n setup (props, { attrs, slots }) {\n const { themeClasses } = provideTheme(props)\n const { borderClasses } = useBorder(props)\n const { colorClasses, colorStyles, variantClasses } = useVariant(props)\n const { densityClasses } = useDensity(props)\n const { dimensionStyles } = useDimension(props)\n const { elevationClasses } = useElevation(props)\n const { loaderClasses } = useLoader(props)\n const { locationStyles } = useLocation(props)\n const { positionClasses } = usePosition(props)\n const { roundedClasses } = useRounded(props)\n const { sizeClasses, sizeStyles } = useSize(props)\n const group = useGroupItem(props, props.symbol, false)\n const link = useLink(props, attrs)\n\n const isActive = computed(() => {\n if (props.active !== undefined) {\n return props.active\n }\n\n if (link.isLink.value) {\n return link.isActive?.value\n }\n\n return group?.isSelected.value\n })\n const isDisabled = computed(() => group?.disabled.value || props.disabled)\n const isElevated = computed(() => {\n return props.variant === 'elevated' && !(props.disabled || props.flat || props.border)\n })\n\n useSelectLink(link, group?.select)\n\n useRender(() => {\n const Tag = (link.isLink.value) ? 'a' : props.tag\n const hasColor = !group || isActive.value\n const hasPrepend = !!(props.prependIcon || slots.prepend)\n const hasAppend = !!(props.appendIcon || slots.append)\n const hasIcon = !!(props.icon && props.icon !== true)\n\n return (\n <Tag\n type={ Tag === 'a' ? undefined : 'button' }\n class={[\n 'v-btn',\n group?.selectedClass.value,\n {\n 'v-btn--active': isActive.value,\n 'v-btn--block': props.block,\n 'v-btn--disabled': isDisabled.value,\n 'v-btn--elevated': isElevated.value,\n 'v-btn--flat': props.flat,\n 'v-btn--icon': !!props.icon,\n 'v-btn--loading': props.loading,\n 'v-btn--stacked': props.stacked,\n },\n themeClasses.value,\n borderClasses.value,\n hasColor ? colorClasses.value : undefined,\n densityClasses.value,\n elevationClasses.value,\n loaderClasses.value,\n positionClasses.value,\n roundedClasses.value,\n sizeClasses.value,\n variantClasses.value,\n ]}\n style={[\n hasColor ? colorStyles.value : undefined,\n dimensionStyles.value,\n locationStyles.value,\n sizeStyles.value,\n ]}\n disabled={ isDisabled.value || undefined }\n href={ link.href.value }\n v-ripple={[\n !isDisabled.value && props.ripple,\n null,\n props.icon ? ['center'] : null,\n ]}\n onClick={ (e: MouseEvent) => {\n if (isDisabled.value) return\n\n link.navigate?.(e)\n group?.toggle()\n } }\n >\n { genOverlays(true, 'v-btn') }\n\n { !props.icon && hasPrepend && (\n <VDefaultsProvider\n key=\"prepend\"\n defaults={{\n VIcon: {\n icon: props.prependIcon,\n },\n }}\n >\n <span class=\"v-btn__prepend\">\n { slots.prepend?.() ?? (<VIcon />) }\n </span>\n </VDefaultsProvider>\n ) }\n\n <span class=\"v-btn__content\" data-no-activator=\"\">\n <VDefaultsProvider\n key=\"content\"\n defaults={{\n VIcon: {\n icon: hasIcon ? props.icon : undefined,\n },\n }}\n >\n { slots.default?.() ?? (\n hasIcon && (\n <VIcon key=\"icon\" />\n )\n ) }\n </VDefaultsProvider>\n </span>\n\n { !props.icon && hasAppend && (\n <VDefaultsProvider\n key=\"append\"\n defaults={{\n VIcon: {\n icon: props.appendIcon,\n },\n }}\n >\n <span class=\"v-btn__append\">\n { slots.append?.() ?? (<VIcon />) }\n </span>\n </VDefaultsProvider>\n ) }\n\n { !!props.loading && (\n <span key=\"loader\" class=\"v-btn__loader\">\n { slots.loader?.() ?? (\n <VProgressCircular\n color={ typeof props.loading === 'boolean' ? undefined : props.loading }\n indeterminate\n size=\"23\"\n width=\"2\"\n />\n ) }\n </span>\n ) }\n </Tag>\n )\n })\n\n return {}\n },\n})\n\nexport type VBtn = InstanceType<typeof VBtn>\n"],"mappings":";AAAA;AACA;;AAEA;AAAA,SACSA,gBAAgB;AAAA,SAChBC,iBAAiB;AAAA,SACjBC,KAAK;AAAA,SACLC,iBAAiB,0CAE1B;AAAA,SACSC,MAAM,6CAEf;AAAA,SACSC,WAAW,EAAEC,gBAAgB,EAAEC,UAAU;AAAA,SACzCC,SAAS;AAAA,SACTC,eAAe,EAAEC,SAAS;AAAA,SAC1BC,gBAAgB,EAAEC,UAAU;AAAA,SAC5BC,kBAAkB,EAAEC,YAAY;AAAA,SAChCC,kBAAkB,EAAEC,YAAY;AAAA,SAChCC,kBAAkB,EAAEC,YAAY;AAAA,SAChCC,eAAe,EAAEC,SAAS;AAAA,SAC1BC,iBAAiB,EAAEC,WAAW;AAAA,SAC9BC,iBAAiB,EAAEC,WAAW;AAAA,SAC9BC,gBAAgB,EAAEC,UAAU;AAAA,SAC5BC,eAAe,EAAEC,OAAO;AAAA,SACxBC,aAAa,EAAEC,OAAO;AAAA,SACtBC,YAAY;AAAA,SACZC,cAAc,EAAEC,YAAY;AAAA,SAC5BC,aAAa,4CAEtB;AACA,SAASC,QAAQ,QAAQ,KAAK;AAAA,SACrBC,eAAe,EAAEC,SAAS,gCAEnC;AAGA,OAAO,MAAMC,IAAI,GAAGF,eAAe,CAAC;EAClCG,IAAI,EAAE,MAAM;EAEZC,UAAU,EAAE;IAAEpC;EAAO,CAAC;EAEtBqC,KAAK,EAAE;IACLC,MAAM,EAAE;MACNC,IAAI,EAAEC,OAAO;MACbC,OAAO,EAAEC;IACX,CAAC;IACDC,MAAM,EAAE;MACNJ,IAAI,EAAE,IAAI;MACVE,OAAO,EAAE7C;IACX,CAAC;IACDgD,IAAI,EAAEJ,OAAO;IACbK,IAAI,EAAE,CAACL,OAAO,EAAEM,MAAM,EAAEC,QAAQ,EAAEC,MAAM,CAAkC;IAC1EC,WAAW,EAAE7C,SAAS;IACtB8C,UAAU,EAAE9C,SAAS;IAErB+C,KAAK,EAAEX,OAAO;IACdY,OAAO,EAAEZ,OAAO;IAEhBa,MAAM,EAAE;MACNd,IAAI,EAAEC,OAAO;MACbC,OAAO,EAAE;IACX,CAAC;IAED,GAAGpC,eAAe,EAAE;IACpB,GAAGgB,gBAAgB,EAAE;IACrB,GAAGd,gBAAgB,EAAE;IACrB,GAAGE,kBAAkB,EAAE;IACvB,GAAGE,kBAAkB,EAAE;IACvB,GAAGE,kBAAkB,EAAE;IACvB,GAAGE,eAAe,EAAE;IACpB,GAAGE,iBAAiB,EAAE;IACtB,GAAGE,iBAAiB,EAAE;IACtB,GAAGI,eAAe,EAAE;IACpB,GAAGE,aAAa,EAAE;IAClB,GAAGE,YAAY,CAAC;MAAE2B,GAAG,EAAE;IAAS,CAAC,CAAC;IAClC,GAAG1B,cAAc,EAAE;IACnB,GAAG1B,gBAAgB,CAAC;MAAEqD,OAAO,EAAE;IAAW,CAAC;EAC7C,CAAC;EAEDC,KAAK,EAAE;IACL,gBAAgB,EAAGC,GAAuB,IAAK;EACjD,CAAC;EAEDC,KAAK,CAAErB,KAAK,QAAoB;IAAA,IAAlB;MAAEsB,KAAK;MAAEC;IAAM,CAAC;IAC5B,MAAM;MAAEC;IAAa,CAAC,GAAGhC,YAAY,CAACQ,KAAK,CAAC;IAC5C,MAAM;MAAEyB;IAAc,CAAC,GAAGxD,SAAS,CAAC+B,KAAK,CAAC;IAC1C,MAAM;MAAE0B,YAAY;MAAEC,WAAW;MAAEC;IAAe,CAAC,GAAG9D,UAAU,CAACkC,KAAK,CAAC;IACvE,MAAM;MAAE6B;IAAe,CAAC,GAAG1D,UAAU,CAAC6B,KAAK,CAAC;IAC5C,MAAM;MAAE8B;IAAgB,CAAC,GAAGzD,YAAY,CAAC2B,KAAK,CAAC;IAC/C,MAAM;MAAE+B;IAAiB,CAAC,GAAGxD,YAAY,CAACyB,KAAK,CAAC;IAChD,MAAM;MAAEgC;IAAc,CAAC,GAAGrD,SAAS,CAACqB,KAAK,CAAC;IAC1C,MAAM;MAAEiC;IAAe,CAAC,GAAGpD,WAAW,CAACmB,KAAK,CAAC;IAC7C,MAAM;MAAEkC;IAAgB,CAAC,GAAGnD,WAAW,CAACiB,KAAK,CAAC;IAC9C,MAAM;MAAEmC;IAAe,CAAC,GAAGlD,UAAU,CAACe,KAAK,CAAC;IAC5C,MAAM;MAAEoC,WAAW;MAAEC;IAAW,CAAC,GAAGhD,OAAO,CAACW,KAAK,CAAC;IAClD,MAAMsC,KAAK,GAAG7D,YAAY,CAACuB,KAAK,EAAEA,KAAK,CAACM,MAAM,EAAE,KAAK,CAAC;IACtD,MAAMiC,IAAI,GAAGpD,OAAO,CAACa,KAAK,EAAEsB,KAAK,CAAC;IAElC,MAAMkB,QAAQ,GAAG9C,QAAQ,CAAC,MAAM;MAC9B,IAAIM,KAAK,CAACC,MAAM,KAAKI,SAAS,EAAE;QAC9B,OAAOL,KAAK,CAACC,MAAM;MACrB;MAEA,IAAIsC,IAAI,CAACE,MAAM,CAACC,KAAK,EAAE;QAAA;QACrB,yBAAOH,IAAI,CAACC,QAAQ,qBAAb,eAAeE,KAAK;MAC7B;MAEA,OAAOJ,KAAK,oBAALA,KAAK,CAAEK,UAAU,CAACD,KAAK;IAChC,CAAC,CAAC;IACF,MAAME,UAAU,GAAGlD,QAAQ,CAAC,MAAM,CAAA4C,KAAK,oBAALA,KAAK,CAAEO,QAAQ,CAACH,KAAK,KAAI1C,KAAK,CAAC6C,QAAQ,CAAC;IAC1E,MAAMC,UAAU,GAAGpD,QAAQ,CAAC,MAAM;MAChC,OAAOM,KAAK,CAACkB,OAAO,KAAK,UAAU,IAAI,EAAElB,KAAK,CAAC6C,QAAQ,IAAI7C,KAAK,CAACO,IAAI,IAAIP,KAAK,CAAC+C,MAAM,CAAC;IACxF,CAAC,CAAC;IAEFtD,aAAa,CAAC8C,IAAI,EAAED,KAAK,oBAALA,KAAK,CAAEU,MAAM,CAAC;IAElCpD,SAAS,CAAC,MAAM;MAAA;MACd,MAAMqD,GAAG,GAAIV,IAAI,CAACE,MAAM,CAACC,KAAK,GAAI,GAAG,GAAG1C,KAAK,CAACiB,GAAG;MACjD,MAAMiC,QAAQ,GAAG,CAACZ,KAAK,IAAIE,QAAQ,CAACE,KAAK;MACzC,MAAMS,UAAU,GAAG,CAAC,EAAEnD,KAAK,CAACY,WAAW,IAAIW,KAAK,CAAC6B,OAAO,CAAC;MACzD,MAAMC,SAAS,GAAG,CAAC,EAAErD,KAAK,CAACa,UAAU,IAAIU,KAAK,CAAC+B,MAAM,CAAC;MACtD,MAAMC,OAAO,GAAG,CAAC,EAAEvD,KAAK,CAACQ,IAAI,IAAIR,KAAK,CAACQ,IAAI,KAAK,IAAI,CAAC;MAErD;QAAA,QAEWyC,GAAG,KAAK,GAAG,GAAG5C,SAAS,GAAG,QAAQ;QAAA,SAClC,CACL,OAAO,EACPiC,KAAK,oBAALA,KAAK,CAAEkB,aAAa,CAACd,KAAK,EAC1B;UACE,eAAe,EAAEF,QAAQ,CAACE,KAAK;UAC/B,cAAc,EAAE1C,KAAK,CAACc,KAAK;UAC3B,iBAAiB,EAAE8B,UAAU,CAACF,KAAK;UACnC,iBAAiB,EAAEI,UAAU,CAACJ,KAAK;UACnC,aAAa,EAAE1C,KAAK,CAACO,IAAI;UACzB,aAAa,EAAE,CAAC,CAACP,KAAK,CAACQ,IAAI;UAC3B,gBAAgB,EAAER,KAAK,CAACyD,OAAO;UAC/B,gBAAgB,EAAEzD,KAAK,CAACe;QAC1B,CAAC,EACDS,YAAY,CAACkB,KAAK,EAClBjB,aAAa,CAACiB,KAAK,EACnBQ,QAAQ,GAAGxB,YAAY,CAACgB,KAAK,GAAGrC,SAAS,EACzCwB,cAAc,CAACa,KAAK,EACpBX,gBAAgB,CAACW,KAAK,EACtBV,aAAa,CAACU,KAAK,EACnBR,eAAe,CAACQ,KAAK,EACrBP,cAAc,CAACO,KAAK,EACpBN,WAAW,CAACM,KAAK,EACjBd,cAAc,CAACc,KAAK,CACrB;QAAA,SACM,CACLQ,QAAQ,GAAGvB,WAAW,CAACe,KAAK,GAAGrC,SAAS,EACxCyB,eAAe,CAACY,KAAK,EACrBT,cAAc,CAACS,KAAK,EACpBL,UAAU,CAACK,KAAK,CACjB;QAAA,YACUE,UAAU,CAACF,KAAK,IAAIrC,SAAS;QAAA,QACjCkC,IAAI,CAACmB,IAAI,CAAChB,KAAK;QAAA,WAMXiB,CAAa,IAAK;UAAA;UAC3B,IAAIf,UAAU,CAACF,KAAK,EAAE;UAEtB,kBAAAH,IAAI,CAACqB,QAAQ,qBAAb,oBAAArB,IAAI,EAAYoB,CAAC,CAAC;UAClBrB,KAAK,oBAALA,KAAK,CAAEuB,MAAM,EAAE;QACjB;MAAC;QAAA,gBAECjG,WAAW,CAAC,IAAI,EAAE,OAAO,CAAC,EAE1B,CAACoC,KAAK,CAACQ,IAAI,IAAI2C,UAAU;UAAA,OAEnB,SAAS;UAAA,YACH;YACR1F,KAAK,EAAE;cACL+C,IAAI,EAAER,KAAK,CAACY;YACd;UACF;QAAC;UAAA;YAAA,SAEW;UAAgB,IACxB,mBAAAW,KAAK,CAAC6B,OAAO,qBAAb,oBAAA7B,KAAK,CAAY,oCAAe;QAAA,EAGvC;UAAA,SAEW,gBAAgB;UAAA,qBAAmB;QAAE;UAAA,OAEzC,SAAS;UAAA,YACH;YACR9D,KAAK,EAAE;cACL+C,IAAI,EAAE+C,OAAO,GAAGvD,KAAK,CAACQ,IAAI,GAAGH;YAC/B;UACF;QAAC;UAAA,gBAEC,mBAAAkB,KAAK,CAACnB,OAAO,qBAAb,oBAAAmB,KAAK,CAAY,MACjBgC,OAAO;YAAA,OACM;UAAM,QAClB,CACF;QAAA,MAIH,CAACvD,KAAK,CAACQ,IAAI,IAAI6C,SAAS;UAAA,OAElB,QAAQ;UAAA,YACF;YACR5F,KAAK,EAAE;cACL+C,IAAI,EAAER,KAAK,CAACa;YACd;UACF;QAAC;UAAA;YAAA,SAEW;UAAe,IACvB,kBAAAU,KAAK,CAAC+B,MAAM,qBAAZ,mBAAA/B,KAAK,CAAW,oCAAe;QAAA,EAGtC,EAEC,CAAC,CAACvB,KAAK,CAACyD,OAAO;UAAA,OACL,QAAQ;UAAA,SAAO;QAAe,IACpC,kBAAAlC,KAAK,CAACuC,MAAM,qBAAZ,mBAAAvC,KAAK,CAAW;UAAA,SAEN,OAAOvB,KAAK,CAACyD,OAAO,KAAK,SAAS,GAAGpD,SAAS,GAAGL,KAAK,CAACyD,OAAO;UAAA;UAAA,QAEjE,IAAI;UAAA,SACH;QAAG,QAEZ,EAEJ;MAAA,mCAvEC,CAACb,UAAU,CAACF,KAAK,IAAI1C,KAAK,CAACgB,MAAM,EACjC,IAAI;IAyEZ,CAAC,CAAC;IAEF,OAAO,CAAC,CAAC;EACX;AACF,CAAC,CAAC"}
|
|
@@ -44,7 +44,10 @@ export const VCard = defineComponent({
|
|
|
44
44
|
},
|
|
45
45
|
prependAvatar: String,
|
|
46
46
|
prependIcon: IconValue,
|
|
47
|
-
ripple:
|
|
47
|
+
ripple: {
|
|
48
|
+
type: Boolean,
|
|
49
|
+
default: true
|
|
50
|
+
},
|
|
48
51
|
subtitle: String,
|
|
49
52
|
text: String,
|
|
50
53
|
title: String,
|
|
@@ -165,7 +168,7 @@ export const VCard = defineComponent({
|
|
|
165
168
|
}), (_slots$default = slots.default) == null ? void 0 : _slots$default.call(slots), slots.actions && _createVNode(VCardActions, null, {
|
|
166
169
|
default: slots.actions
|
|
167
170
|
}), genOverlays(isClickable.value, 'v-card')]
|
|
168
|
-
}), [[_resolveDirective("ripple"), isClickable.value]]);
|
|
171
|
+
}), [[_resolveDirective("ripple"), isClickable.value && props.ripple]]);
|
|
169
172
|
});
|
|
170
173
|
return {};
|
|
171
174
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VCard.mjs","names":["VCardActions","VCardItem","VCardText","VDefaultsProvider","VImg","Ripple","genOverlays","makeVariantProps","useVariant","IconValue","LoaderSlot","makeLoaderProps","useLoader","makeBorderProps","useBorder","makeDensityProps","useDensity","makeDimensionProps","useDimension","makeElevationProps","useElevation","makeLocationProps","useLocation","makePositionProps","usePosition","makeRoundedProps","useRounded","makeRouterProps","useLink","makeTagProps","makeThemeProps","provideTheme","defineComponent","useRender","computed","VCard","name","directives","props","appendAvatar","String","appendIcon","disabled","Boolean","flat","hover","image","link","type","default","undefined","prependAvatar","prependIcon","ripple","subtitle","text","title","variant","setup","attrs","slots","themeClasses","borderClasses","colorClasses","colorStyles","variantClasses","densityClasses","dimensionStyles","elevationClasses","loaderClasses","locationStyles","positionClasses","roundedClasses","isLink","value","isClickable","Tag","tag","hasTitle","hasSubtitle","hasHeader","hasAppend","append","hasPrepend","prepend","hasImage","hasCardItem","hasText","href","navigate","cover","src","loading","loader","item","actions"],"sources":["../../../src/components/VCard/VCard.tsx"],"sourcesContent":["/* eslint-disable complexity */\n\n// Styles\nimport './VCard.sass'\n\n// Components\nimport { VCardActions } from './VCardActions'\nimport { VCardItem } from './VCardItem'\nimport { VCardText } from './VCardText'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VImg } from '@/components/VImg'\n\n// Directives\nimport { Ripple } from '@/directives/ripple'\n\n// Composables\nimport { genOverlays, makeVariantProps, useVariant } from '@/composables/variant'\nimport { IconValue } from '@/composables/icons'\nimport { LoaderSlot, makeLoaderProps, useLoader } from '@/composables/loader'\nimport { makeBorderProps, useBorder } from '@/composables/border'\nimport { makeDensityProps, useDensity } from '@/composables/density'\nimport { makeDimensionProps, useDimension } from '@/composables/dimensions'\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeLocationProps, useLocation } from '@/composables/location'\nimport { makePositionProps, usePosition } from '@/composables/position'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeRouterProps, useLink } from '@/composables/router'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\n\n// Utilities\nimport { defineComponent, useRender } from '@/util'\nimport { computed } from 'vue'\n\nexport const VCard = defineComponent({\n name: 'VCard',\n\n directives: { Ripple },\n\n props: {\n appendAvatar: String,\n appendIcon: IconValue,\n disabled: Boolean,\n flat: Boolean,\n hover: Boolean,\n image: String,\n link: {\n type: Boolean,\n default: undefined,\n },\n prependAvatar: String,\n prependIcon: IconValue,\n ripple: Boolean,\n subtitle: String,\n text: String,\n title: String,\n\n ...makeThemeProps(),\n ...makeBorderProps(),\n ...makeDensityProps(),\n ...makeDimensionProps(),\n ...makeElevationProps(),\n ...makeLoaderProps(),\n ...makeLocationProps(),\n ...makePositionProps(),\n ...makeRoundedProps(),\n ...makeRouterProps(),\n ...makeTagProps(),\n ...makeVariantProps({ variant: 'elevated' } as const),\n },\n\n setup (props, { attrs, slots }) {\n const { themeClasses } = provideTheme(props)\n const { borderClasses } = useBorder(props)\n const { colorClasses, colorStyles, variantClasses } = useVariant(props)\n const { densityClasses } = useDensity(props)\n const { dimensionStyles } = useDimension(props)\n const { elevationClasses } = useElevation(props)\n const { loaderClasses } = useLoader(props)\n const { locationStyles } = useLocation(props)\n const { positionClasses } = usePosition(props)\n const { roundedClasses } = useRounded(props)\n const link = useLink(props, attrs)\n\n const isLink = computed(() => props.link !== false && link.isLink.value)\n const isClickable = computed(() =>\n !props.disabled &&\n props.link !== false &&\n (props.link || link.isClickable.value)\n )\n\n useRender(() => {\n const Tag = isLink.value ? 'a' : props.tag\n const hasTitle = !!(slots.title || props.title)\n const hasSubtitle = !!(slots.subtitle || props.subtitle)\n const hasHeader = hasTitle || hasSubtitle\n const hasAppend = !!(slots.append || props.appendAvatar || props.appendIcon)\n const hasPrepend = !!(slots.prepend || props.prependAvatar || props.prependIcon)\n const hasImage = !!(slots.image || props.image)\n const hasCardItem = hasHeader || hasPrepend || hasAppend\n const hasText = !!(slots.text || props.text)\n\n return (\n <Tag\n class={[\n 'v-card',\n {\n 'v-card--disabled': props.disabled,\n 'v-card--flat': props.flat,\n 'v-card--hover': props.hover && !(props.disabled || props.flat),\n 'v-card--link': isClickable.value,\n },\n themeClasses.value,\n borderClasses.value,\n colorClasses.value,\n densityClasses.value,\n elevationClasses.value,\n loaderClasses.value,\n positionClasses.value,\n roundedClasses.value,\n variantClasses.value,\n ]}\n style={[\n colorStyles.value,\n dimensionStyles.value,\n locationStyles.value,\n ]}\n href={ link.href.value }\n onClick={ isClickable.value && link.navigate }\n v-ripple={ isClickable.value }\n tabindex={ props.disabled ? -1 : undefined }\n >\n { hasImage && (\n <VDefaultsProvider\n key=\"image\"\n defaults={{\n VImg: {\n cover: true,\n src: props.image,\n },\n }}\n >\n <div class=\"v-card__image\">\n { slots.image?.() ?? <VImg /> }\n </div>\n </VDefaultsProvider>\n ) }\n\n <LoaderSlot\n name=\"v-card\"\n active={ !!props.loading }\n color={ typeof props.loading === 'boolean' ? undefined : props.loading }\n v-slots={{ default: slots.loader }}\n />\n\n { hasCardItem && (\n <VCardItem\n key=\"item\"\n prependAvatar={ props.prependAvatar }\n prependIcon={ props.prependIcon }\n title={ props.title }\n subtitle={ props.subtitle }\n appendAvatar={ props.appendAvatar }\n appendIcon={ props.appendIcon }\n >\n {{\n default: slots.item,\n prepend: slots.prepend,\n title: slots.title,\n subtitle: slots.subtitle,\n append: slots.append,\n }}\n </VCardItem>\n ) }\n\n { hasText && (\n <VCardText key=\"text\">\n { slots.text?.() ?? props.text }\n </VCardText>\n ) }\n\n { slots.default?.() }\n\n { slots.actions && (\n <VCardActions v-slots={{ default: slots.actions }} />\n ) }\n\n { genOverlays(isClickable.value, 'v-card') }\n </Tag>\n )\n })\n\n return {}\n },\n})\n\nexport type VCard = InstanceType<typeof VCard>\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"VCard.mjs","names":["VCardActions","VCardItem","VCardText","VDefaultsProvider","VImg","Ripple","genOverlays","makeVariantProps","useVariant","IconValue","LoaderSlot","makeLoaderProps","useLoader","makeBorderProps","useBorder","makeDensityProps","useDensity","makeDimensionProps","useDimension","makeElevationProps","useElevation","makeLocationProps","useLocation","makePositionProps","usePosition","makeRoundedProps","useRounded","makeRouterProps","useLink","makeTagProps","makeThemeProps","provideTheme","defineComponent","useRender","computed","VCard","name","directives","props","appendAvatar","String","appendIcon","disabled","Boolean","flat","hover","image","link","type","default","undefined","prependAvatar","prependIcon","ripple","subtitle","text","title","variant","setup","attrs","slots","themeClasses","borderClasses","colorClasses","colorStyles","variantClasses","densityClasses","dimensionStyles","elevationClasses","loaderClasses","locationStyles","positionClasses","roundedClasses","isLink","value","isClickable","Tag","tag","hasTitle","hasSubtitle","hasHeader","hasAppend","append","hasPrepend","prepend","hasImage","hasCardItem","hasText","href","navigate","cover","src","loading","loader","item","actions"],"sources":["../../../src/components/VCard/VCard.tsx"],"sourcesContent":["/* eslint-disable complexity */\n\n// Styles\nimport './VCard.sass'\n\n// Components\nimport { VCardActions } from './VCardActions'\nimport { VCardItem } from './VCardItem'\nimport { VCardText } from './VCardText'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VImg } from '@/components/VImg'\n\n// Directives\nimport { Ripple } from '@/directives/ripple'\n\n// Composables\nimport { genOverlays, makeVariantProps, useVariant } from '@/composables/variant'\nimport { IconValue } from '@/composables/icons'\nimport { LoaderSlot, makeLoaderProps, useLoader } from '@/composables/loader'\nimport { makeBorderProps, useBorder } from '@/composables/border'\nimport { makeDensityProps, useDensity } from '@/composables/density'\nimport { makeDimensionProps, useDimension } from '@/composables/dimensions'\nimport { makeElevationProps, useElevation } from '@/composables/elevation'\nimport { makeLocationProps, useLocation } from '@/composables/location'\nimport { makePositionProps, usePosition } from '@/composables/position'\nimport { makeRoundedProps, useRounded } from '@/composables/rounded'\nimport { makeRouterProps, useLink } from '@/composables/router'\nimport { makeTagProps } from '@/composables/tag'\nimport { makeThemeProps, provideTheme } from '@/composables/theme'\n\n// Utilities\nimport { defineComponent, useRender } from '@/util'\nimport { computed } from 'vue'\n\nexport const VCard = defineComponent({\n name: 'VCard',\n\n directives: { Ripple },\n\n props: {\n appendAvatar: String,\n appendIcon: IconValue,\n disabled: Boolean,\n flat: Boolean,\n hover: Boolean,\n image: String,\n link: {\n type: Boolean,\n default: undefined,\n },\n prependAvatar: String,\n prependIcon: IconValue,\n ripple: {\n type: Boolean,\n default: true,\n },\n subtitle: String,\n text: String,\n title: String,\n\n ...makeThemeProps(),\n ...makeBorderProps(),\n ...makeDensityProps(),\n ...makeDimensionProps(),\n ...makeElevationProps(),\n ...makeLoaderProps(),\n ...makeLocationProps(),\n ...makePositionProps(),\n ...makeRoundedProps(),\n ...makeRouterProps(),\n ...makeTagProps(),\n ...makeVariantProps({ variant: 'elevated' } as const),\n },\n\n setup (props, { attrs, slots }) {\n const { themeClasses } = provideTheme(props)\n const { borderClasses } = useBorder(props)\n const { colorClasses, colorStyles, variantClasses } = useVariant(props)\n const { densityClasses } = useDensity(props)\n const { dimensionStyles } = useDimension(props)\n const { elevationClasses } = useElevation(props)\n const { loaderClasses } = useLoader(props)\n const { locationStyles } = useLocation(props)\n const { positionClasses } = usePosition(props)\n const { roundedClasses } = useRounded(props)\n const link = useLink(props, attrs)\n\n const isLink = computed(() => props.link !== false && link.isLink.value)\n const isClickable = computed(() =>\n !props.disabled &&\n props.link !== false &&\n (props.link || link.isClickable.value)\n )\n\n useRender(() => {\n const Tag = isLink.value ? 'a' : props.tag\n const hasTitle = !!(slots.title || props.title)\n const hasSubtitle = !!(slots.subtitle || props.subtitle)\n const hasHeader = hasTitle || hasSubtitle\n const hasAppend = !!(slots.append || props.appendAvatar || props.appendIcon)\n const hasPrepend = !!(slots.prepend || props.prependAvatar || props.prependIcon)\n const hasImage = !!(slots.image || props.image)\n const hasCardItem = hasHeader || hasPrepend || hasAppend\n const hasText = !!(slots.text || props.text)\n\n return (\n <Tag\n class={[\n 'v-card',\n {\n 'v-card--disabled': props.disabled,\n 'v-card--flat': props.flat,\n 'v-card--hover': props.hover && !(props.disabled || props.flat),\n 'v-card--link': isClickable.value,\n },\n themeClasses.value,\n borderClasses.value,\n colorClasses.value,\n densityClasses.value,\n elevationClasses.value,\n loaderClasses.value,\n positionClasses.value,\n roundedClasses.value,\n variantClasses.value,\n ]}\n style={[\n colorStyles.value,\n dimensionStyles.value,\n locationStyles.value,\n ]}\n href={ link.href.value }\n onClick={ isClickable.value && link.navigate }\n v-ripple={ isClickable.value && props.ripple }\n tabindex={ props.disabled ? -1 : undefined }\n >\n { hasImage && (\n <VDefaultsProvider\n key=\"image\"\n defaults={{\n VImg: {\n cover: true,\n src: props.image,\n },\n }}\n >\n <div class=\"v-card__image\">\n { slots.image?.() ?? <VImg /> }\n </div>\n </VDefaultsProvider>\n ) }\n\n <LoaderSlot\n name=\"v-card\"\n active={ !!props.loading }\n color={ typeof props.loading === 'boolean' ? undefined : props.loading }\n v-slots={{ default: slots.loader }}\n />\n\n { hasCardItem && (\n <VCardItem\n key=\"item\"\n prependAvatar={ props.prependAvatar }\n prependIcon={ props.prependIcon }\n title={ props.title }\n subtitle={ props.subtitle }\n appendAvatar={ props.appendAvatar }\n appendIcon={ props.appendIcon }\n >\n {{\n default: slots.item,\n prepend: slots.prepend,\n title: slots.title,\n subtitle: slots.subtitle,\n append: slots.append,\n }}\n </VCardItem>\n ) }\n\n { hasText && (\n <VCardText key=\"text\">\n { slots.text?.() ?? props.text }\n </VCardText>\n ) }\n\n { slots.default?.() }\n\n { slots.actions && (\n <VCardActions v-slots={{ default: slots.actions }} />\n ) }\n\n { genOverlays(isClickable.value, 'v-card') }\n </Tag>\n )\n })\n\n return {}\n },\n})\n\nexport type VCard = InstanceType<typeof VCard>\n"],"mappings":"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"}
|
|
@@ -71,7 +71,10 @@ declare const VCard: vue.DefineComponent<{
|
|
|
71
71
|
};
|
|
72
72
|
prependAvatar: StringConstructor;
|
|
73
73
|
prependIcon: vue.PropType<IconValue>;
|
|
74
|
-
ripple:
|
|
74
|
+
ripple: {
|
|
75
|
+
type: BooleanConstructor;
|
|
76
|
+
default: boolean;
|
|
77
|
+
};
|
|
75
78
|
subtitle: StringConstructor;
|
|
76
79
|
text: StringConstructor;
|
|
77
80
|
title: StringConstructor;
|
|
@@ -132,7 +135,10 @@ declare const VCard: vue.DefineComponent<{
|
|
|
132
135
|
};
|
|
133
136
|
prependAvatar: StringConstructor;
|
|
134
137
|
prependIcon: vue.PropType<IconValue>;
|
|
135
|
-
ripple:
|
|
138
|
+
ripple: {
|
|
139
|
+
type: BooleanConstructor;
|
|
140
|
+
default: boolean;
|
|
141
|
+
};
|
|
136
142
|
subtitle: StringConstructor;
|
|
137
143
|
text: StringConstructor;
|
|
138
144
|
title: StringConstructor;
|
|
@@ -206,7 +206,7 @@ export const VCombobox = genericComponent()({
|
|
|
206
206
|
vTextFieldRef.value.setSelectionRange(0, 0);
|
|
207
207
|
}
|
|
208
208
|
}
|
|
209
|
-
if (e.key === 'Enter') {
|
|
209
|
+
if (e.key === 'Enter' && search.value) {
|
|
210
210
|
select(transformItem(props, search.value));
|
|
211
211
|
search.value = '';
|
|
212
212
|
}
|
|
@@ -295,6 +295,7 @@ export const VCombobox = genericComponent()({
|
|
|
295
295
|
"activator": "parent",
|
|
296
296
|
"contentClass": "v-combobox__content",
|
|
297
297
|
"eager": props.eager,
|
|
298
|
+
"maxHeight": 310,
|
|
298
299
|
"openOnClick": false,
|
|
299
300
|
"closeOnContentClick": false,
|
|
300
301
|
"transition": props.transition,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VCombobox.mjs","names":["makeSelectProps","VCheckboxBtn","VChip","VDefaultsProvider","VList","VListItem","VMenu","VTextField","forwardRefs","makeFilterProps","useFilter","makeTransitionProps","transformItem","useItems","useForm","useLocale","useProxiedModel","useTextColor","computed","mergeProps","nextTick","ref","watch","genericComponent","omit","useRender","wrapInArray","filterVTextFieldProps","makeVTextFieldProps","highlightResult","text","matches","length","Array","isArray","Error","substr","VCombobox","name","props","delimiters","filterKeys","hideNoData","returnObject","modelValue","transition","emits","val","setup","emit","slots","t","vTextFieldRef","isFocused","isPristine","menu","selectionIndex","color","value","items","transformIn","transformOut","textColorClasses","textColorStyles","model","v","transformed","multiple","form","_search","title","search","get","set","values","split","RegExp","join","forEach","trim","select","filteredItems","getMatches","undefined","selections","map","find","item","valueComparator","displayItems","hideSelected","filter","filteredItem","some","s","selected","selection","listRef","onClear","e","openOnClear","onClickControl","readonly","isReadonly","onKeydown","selectionStart","preventDefault","includes","key","focus","prev","setSelectionRange","next","onAfterLeave","index","findIndex","splice","onFocusin","onFocusout","relatedTarget","hasChips","chips","chip","hasList","prepend","append","textFieldProps","externalValue","menuIcon","default","eager","menuProps","noDataText","onClick","isSelected","onChipClose","stopPropagation","slotProps","closable","closableChips","size"],"sources":["../../../src/components/VCombobox/VCombobox.tsx"],"sourcesContent":["// Styles\nimport './VCombobox.sass'\n\n// Components\nimport { makeSelectProps } from '@/components/VSelect/VSelect'\nimport { VCheckboxBtn } from '@/components/VCheckbox'\nimport { VChip } from '@/components/VChip'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VList, VListItem } from '@/components/VList'\nimport { VMenu } from '@/components/VMenu'\nimport { VTextField } from '@/components/VTextField'\n\n// Composables\nimport { forwardRefs } from '@/composables/forwardRefs'\nimport { makeFilterProps, useFilter } from '@/composables/filter'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { transformItem, useItems } from '@/composables/items'\nimport { useForm } from '@/composables/form'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useTextColor } from '@/composables/color'\n\n// Utility\nimport { computed, mergeProps, nextTick, ref, watch } from 'vue'\nimport { genericComponent, omit, useRender, wrapInArray } from '@/util'\nimport { filterVTextFieldProps, makeVTextFieldProps } from '../VTextField/VTextField'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { MakeSlots, SlotsToProps } from '@/util'\nimport type { FilterMatch } from '@/composables/filter'\nimport type { InternalItem } from '@/composables/items'\nimport type { VFieldSlots } from '@/components/VField/VField'\nimport type { VInputSlots } from '@/components/VInput/VInput'\n\nfunction highlightResult (text: string, matches: FilterMatch | undefined, length: number) {\n if (matches == null) return text\n\n if (Array.isArray(matches)) throw new Error('Multiple matches is not implemented')\n\n return typeof matches === 'number' && ~matches\n ? (\n <>\n <span class=\"v-combobox__unmask\">{ text.substr(0, matches) }</span>\n <span class=\"v-combobox__mask\">{ text.substr(matches, length) }</span>\n <span class=\"v-combobox__unmask\">{ text.substr(matches + length) }</span>\n </>\n )\n : text\n}\n\ntype Primitive = string | number | boolean | symbol\n\ntype Val <T, ReturnObject extends boolean> = string | (T extends Primitive\n ? T\n : (ReturnObject extends true ? T : any))\n\ntype Value <T, ReturnObject extends boolean, Multiple extends boolean> =\n Multiple extends true\n ? readonly Val<T, ReturnObject>[]\n : Val<T, ReturnObject>\n\nexport const VCombobox = genericComponent<new <\n T,\n ReturnObject extends boolean = true,\n Multiple extends boolean = false,\n V extends Value<T, ReturnObject, Multiple> = Value<T, ReturnObject, Multiple>\n>() => {\n $props: {\n items?: readonly T[]\n returnObject?: ReturnObject\n multiple?: Multiple\n modelValue?: V\n 'onUpdate:modelValue'?: (val: V) => void\n } & SlotsToProps<\n Omit<VInputSlots & VFieldSlots, 'default'> & MakeSlots<{\n item: [{ item: InternalItem<T>, index: number, props: Record<string, unknown> }]\n chip: [{ item: InternalItem<T>, index: number, props: Record<string, unknown> }]\n selection: [{ item: InternalItem<T>, index: number }]\n 'prepend-item': []\n 'append-item': []\n 'no-data': []\n }>\n >\n}>()({\n name: 'VCombobox',\n\n props: {\n // TODO: implement post keyboard support\n // autoSelectFirst: Boolean,\n delimiters: Array as PropType<string[]>,\n\n ...makeFilterProps({ filterKeys: ['title'] }),\n ...makeSelectProps({ hideNoData: true, returnObject: true }),\n ...omit(makeVTextFieldProps({\n modelValue: null,\n }), ['validationValue', 'dirty', 'appendInnerIcon']),\n ...makeTransitionProps({ transition: false }),\n },\n\n emits: {\n 'update:modelValue': (val: any) => true,\n 'update:search': (val: string) => true,\n 'update:menu': (val: boolean) => true,\n },\n\n setup (props, { emit, slots }) {\n const { t } = useLocale()\n const vTextFieldRef = ref()\n const isFocused = ref(false)\n const isPristine = ref(true)\n const menu = useProxiedModel(props, 'menu')\n const selectionIndex = ref(-1)\n const color = computed(() => vTextFieldRef.value?.color)\n const { items, transformIn, transformOut } = useItems(props)\n const { textColorClasses, textColorStyles } = useTextColor(color)\n const model = useProxiedModel(\n props,\n 'modelValue',\n [],\n v => transformIn(wrapInArray(v || [])),\n v => {\n const transformed = transformOut(v)\n return props.multiple ? transformed : (transformed[0] ?? null)\n }\n )\n const form = useForm()\n const _search = ref(!props.multiple ? model.value[0]?.title ?? '' : '')\n const search = computed<string>({\n get: () => {\n return _search.value\n },\n set: val => {\n _search.value = val\n if (!props.multiple) {\n model.value = [transformItem(props, val)]\n }\n\n if (val && props.multiple && props.delimiters?.length) {\n const values = val.split(new RegExp(`(?:${props.delimiters.join('|')})+`))\n if (values.length > 1) {\n values.forEach(v => {\n v = v.trim()\n if (v) select(transformItem(props, v))\n })\n _search.value = ''\n }\n }\n\n if (!val) selectionIndex.value = -1\n if (isFocused.value) menu.value = true\n\n isPristine.value = !val\n },\n })\n watch(_search, value => {\n emit('update:search', value)\n })\n watch(model, value => {\n if (!props.multiple) {\n _search.value = value[0]?.title ?? ''\n }\n })\n\n const { filteredItems, getMatches } = useFilter(props, items, computed(() => isPristine.value ? undefined : search.value))\n\n const selections = computed(() => {\n return model.value.map(v => {\n return items.value.find(item => props.valueComparator(item.value, v.value)) || v\n })\n })\n\n const displayItems = computed(() => {\n if (props.hideSelected) {\n return filteredItems.value.filter(filteredItem => !selections.value.some(s => s.value === filteredItem.value))\n }\n return filteredItems.value\n })\n\n const selected = computed(() => selections.value.map(selection => selection.props.value))\n const selection = computed(() => selections.value[selectionIndex.value])\n const listRef = ref<VList>()\n\n function onClear (e: MouseEvent) {\n model.value = []\n\n if (props.openOnClear) {\n menu.value = true\n }\n }\n function onClickControl () {\n if (\n (props.hideNoData && !items.value.length) ||\n props.readonly || form?.isReadonly.value\n ) return\n\n menu.value = true\n }\n function onKeydown (e: KeyboardEvent) {\n if (props.readonly || form?.isReadonly.value) return\n\n const selectionStart = vTextFieldRef.value.selectionStart\n const length = selected.value.length\n\n if (selectionIndex.value > -1) e.preventDefault()\n\n if (['Enter', 'ArrowDown'].includes(e.key)) {\n menu.value = true\n }\n\n if (['Escape'].includes(e.key)) {\n menu.value = false\n }\n\n if (['Enter', 'Escape', 'Tab'].includes(e.key)) {\n isPristine.value = true\n }\n\n if (e.key === 'ArrowDown') {\n e.preventDefault()\n listRef.value?.focus('next')\n } else if (e.key === 'ArrowUp') {\n e.preventDefault()\n listRef.value?.focus('prev')\n }\n\n if (!props.multiple) return\n\n if (['Backspace', 'Delete'].includes(e.key)) {\n if (selectionIndex.value < 0) {\n if (e.key === 'Backspace' && !search.value) {\n selectionIndex.value = length - 1\n }\n\n return\n }\n\n select(selection.value)\n\n nextTick(() => !selection.value && (selectionIndex.value = length - 2))\n }\n\n if (e.key === 'ArrowLeft') {\n if (selectionIndex.value < 0 && selectionStart > 0) return\n\n const prev = selectionIndex.value > -1\n ? selectionIndex.value - 1\n : length - 1\n\n if (selections.value[prev]) {\n selectionIndex.value = prev\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(search.value.length, search.value.length)\n }\n }\n\n if (e.key === 'ArrowRight') {\n if (selectionIndex.value < 0) return\n\n const next = selectionIndex.value + 1\n\n if (selections.value[next]) {\n selectionIndex.value = next\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(0, 0)\n }\n }\n\n if (e.key === 'Enter') {\n select(transformItem(props, search.value))\n search.value = ''\n }\n }\n function onAfterLeave () {\n if (isFocused.value) isPristine.value = true\n }\n function select (item: InternalItem) {\n if (props.multiple) {\n const index = selected.value.findIndex(selection => props.valueComparator(selection, item.value))\n\n if (index === -1) {\n model.value = [...model.value, item]\n } else {\n const value = [...model.value]\n value.splice(index, 1)\n model.value = value\n }\n\n search.value = ''\n } else {\n model.value = [item]\n _search.value = item.title\n\n // watch for search watcher to trigger\n nextTick(() => {\n menu.value = false\n isPristine.value = true\n })\n }\n }\n\n function onFocusin (e: FocusEvent) {\n isFocused.value = true\n }\n\n function onFocusout (e: FocusEvent) {\n if (e.relatedTarget == null) {\n vTextFieldRef.value?.focus()\n }\n }\n\n watch(filteredItems, val => {\n if (!val.length && props.hideNoData) menu.value = false\n })\n\n watch(isFocused, val => {\n if (val) {\n selectionIndex.value = -1\n } else {\n menu.value = false\n\n if (!props.multiple || !search.value) return\n\n model.value = [...model.value, transformItem(props, search.value)]\n search.value = ''\n }\n })\n\n useRender(() => {\n const hasChips = !!(props.chips || slots.chip)\n const hasList = !!((!props.hideNoData || displayItems.value.length) || slots.prepend || slots.append || slots['no-data'])\n const [textFieldProps] = filterVTextFieldProps(props)\n\n return (\n <VTextField\n ref={ vTextFieldRef }\n { ...textFieldProps }\n v-model={ search.value }\n onUpdate:modelValue={ v => { if (v == null) model.value = [] } }\n validationValue={ model.externalValue }\n dirty={ model.value.length > 0 }\n class={[\n 'v-combobox',\n {\n 'v-combobox--active-menu': menu.value,\n 'v-combobox--chips': !!props.chips,\n 'v-combobox--selecting-index': selectionIndex.value > -1,\n [`v-combobox--${props.multiple ? 'multiple' : 'single'}`]: true,\n },\n ]}\n appendInnerIcon={ props.items.length ? props.menuIcon : undefined }\n readonly={ props.readonly }\n onClick:clear={ onClear }\n onClick:control={ onClickControl }\n onClick:input={ onClickControl }\n onFocus={ () => isFocused.value = true }\n onBlur={ () => isFocused.value = false }\n onKeydown={ onKeydown }\n >\n {{\n ...slots,\n default: () => (\n <>\n <VMenu\n v-model={ menu.value }\n activator=\"parent\"\n contentClass=\"v-combobox__content\"\n eager={ props.eager }\n openOnClick={ false }\n closeOnContentClick={ false }\n transition={ props.transition }\n onAfterLeave={ onAfterLeave }\n { ...props.menuProps }\n >\n { hasList && (\n <VList\n ref={ listRef }\n selected={ selected.value }\n selectStrategy={ props.multiple ? 'independent' : 'single-independent' }\n onMousedown={ (e: MouseEvent) => e.preventDefault() }\n onFocusin={ onFocusin }\n onFocusout={ onFocusout }\n >\n { !displayItems.value.length && !props.hideNoData && (slots['no-data']?.() ?? (\n <VListItem title={ t(props.noDataText) } />\n )) }\n\n { slots['prepend-item']?.() }\n\n { displayItems.value.map((item, index) => slots.item?.({\n item,\n index,\n props: mergeProps(item.props, { onClick: () => select(item) }),\n }) ?? (\n <VListItem\n key={ index }\n { ...item.props }\n onClick={ () => select(item) }\n >\n {{\n prepend: ({ isSelected }) => props.multiple && !props.hideSelected ? (\n <VCheckboxBtn modelValue={ isSelected } ripple={ false } />\n ) : undefined,\n title: () => {\n return isPristine.value\n ? item.title\n : highlightResult(item.title, getMatches(item)?.title, search.value?.length ?? 0)\n },\n }}\n </VListItem>\n )) }\n\n { slots['append-item']?.() }\n </VList>\n ) }\n </VMenu>\n\n { selections.value.map((item, index) => {\n function onChipClose (e: Event) {\n e.stopPropagation()\n e.preventDefault()\n\n select(item)\n }\n\n const slotProps = {\n 'onClick:close': onChipClose,\n modelValue: true,\n 'onUpdate:modelValue': undefined,\n }\n\n return (\n <div\n key={ item.value }\n class={[\n 'v-combobox__selection',\n index === selectionIndex.value && [\n 'v-combobox__selection--selected',\n textColorClasses.value,\n ],\n ]}\n style={ index === selectionIndex.value ? textColorStyles.value : {} }\n >\n { hasChips ? (\n <VDefaultsProvider\n defaults={{\n VChip: {\n closable: props.closableChips,\n size: 'small',\n text: item.title,\n },\n }}\n >\n { slots.chip\n ? slots.chip({ item, index, props: slotProps })\n : (<VChip { ...slotProps } />)\n }\n </VDefaultsProvider>\n ) : (\n slots.selection\n ? slots.selection({ item, index })\n : (\n <span class=\"v-combobox__selection-text\">\n { item.title }\n { props.multiple && (index < selections.value.length - 1) && (\n <span class=\"v-combobox__selection-comma\">,</span>\n ) }\n </span>\n )\n ) }\n </div>\n )\n }) }\n </>\n ),\n }}\n </VTextField>\n )\n })\n\n return forwardRefs({\n isFocused,\n isPristine,\n menu,\n search,\n selectionIndex,\n filteredItems,\n select,\n }, vTextFieldRef)\n },\n})\n\nexport type VCombobox = InstanceType<typeof VCombobox>\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"VCombobox.mjs","names":["makeSelectProps","VCheckboxBtn","VChip","VDefaultsProvider","VList","VListItem","VMenu","VTextField","forwardRefs","makeFilterProps","useFilter","makeTransitionProps","transformItem","useItems","useForm","useLocale","useProxiedModel","useTextColor","computed","mergeProps","nextTick","ref","watch","genericComponent","omit","useRender","wrapInArray","filterVTextFieldProps","makeVTextFieldProps","highlightResult","text","matches","length","Array","isArray","Error","substr","VCombobox","name","props","delimiters","filterKeys","hideNoData","returnObject","modelValue","transition","emits","val","setup","emit","slots","t","vTextFieldRef","isFocused","isPristine","menu","selectionIndex","color","value","items","transformIn","transformOut","textColorClasses","textColorStyles","model","v","transformed","multiple","form","_search","title","search","get","set","values","split","RegExp","join","forEach","trim","select","filteredItems","getMatches","undefined","selections","map","find","item","valueComparator","displayItems","hideSelected","filter","filteredItem","some","s","selected","selection","listRef","onClear","e","openOnClear","onClickControl","readonly","isReadonly","onKeydown","selectionStart","preventDefault","includes","key","focus","prev","setSelectionRange","next","onAfterLeave","index","findIndex","splice","onFocusin","onFocusout","relatedTarget","hasChips","chips","chip","hasList","prepend","append","textFieldProps","externalValue","menuIcon","default","eager","menuProps","noDataText","onClick","isSelected","onChipClose","stopPropagation","slotProps","closable","closableChips","size"],"sources":["../../../src/components/VCombobox/VCombobox.tsx"],"sourcesContent":["// Styles\nimport './VCombobox.sass'\n\n// Components\nimport { makeSelectProps } from '@/components/VSelect/VSelect'\nimport { VCheckboxBtn } from '@/components/VCheckbox'\nimport { VChip } from '@/components/VChip'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VList, VListItem } from '@/components/VList'\nimport { VMenu } from '@/components/VMenu'\nimport { VTextField } from '@/components/VTextField'\n\n// Composables\nimport { forwardRefs } from '@/composables/forwardRefs'\nimport { makeFilterProps, useFilter } from '@/composables/filter'\nimport { makeTransitionProps } from '@/composables/transition'\nimport { transformItem, useItems } from '@/composables/items'\nimport { useForm } from '@/composables/form'\nimport { useLocale } from '@/composables/locale'\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useTextColor } from '@/composables/color'\n\n// Utility\nimport { computed, mergeProps, nextTick, ref, watch } from 'vue'\nimport { genericComponent, omit, useRender, wrapInArray } from '@/util'\nimport { filterVTextFieldProps, makeVTextFieldProps } from '../VTextField/VTextField'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { MakeSlots, SlotsToProps } from '@/util'\nimport type { FilterMatch } from '@/composables/filter'\nimport type { InternalItem } from '@/composables/items'\nimport type { VFieldSlots } from '@/components/VField/VField'\nimport type { VInputSlots } from '@/components/VInput/VInput'\n\nfunction highlightResult (text: string, matches: FilterMatch | undefined, length: number) {\n if (matches == null) return text\n\n if (Array.isArray(matches)) throw new Error('Multiple matches is not implemented')\n\n return typeof matches === 'number' && ~matches\n ? (\n <>\n <span class=\"v-combobox__unmask\">{ text.substr(0, matches) }</span>\n <span class=\"v-combobox__mask\">{ text.substr(matches, length) }</span>\n <span class=\"v-combobox__unmask\">{ text.substr(matches + length) }</span>\n </>\n )\n : text\n}\n\ntype Primitive = string | number | boolean | symbol\n\ntype Val <T, ReturnObject extends boolean> = string | (T extends Primitive\n ? T\n : (ReturnObject extends true ? T : any))\n\ntype Value <T, ReturnObject extends boolean, Multiple extends boolean> =\n Multiple extends true\n ? readonly Val<T, ReturnObject>[]\n : Val<T, ReturnObject>\n\nexport const VCombobox = genericComponent<new <\n T,\n ReturnObject extends boolean = true,\n Multiple extends boolean = false,\n V extends Value<T, ReturnObject, Multiple> = Value<T, ReturnObject, Multiple>\n>() => {\n $props: {\n items?: readonly T[]\n returnObject?: ReturnObject\n multiple?: Multiple\n modelValue?: V\n 'onUpdate:modelValue'?: (val: V) => void\n } & SlotsToProps<\n Omit<VInputSlots & VFieldSlots, 'default'> & MakeSlots<{\n item: [{ item: InternalItem<T>, index: number, props: Record<string, unknown> }]\n chip: [{ item: InternalItem<T>, index: number, props: Record<string, unknown> }]\n selection: [{ item: InternalItem<T>, index: number }]\n 'prepend-item': []\n 'append-item': []\n 'no-data': []\n }>\n >\n}>()({\n name: 'VCombobox',\n\n props: {\n // TODO: implement post keyboard support\n // autoSelectFirst: Boolean,\n delimiters: Array as PropType<string[]>,\n\n ...makeFilterProps({ filterKeys: ['title'] }),\n ...makeSelectProps({ hideNoData: true, returnObject: true }),\n ...omit(makeVTextFieldProps({\n modelValue: null,\n }), ['validationValue', 'dirty', 'appendInnerIcon']),\n ...makeTransitionProps({ transition: false }),\n },\n\n emits: {\n 'update:modelValue': (val: any) => true,\n 'update:search': (val: string) => true,\n 'update:menu': (val: boolean) => true,\n },\n\n setup (props, { emit, slots }) {\n const { t } = useLocale()\n const vTextFieldRef = ref()\n const isFocused = ref(false)\n const isPristine = ref(true)\n const menu = useProxiedModel(props, 'menu')\n const selectionIndex = ref(-1)\n const color = computed(() => vTextFieldRef.value?.color)\n const { items, transformIn, transformOut } = useItems(props)\n const { textColorClasses, textColorStyles } = useTextColor(color)\n const model = useProxiedModel(\n props,\n 'modelValue',\n [],\n v => transformIn(wrapInArray(v || [])),\n v => {\n const transformed = transformOut(v)\n return props.multiple ? transformed : (transformed[0] ?? null)\n }\n )\n const form = useForm()\n const _search = ref(!props.multiple ? model.value[0]?.title ?? '' : '')\n const search = computed<string>({\n get: () => {\n return _search.value\n },\n set: val => {\n _search.value = val\n if (!props.multiple) {\n model.value = [transformItem(props, val)]\n }\n\n if (val && props.multiple && props.delimiters?.length) {\n const values = val.split(new RegExp(`(?:${props.delimiters.join('|')})+`))\n if (values.length > 1) {\n values.forEach(v => {\n v = v.trim()\n if (v) select(transformItem(props, v))\n })\n _search.value = ''\n }\n }\n\n if (!val) selectionIndex.value = -1\n if (isFocused.value) menu.value = true\n\n isPristine.value = !val\n },\n })\n watch(_search, value => {\n emit('update:search', value)\n })\n watch(model, value => {\n if (!props.multiple) {\n _search.value = value[0]?.title ?? ''\n }\n })\n\n const { filteredItems, getMatches } = useFilter(props, items, computed(() => isPristine.value ? undefined : search.value))\n\n const selections = computed(() => {\n return model.value.map(v => {\n return items.value.find(item => props.valueComparator(item.value, v.value)) || v\n })\n })\n\n const displayItems = computed(() => {\n if (props.hideSelected) {\n return filteredItems.value.filter(filteredItem => !selections.value.some(s => s.value === filteredItem.value))\n }\n return filteredItems.value\n })\n\n const selected = computed(() => selections.value.map(selection => selection.props.value))\n const selection = computed(() => selections.value[selectionIndex.value])\n const listRef = ref<VList>()\n\n function onClear (e: MouseEvent) {\n model.value = []\n\n if (props.openOnClear) {\n menu.value = true\n }\n }\n function onClickControl () {\n if (\n (props.hideNoData && !items.value.length) ||\n props.readonly || form?.isReadonly.value\n ) return\n\n menu.value = true\n }\n function onKeydown (e: KeyboardEvent) {\n if (props.readonly || form?.isReadonly.value) return\n\n const selectionStart = vTextFieldRef.value.selectionStart\n const length = selected.value.length\n\n if (selectionIndex.value > -1) e.preventDefault()\n\n if (['Enter', 'ArrowDown'].includes(e.key)) {\n menu.value = true\n }\n\n if (['Escape'].includes(e.key)) {\n menu.value = false\n }\n\n if (['Enter', 'Escape', 'Tab'].includes(e.key)) {\n isPristine.value = true\n }\n\n if (e.key === 'ArrowDown') {\n e.preventDefault()\n listRef.value?.focus('next')\n } else if (e.key === 'ArrowUp') {\n e.preventDefault()\n listRef.value?.focus('prev')\n }\n\n if (!props.multiple) return\n\n if (['Backspace', 'Delete'].includes(e.key)) {\n if (selectionIndex.value < 0) {\n if (e.key === 'Backspace' && !search.value) {\n selectionIndex.value = length - 1\n }\n\n return\n }\n\n select(selection.value)\n\n nextTick(() => !selection.value && (selectionIndex.value = length - 2))\n }\n\n if (e.key === 'ArrowLeft') {\n if (selectionIndex.value < 0 && selectionStart > 0) return\n\n const prev = selectionIndex.value > -1\n ? selectionIndex.value - 1\n : length - 1\n\n if (selections.value[prev]) {\n selectionIndex.value = prev\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(search.value.length, search.value.length)\n }\n }\n\n if (e.key === 'ArrowRight') {\n if (selectionIndex.value < 0) return\n\n const next = selectionIndex.value + 1\n\n if (selections.value[next]) {\n selectionIndex.value = next\n } else {\n selectionIndex.value = -1\n vTextFieldRef.value.setSelectionRange(0, 0)\n }\n }\n\n if (e.key === 'Enter' && search.value) {\n select(transformItem(props, search.value))\n search.value = ''\n }\n }\n function onAfterLeave () {\n if (isFocused.value) isPristine.value = true\n }\n function select (item: InternalItem) {\n if (props.multiple) {\n const index = selected.value.findIndex(selection => props.valueComparator(selection, item.value))\n\n if (index === -1) {\n model.value = [...model.value, item]\n } else {\n const value = [...model.value]\n value.splice(index, 1)\n model.value = value\n }\n\n search.value = ''\n } else {\n model.value = [item]\n _search.value = item.title\n\n // watch for search watcher to trigger\n nextTick(() => {\n menu.value = false\n isPristine.value = true\n })\n }\n }\n\n function onFocusin (e: FocusEvent) {\n isFocused.value = true\n }\n\n function onFocusout (e: FocusEvent) {\n if (e.relatedTarget == null) {\n vTextFieldRef.value?.focus()\n }\n }\n\n watch(filteredItems, val => {\n if (!val.length && props.hideNoData) menu.value = false\n })\n\n watch(isFocused, val => {\n if (val) {\n selectionIndex.value = -1\n } else {\n menu.value = false\n\n if (!props.multiple || !search.value) return\n\n model.value = [...model.value, transformItem(props, search.value)]\n search.value = ''\n }\n })\n\n useRender(() => {\n const hasChips = !!(props.chips || slots.chip)\n const hasList = !!((!props.hideNoData || displayItems.value.length) || slots.prepend || slots.append || slots['no-data'])\n const [textFieldProps] = filterVTextFieldProps(props)\n\n return (\n <VTextField\n ref={ vTextFieldRef }\n { ...textFieldProps }\n v-model={ search.value }\n onUpdate:modelValue={ v => { if (v == null) model.value = [] } }\n validationValue={ model.externalValue }\n dirty={ model.value.length > 0 }\n class={[\n 'v-combobox',\n {\n 'v-combobox--active-menu': menu.value,\n 'v-combobox--chips': !!props.chips,\n 'v-combobox--selecting-index': selectionIndex.value > -1,\n [`v-combobox--${props.multiple ? 'multiple' : 'single'}`]: true,\n },\n ]}\n appendInnerIcon={ props.items.length ? props.menuIcon : undefined }\n readonly={ props.readonly }\n onClick:clear={ onClear }\n onClick:control={ onClickControl }\n onClick:input={ onClickControl }\n onFocus={ () => isFocused.value = true }\n onBlur={ () => isFocused.value = false }\n onKeydown={ onKeydown }\n >\n {{\n ...slots,\n default: () => (\n <>\n <VMenu\n v-model={ menu.value }\n activator=\"parent\"\n contentClass=\"v-combobox__content\"\n eager={ props.eager }\n maxHeight={ 310 }\n openOnClick={ false }\n closeOnContentClick={ false }\n transition={ props.transition }\n onAfterLeave={ onAfterLeave }\n { ...props.menuProps }\n >\n { hasList && (\n <VList\n ref={ listRef }\n selected={ selected.value }\n selectStrategy={ props.multiple ? 'independent' : 'single-independent' }\n onMousedown={ (e: MouseEvent) => e.preventDefault() }\n onFocusin={ onFocusin }\n onFocusout={ onFocusout }\n >\n { !displayItems.value.length && !props.hideNoData && (slots['no-data']?.() ?? (\n <VListItem title={ t(props.noDataText) } />\n )) }\n\n { slots['prepend-item']?.() }\n\n { displayItems.value.map((item, index) => slots.item?.({\n item,\n index,\n props: mergeProps(item.props, { onClick: () => select(item) }),\n }) ?? (\n <VListItem\n key={ index }\n { ...item.props }\n onClick={ () => select(item) }\n >\n {{\n prepend: ({ isSelected }) => props.multiple && !props.hideSelected ? (\n <VCheckboxBtn modelValue={ isSelected } ripple={ false } />\n ) : undefined,\n title: () => {\n return isPristine.value\n ? item.title\n : highlightResult(item.title, getMatches(item)?.title, search.value?.length ?? 0)\n },\n }}\n </VListItem>\n )) }\n\n { slots['append-item']?.() }\n </VList>\n ) }\n </VMenu>\n\n { selections.value.map((item, index) => {\n function onChipClose (e: Event) {\n e.stopPropagation()\n e.preventDefault()\n\n select(item)\n }\n\n const slotProps = {\n 'onClick:close': onChipClose,\n modelValue: true,\n 'onUpdate:modelValue': undefined,\n }\n\n return (\n <div\n key={ item.value }\n class={[\n 'v-combobox__selection',\n index === selectionIndex.value && [\n 'v-combobox__selection--selected',\n textColorClasses.value,\n ],\n ]}\n style={ index === selectionIndex.value ? textColorStyles.value : {} }\n >\n { hasChips ? (\n <VDefaultsProvider\n defaults={{\n VChip: {\n closable: props.closableChips,\n size: 'small',\n text: item.title,\n },\n }}\n >\n { slots.chip\n ? slots.chip({ item, index, props: slotProps })\n : (<VChip { ...slotProps } />)\n }\n </VDefaultsProvider>\n ) : (\n slots.selection\n ? slots.selection({ item, index })\n : (\n <span class=\"v-combobox__selection-text\">\n { item.title }\n { props.multiple && (index < selections.value.length - 1) && (\n <span class=\"v-combobox__selection-comma\">,</span>\n ) }\n </span>\n )\n ) }\n </div>\n )\n }) }\n </>\n ),\n }}\n </VTextField>\n )\n })\n\n return forwardRefs({\n isFocused,\n isPristine,\n menu,\n search,\n selectionIndex,\n filteredItems,\n select,\n }, vTextFieldRef)\n },\n})\n\nexport type VCombobox = InstanceType<typeof VCombobox>\n"],"mappings":"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"}
|
|
@@ -46,6 +46,10 @@ export const VListItem = genericComponent()({
|
|
|
46
46
|
nav: Boolean,
|
|
47
47
|
prependAvatar: String,
|
|
48
48
|
prependIcon: IconValue,
|
|
49
|
+
ripple: {
|
|
50
|
+
type: Boolean,
|
|
51
|
+
default: true
|
|
52
|
+
},
|
|
49
53
|
subtitle: [String, Number, Boolean],
|
|
50
54
|
title: [String, Number, Boolean],
|
|
51
55
|
value: null,
|
|
@@ -237,7 +241,7 @@ export const VListItem = genericComponent()({
|
|
|
237
241
|
"key": "append-avatar"
|
|
238
242
|
}, null)])]
|
|
239
243
|
})]
|
|
240
|
-
}), [[_resolveDirective("ripple"), isClickable.value]]);
|
|
244
|
+
}), [[_resolveDirective("ripple"), isClickable.value && props.ripple]]);
|
|
241
245
|
});
|
|
242
246
|
return {};
|
|
243
247
|
}
|