vuetify 3.1.11 → 3.1.12
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/dist/json/attributes.json +8 -12
- package/dist/json/importMap.json +84 -84
- package/dist/json/tags.json +0 -1
- package/dist/json/web-types.json +19 -25
- package/dist/vuetify-labs.css +129 -135
- package/dist/vuetify-labs.d.ts +73 -66
- package/dist/vuetify-labs.esm.js +65 -36
- package/dist/vuetify-labs.esm.js.map +1 -1
- package/dist/vuetify-labs.js +64 -35
- package/dist/vuetify-labs.min.css +2 -2
- package/dist/vuetify.css +53 -59
- package/dist/vuetify.d.ts +66 -75
- package/dist/vuetify.esm.js +44 -30
- package/dist/vuetify.esm.js.map +1 -1
- package/dist/vuetify.js +44 -30
- package/dist/vuetify.js.map +1 -1
- package/dist/vuetify.min.css +2 -2
- package/dist/vuetify.min.js +326 -325
- package/dist/vuetify.min.js.map +1 -1
- package/lib/components/VBadge/VBadge.css +1 -0
- package/lib/components/VBadge/VBadge.sass +1 -0
- package/lib/components/VCheckbox/VCheckbox.mjs +2 -2
- package/lib/components/VCheckbox/VCheckbox.mjs.map +1 -1
- package/lib/components/VCheckbox/index.d.ts +41 -50
- package/lib/components/VCombobox/VCombobox.mjs +9 -1
- package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
- package/lib/components/VDialog/VDialog.css +11 -18
- package/lib/components/VDialog/VDialog.mjs +2 -2
- package/lib/components/VDialog/VDialog.mjs.map +1 -1
- package/lib/components/VDialog/VDialog.sass +8 -15
- package/lib/components/VField/VField.mjs +5 -1
- package/lib/components/VField/VField.mjs.map +1 -1
- package/lib/components/VGrid/VCol.mjs +2 -2
- package/lib/components/VGrid/VCol.mjs.map +1 -1
- package/lib/components/VGrid/VRow.mjs +2 -2
- package/lib/components/VGrid/VRow.mjs.map +1 -1
- package/lib/components/VOverlay/VOverlay.css +1 -1
- package/lib/components/VOverlay/VOverlay.sass +1 -1
- package/lib/components/VTextField/VTextField.mjs +11 -6
- package/lib/components/VTextField/VTextField.mjs.map +1 -1
- package/lib/components/index.d.ts +41 -50
- package/lib/composables/forwardRefs.mjs +12 -15
- package/lib/composables/forwardRefs.mjs.map +1 -1
- package/lib/entry-bundler.mjs +1 -1
- package/lib/framework.mjs +1 -1
- package/lib/index.d.ts +25 -25
- package/lib/labs/VDataTable/VDataTable.mjs.map +1 -1
- package/lib/labs/VDataTable/VDataTableRow.mjs +5 -4
- package/lib/labs/VDataTable/VDataTableRow.mjs.map +1 -1
- package/lib/labs/VDataTable/VDataTableServer.mjs +3 -1
- package/lib/labs/VDataTable/VDataTableServer.mjs.map +1 -1
- package/lib/labs/VDataTable/composables/items.mjs +14 -1
- package/lib/labs/VDataTable/composables/items.mjs.map +1 -1
- package/lib/labs/VDataTable/index.d.ts +32 -16
- package/lib/labs/components.d.ts +32 -16
- package/lib/util/globals.mjs +1 -1
- package/lib/util/globals.mjs.map +1 -1
- package/package.json +2 -2
|
@@ -7,13 +7,13 @@ import { filterInputProps, makeVInputProps, VInput } from "../VInput/VInput.mjs"
|
|
|
7
7
|
import { makeVCheckboxBtnProps, VCheckboxBtn } from "./VCheckboxBtn.mjs"; // Composables
|
|
8
8
|
import { useFocus } from "../../composables/focus.mjs"; // Utilities
|
|
9
9
|
import { computed } from 'vue';
|
|
10
|
-
import { filterInputAttrs, genericComponent, getUid, useRender } from "../../util/index.mjs"; // Types
|
|
10
|
+
import { filterInputAttrs, genericComponent, getUid, omit, useRender } from "../../util/index.mjs"; // Types
|
|
11
11
|
export const VCheckbox = genericComponent()({
|
|
12
12
|
name: 'VCheckbox',
|
|
13
13
|
inheritAttrs: false,
|
|
14
14
|
props: {
|
|
15
15
|
...makeVInputProps(),
|
|
16
|
-
...makeVCheckboxBtnProps()
|
|
16
|
+
...omit(makeVCheckboxBtnProps(), ['inline'])
|
|
17
17
|
},
|
|
18
18
|
emits: {
|
|
19
19
|
'update:focused': focused => true
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VCheckbox.mjs","names":["filterInputProps","makeVInputProps","VInput","makeVCheckboxBtnProps","VCheckboxBtn","useFocus","computed","filterInputAttrs","genericComponent","getUid","useRender","VCheckbox","name","inheritAttrs","props","emits","focused","setup","attrs","slots","isFocused","focus","blur","uid","id","inputAttrs","controlAttrs","inputProps","_1","checkboxProps","_2","filterProps","value","default","messagesId","isDisabled","isReadonly"],"sources":["../../../src/components/VCheckbox/VCheckbox.tsx"],"sourcesContent":["// Styles\nimport './VCheckbox.sass'\n\n// Components\nimport type { VInputSlots } from '@/components/VInput/VInput'\nimport { filterInputProps, makeVInputProps, VInput } from '@/components/VInput/VInput'\nimport { makeVCheckboxBtnProps, VCheckboxBtn } from './VCheckboxBtn'\n\n// Composables\nimport { useFocus } from '@/composables/focus'\n\n// Utilities\nimport { computed } from 'vue'\nimport { filterInputAttrs, genericComponent, getUid, useRender } from '@/util'\n\n// Types\nimport type { VSelectionControlSlots } from '../VSelectionControl/VSelectionControl'\n\nexport type VCheckboxSlots = VInputSlots & VSelectionControlSlots\n\nexport const VCheckbox = genericComponent<VCheckboxSlots>()({\n name: 'VCheckbox',\n\n inheritAttrs: false,\n\n props: {\n ...makeVInputProps(),\n ...makeVCheckboxBtnProps(),\n },\n\n emits: {\n 'update:focused': (focused: boolean) => true,\n },\n\n setup (props, { attrs, slots }) {\n const { isFocused, focus, blur } = useFocus(props)\n\n const uid = getUid()\n const id = computed(() => props.id || `checkbox-${uid}`)\n\n useRender(() => {\n const [inputAttrs, controlAttrs] = filterInputAttrs(attrs)\n const [inputProps, _1] = filterInputProps(props)\n const [checkboxProps, _2] = VCheckboxBtn.filterProps(props)\n\n return (\n <VInput\n class=\"v-checkbox\"\n { ...inputAttrs }\n { ...inputProps }\n id={ id.value }\n focused={ isFocused.value }\n >\n {{\n ...slots,\n default: ({\n id,\n messagesId,\n isDisabled,\n isReadonly,\n }) => (\n <VCheckboxBtn\n { ...checkboxProps }\n id={ id.value }\n aria-describedby={ messagesId.value }\n disabled={ isDisabled.value }\n readonly={ isReadonly.value }\n { ...controlAttrs }\n onFocus={ focus }\n onBlur={ blur }\n v-slots={ slots }\n />\n ),\n }}\n </VInput>\n )\n })\n\n return {}\n },\n})\n\nexport type VCheckbox = InstanceType<typeof VCheckbox>\n"],"mappings":";AAAA;AACA;;AAEA;AAAA,SAESA,gBAAgB,EAAEC,eAAe,EAAEC,MAAM;AAAA,SACzCC,qBAAqB,EAAEC,YAAY,8BAE5C;AAAA,SACSC,QAAQ,uCAEjB;AACA,SAASC,QAAQ,QAAQ,KAAK;AAAA,SACrBC,gBAAgB,EAAEC,gBAAgB,EAAEC,MAAM,EAAEC,SAAS,
|
|
1
|
+
{"version":3,"file":"VCheckbox.mjs","names":["filterInputProps","makeVInputProps","VInput","makeVCheckboxBtnProps","VCheckboxBtn","useFocus","computed","filterInputAttrs","genericComponent","getUid","omit","useRender","VCheckbox","name","inheritAttrs","props","emits","focused","setup","attrs","slots","isFocused","focus","blur","uid","id","inputAttrs","controlAttrs","inputProps","_1","checkboxProps","_2","filterProps","value","default","messagesId","isDisabled","isReadonly"],"sources":["../../../src/components/VCheckbox/VCheckbox.tsx"],"sourcesContent":["// Styles\nimport './VCheckbox.sass'\n\n// Components\nimport type { VInputSlots } from '@/components/VInput/VInput'\nimport { filterInputProps, makeVInputProps, VInput } from '@/components/VInput/VInput'\nimport { makeVCheckboxBtnProps, VCheckboxBtn } from './VCheckboxBtn'\n\n// Composables\nimport { useFocus } from '@/composables/focus'\n\n// Utilities\nimport { computed } from 'vue'\nimport { filterInputAttrs, genericComponent, getUid, omit, useRender } from '@/util'\n\n// Types\nimport type { VSelectionControlSlots } from '../VSelectionControl/VSelectionControl'\n\nexport type VCheckboxSlots = VInputSlots & VSelectionControlSlots\n\nexport const VCheckbox = genericComponent<VCheckboxSlots>()({\n name: 'VCheckbox',\n\n inheritAttrs: false,\n\n props: {\n ...makeVInputProps(),\n ...omit(makeVCheckboxBtnProps(), ['inline']),\n },\n\n emits: {\n 'update:focused': (focused: boolean) => true,\n },\n\n setup (props, { attrs, slots }) {\n const { isFocused, focus, blur } = useFocus(props)\n\n const uid = getUid()\n const id = computed(() => props.id || `checkbox-${uid}`)\n\n useRender(() => {\n const [inputAttrs, controlAttrs] = filterInputAttrs(attrs)\n const [inputProps, _1] = filterInputProps(props)\n const [checkboxProps, _2] = VCheckboxBtn.filterProps(props)\n\n return (\n <VInput\n class=\"v-checkbox\"\n { ...inputAttrs }\n { ...inputProps }\n id={ id.value }\n focused={ isFocused.value }\n >\n {{\n ...slots,\n default: ({\n id,\n messagesId,\n isDisabled,\n isReadonly,\n }) => (\n <VCheckboxBtn\n { ...checkboxProps }\n id={ id.value }\n aria-describedby={ messagesId.value }\n disabled={ isDisabled.value }\n readonly={ isReadonly.value }\n { ...controlAttrs }\n onFocus={ focus }\n onBlur={ blur }\n v-slots={ slots }\n />\n ),\n }}\n </VInput>\n )\n })\n\n return {}\n },\n})\n\nexport type VCheckbox = InstanceType<typeof VCheckbox>\n"],"mappings":";AAAA;AACA;;AAEA;AAAA,SAESA,gBAAgB,EAAEC,eAAe,EAAEC,MAAM;AAAA,SACzCC,qBAAqB,EAAEC,YAAY,8BAE5C;AAAA,SACSC,QAAQ,uCAEjB;AACA,SAASC,QAAQ,QAAQ,KAAK;AAAA,SACrBC,gBAAgB,EAAEC,gBAAgB,EAAEC,MAAM,EAAEC,IAAI,EAAEC,SAAS,gCAEpE;AAKA,OAAO,MAAMC,SAAS,GAAGJ,gBAAgB,EAAkB,CAAC;EAC1DK,IAAI,EAAE,WAAW;EAEjBC,YAAY,EAAE,KAAK;EAEnBC,KAAK,EAAE;IACL,GAAGd,eAAe,EAAE;IACpB,GAAGS,IAAI,CAACP,qBAAqB,EAAE,EAAE,CAAC,QAAQ,CAAC;EAC7C,CAAC;EAEDa,KAAK,EAAE;IACL,gBAAgB,EAAGC,OAAgB,IAAK;EAC1C,CAAC;EAEDC,KAAK,CAAEH,KAAK,QAAoB;IAAA,IAAlB;MAAEI,KAAK;MAAEC;IAAM,CAAC;IAC5B,MAAM;MAAEC,SAAS;MAAEC,KAAK;MAAEC;IAAK,CAAC,GAAGlB,QAAQ,CAACU,KAAK,CAAC;IAElD,MAAMS,GAAG,GAAGf,MAAM,EAAE;IACpB,MAAMgB,EAAE,GAAGnB,QAAQ,CAAC,MAAMS,KAAK,CAACU,EAAE,IAAK,YAAWD,GAAI,EAAC,CAAC;IAExDb,SAAS,CAAC,MAAM;MACd,MAAM,CAACe,UAAU,EAAEC,YAAY,CAAC,GAAGpB,gBAAgB,CAACY,KAAK,CAAC;MAC1D,MAAM,CAACS,UAAU,EAAEC,EAAE,CAAC,GAAG7B,gBAAgB,CAACe,KAAK,CAAC;MAChD,MAAM,CAACe,aAAa,EAAEC,EAAE,CAAC,GAAG3B,YAAY,CAAC4B,WAAW,CAACjB,KAAK,CAAC;MAE3D;QAAA,SAEU;MAAY,GACbW,UAAU,EACVE,UAAU;QAAA,MACVH,EAAE,CAACQ,KAAK;QAAA,WACHZ,SAAS,CAACY;MAAK;QAGvB,GAAGb,KAAK;QACRc,OAAO,EAAE;UAAA,IAAC;YACRT,EAAE;YACFU,UAAU;YACVC,UAAU;YACVC;UACF,CAAC;UAAA,8CAEQP,aAAa;YAAA,MACbL,EAAE,CAACQ,KAAK;YAAA,oBACME,UAAU,CAACF,KAAK;YAAA,YACxBG,UAAU,CAACH,KAAK;YAAA,YAChBI,UAAU,CAACJ;UAAK,GACtBN,YAAY;YAAA,WACPL,KAAK;YAAA,UACNC;UAAI,IACHH,KAAK;QAAA;MAElB;IAIT,CAAC,CAAC;IAEF,OAAO,CAAC,CAAC;EACX;AACF,CAAC,CAAC"}
|
|
@@ -47,7 +47,6 @@ declare const VCheckbox: {
|
|
|
47
47
|
$: vue.ComponentInternalInstance;
|
|
48
48
|
$data: {};
|
|
49
49
|
$props: Partial<{
|
|
50
|
-
inline: boolean;
|
|
51
50
|
error: boolean;
|
|
52
51
|
direction: "horizontal" | "vertical";
|
|
53
52
|
disabled: boolean;
|
|
@@ -66,7 +65,6 @@ declare const VCheckbox: {
|
|
|
66
65
|
valueComparator: typeof deepEqual;
|
|
67
66
|
indeterminateIcon: IconValue;
|
|
68
67
|
}> & Omit<{
|
|
69
|
-
inline: boolean;
|
|
70
68
|
error: boolean;
|
|
71
69
|
direction: "horizontal" | "vertical";
|
|
72
70
|
disabled: boolean;
|
|
@@ -148,7 +146,7 @@ declare const VCheckbox: {
|
|
|
148
146
|
"v-slot:input"?: false | ((args_0: SelectionControlSlot) => vue.VNodeChild) | undefined;
|
|
149
147
|
} & {
|
|
150
148
|
"onUpdate:focused"?: ((focused: boolean) => any) | undefined;
|
|
151
|
-
} & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, "
|
|
149
|
+
} & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, "error" | "direction" | "disabled" | "multiple" | "readonly" | "indeterminate" | "messages" | "density" | "ripple" | "focused" | "errorMessages" | "maxErrors" | "rules" | "falseIcon" | "trueIcon" | "valueComparator" | "indeterminateIcon">;
|
|
152
150
|
$attrs: {
|
|
153
151
|
[x: string]: unknown;
|
|
154
152
|
};
|
|
@@ -163,7 +161,6 @@ declare const VCheckbox: {
|
|
|
163
161
|
$emit: (event: "update:focused", focused: boolean) => void;
|
|
164
162
|
$el: any;
|
|
165
163
|
$options: vue.ComponentOptionsBase<{
|
|
166
|
-
inline: boolean;
|
|
167
164
|
error: boolean;
|
|
168
165
|
direction: "horizontal" | "vertical";
|
|
169
166
|
disabled: boolean;
|
|
@@ -248,7 +245,6 @@ declare const VCheckbox: {
|
|
|
248
245
|
}, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
|
|
249
246
|
'update:focused': (focused: boolean) => boolean;
|
|
250
247
|
}, string, {
|
|
251
|
-
inline: boolean;
|
|
252
248
|
error: boolean;
|
|
253
249
|
direction: "horizontal" | "vertical";
|
|
254
250
|
disabled: boolean;
|
|
@@ -287,7 +283,6 @@ declare const VCheckbox: {
|
|
|
287
283
|
$nextTick: typeof vue.nextTick;
|
|
288
284
|
$watch<T extends string | ((...args: any) => any)>(source: T, cb: T extends (...args: any) => infer R ? (args_0: R, args_1: R) => any : (...args: any) => any, options?: vue.WatchOptions<boolean> | undefined): vue.WatchStopHandle;
|
|
289
285
|
} & {
|
|
290
|
-
inline: boolean;
|
|
291
286
|
error: boolean;
|
|
292
287
|
direction: "horizontal" | "vertical";
|
|
293
288
|
disabled: boolean;
|
|
@@ -374,7 +369,6 @@ declare const VCheckbox: {
|
|
|
374
369
|
__isTeleport?: undefined;
|
|
375
370
|
__isSuspense?: undefined;
|
|
376
371
|
} & vue.ComponentOptionsBase<{
|
|
377
|
-
inline: boolean;
|
|
378
372
|
error: boolean;
|
|
379
373
|
direction: "horizontal" | "vertical";
|
|
380
374
|
disabled: boolean;
|
|
@@ -459,7 +453,6 @@ declare const VCheckbox: {
|
|
|
459
453
|
}, {}, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, {
|
|
460
454
|
'update:focused': (focused: boolean) => boolean;
|
|
461
455
|
}, string, {
|
|
462
|
-
inline: boolean;
|
|
463
456
|
error: boolean;
|
|
464
457
|
direction: "horizontal" | "vertical";
|
|
465
458
|
disabled: boolean;
|
|
@@ -478,17 +471,31 @@ declare const VCheckbox: {
|
|
|
478
471
|
valueComparator: typeof deepEqual;
|
|
479
472
|
indeterminateIcon: IconValue;
|
|
480
473
|
}, {}, string> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & FilterPropsOptions<{
|
|
474
|
+
type: StringConstructor;
|
|
475
|
+
error: BooleanConstructor;
|
|
476
|
+
id: StringConstructor;
|
|
477
|
+
name: StringConstructor;
|
|
478
|
+
color: StringConstructor;
|
|
479
|
+
value: null;
|
|
480
|
+
label: StringConstructor;
|
|
481
|
+
disabled: BooleanConstructor;
|
|
482
|
+
multiple: {
|
|
483
|
+
type: vue.PropType<boolean | null>;
|
|
484
|
+
default: null;
|
|
485
|
+
};
|
|
486
|
+
readonly: BooleanConstructor;
|
|
487
|
+
indeterminate: BooleanConstructor;
|
|
488
|
+
theme: StringConstructor;
|
|
481
489
|
density: {
|
|
482
490
|
type: vue.PropType<Density>;
|
|
483
491
|
default: string;
|
|
484
492
|
validator: (v: any) => boolean;
|
|
485
493
|
};
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
inline: BooleanConstructor;
|
|
494
|
+
modelValue: null;
|
|
495
|
+
ripple: {
|
|
496
|
+
type: BooleanConstructor;
|
|
497
|
+
default: boolean;
|
|
498
|
+
};
|
|
492
499
|
falseIcon: {
|
|
493
500
|
type: vue.PropType<NonNullable<IconValue>>;
|
|
494
501
|
default: NonNullable<IconValue>;
|
|
@@ -497,27 +504,12 @@ declare const VCheckbox: {
|
|
|
497
504
|
type: vue.PropType<NonNullable<IconValue>>;
|
|
498
505
|
default: NonNullable<IconValue>;
|
|
499
506
|
};
|
|
500
|
-
ripple: {
|
|
501
|
-
type: BooleanConstructor;
|
|
502
|
-
default: boolean;
|
|
503
|
-
};
|
|
504
|
-
multiple: {
|
|
505
|
-
type: vue.PropType<boolean | null>;
|
|
506
|
-
default: null;
|
|
507
|
-
};
|
|
508
|
-
name: StringConstructor;
|
|
509
|
-
readonly: BooleanConstructor;
|
|
510
|
-
modelValue: null;
|
|
511
|
-
type: StringConstructor;
|
|
512
507
|
valueComparator: {
|
|
513
508
|
type: vue.PropType<typeof deepEqual>;
|
|
514
509
|
default: typeof deepEqual;
|
|
515
510
|
};
|
|
516
|
-
label: StringConstructor;
|
|
517
511
|
trueValue: null;
|
|
518
512
|
falseValue: null;
|
|
519
|
-
value: null;
|
|
520
|
-
indeterminate: BooleanConstructor;
|
|
521
513
|
indeterminateIcon: {
|
|
522
514
|
type: vue.PropType<IconValue>;
|
|
523
515
|
default: string;
|
|
@@ -552,17 +544,31 @@ declare const VCheckbox: {
|
|
|
552
544
|
'onClick:prepend': vue.PropType<EventProp<(...args: any[]) => any>>;
|
|
553
545
|
'onClick:append': vue.PropType<EventProp<(...args: any[]) => any>>;
|
|
554
546
|
}, vue.ExtractPropTypes<{
|
|
547
|
+
type: StringConstructor;
|
|
548
|
+
error: BooleanConstructor;
|
|
549
|
+
id: StringConstructor;
|
|
550
|
+
name: StringConstructor;
|
|
551
|
+
color: StringConstructor;
|
|
552
|
+
value: null;
|
|
553
|
+
label: StringConstructor;
|
|
554
|
+
disabled: BooleanConstructor;
|
|
555
|
+
multiple: {
|
|
556
|
+
type: vue.PropType<boolean | null>;
|
|
557
|
+
default: null;
|
|
558
|
+
};
|
|
559
|
+
readonly: BooleanConstructor;
|
|
560
|
+
indeterminate: BooleanConstructor;
|
|
561
|
+
theme: StringConstructor;
|
|
555
562
|
density: {
|
|
556
563
|
type: vue.PropType<Density>;
|
|
557
564
|
default: string;
|
|
558
565
|
validator: (v: any) => boolean;
|
|
559
566
|
};
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
inline: BooleanConstructor;
|
|
567
|
+
modelValue: null;
|
|
568
|
+
ripple: {
|
|
569
|
+
type: BooleanConstructor;
|
|
570
|
+
default: boolean;
|
|
571
|
+
};
|
|
566
572
|
falseIcon: {
|
|
567
573
|
type: vue.PropType<NonNullable<IconValue>>;
|
|
568
574
|
default: NonNullable<IconValue>;
|
|
@@ -571,27 +577,12 @@ declare const VCheckbox: {
|
|
|
571
577
|
type: vue.PropType<NonNullable<IconValue>>;
|
|
572
578
|
default: NonNullable<IconValue>;
|
|
573
579
|
};
|
|
574
|
-
ripple: {
|
|
575
|
-
type: BooleanConstructor;
|
|
576
|
-
default: boolean;
|
|
577
|
-
};
|
|
578
|
-
multiple: {
|
|
579
|
-
type: vue.PropType<boolean | null>;
|
|
580
|
-
default: null;
|
|
581
|
-
};
|
|
582
|
-
name: StringConstructor;
|
|
583
|
-
readonly: BooleanConstructor;
|
|
584
|
-
modelValue: null;
|
|
585
|
-
type: StringConstructor;
|
|
586
580
|
valueComparator: {
|
|
587
581
|
type: vue.PropType<typeof deepEqual>;
|
|
588
582
|
default: typeof deepEqual;
|
|
589
583
|
};
|
|
590
|
-
label: StringConstructor;
|
|
591
584
|
trueValue: null;
|
|
592
585
|
falseValue: null;
|
|
593
|
-
value: null;
|
|
594
|
-
indeterminate: BooleanConstructor;
|
|
595
586
|
indeterminateIcon: {
|
|
596
587
|
type: vue.PropType<IconValue>;
|
|
597
588
|
default: string;
|
|
@@ -78,6 +78,7 @@ export const VCombobox = genericComponent()({
|
|
|
78
78
|
}
|
|
79
79
|
});
|
|
80
80
|
const selectionIndex = ref(-1);
|
|
81
|
+
let cleared = false;
|
|
81
82
|
const color = computed(() => vTextFieldRef.value?.color);
|
|
82
83
|
const {
|
|
83
84
|
items,
|
|
@@ -114,11 +115,17 @@ export const VCombobox = genericComponent()({
|
|
|
114
115
|
}
|
|
115
116
|
}
|
|
116
117
|
if (!val) selectionIndex.value = -1;
|
|
117
|
-
if (isFocused.value) menu.value = true;
|
|
118
118
|
isPristine.value = !val;
|
|
119
119
|
}
|
|
120
120
|
});
|
|
121
121
|
watch(_search, value => {
|
|
122
|
+
if (cleared) {
|
|
123
|
+
// wait for clear to finish, VTextField sets _search to null
|
|
124
|
+
// then search computed triggers and updates _search to ''
|
|
125
|
+
nextTick(() => cleared = false);
|
|
126
|
+
} else if (isFocused.value && !menu.value) {
|
|
127
|
+
menu.value = true;
|
|
128
|
+
}
|
|
122
129
|
emit('update:search', value);
|
|
123
130
|
});
|
|
124
131
|
watch(model, value => {
|
|
@@ -145,6 +152,7 @@ export const VCombobox = genericComponent()({
|
|
|
145
152
|
const selection = computed(() => selections.value[selectionIndex.value]);
|
|
146
153
|
const listRef = ref();
|
|
147
154
|
function onClear(e) {
|
|
155
|
+
cleared = true;
|
|
148
156
|
if (props.openOnClear) {
|
|
149
157
|
menu.value = true;
|
|
150
158
|
}
|
|
@@ -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","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","vMenuRef","_menu","menu","get","value","set","v","ΨopenChildren","selectionIndex","color","items","transformIn","transformOut","textColorClasses","textColorStyles","model","transformed","multiple","form","_search","title","search","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","onMousedownControl","readonly","isReadonly","onKeydown","selectionStart","includes","key","preventDefault","focus","prev","setSelectionRange","next","onAfterLeave","index","findIndex","splice","onFocusin","onFocusout","relatedTarget","hasChips","chips","chip","hasList","prepend","append","textFieldProps","filterProps","externalValue","menuIcon","default","eager","menuProps","noDataText","onClick","isSelected","onChipClose","stopPropagation","slotProps","closableChips","closable","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 { makeVTextFieldProps } from '@/components/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 vMenuRef = ref<VMenu>()\n const _menu = useProxiedModel(props, 'menu')\n const menu = computed({\n get: () => _menu.value,\n set: v => {\n if (_menu.value && !v && vMenuRef.value?.ΨopenChildren) return\n _menu.value = v\n },\n })\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 if (props.openOnClear) {\n menu.value = true\n }\n }\n function onMousedownControl () {\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 (\n selectionIndex.value > -1 ||\n ['Enter', 'ArrowDown', 'ArrowUp'].includes(e.key)\n ) {\n e.preventDefault()\n }\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 listRef.value?.focus('next')\n } else if (e.key === 'ArrowUp') {\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] = VTextField.filterProps(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 onMousedown:control={ onMousedownControl }\n onFocus={ () => isFocused.value = true }\n onBlur={ () => isFocused.value = false }\n onKeydown={ onKeydown }\n >\n {{\n ...slots,\n default: () => (\n <>\n <VMenu\n ref={ vMenuRef }\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 !slots.chip ? (\n <VChip\n key=\"chip\"\n closable={ props.closableChips }\n size=\"small\"\n text={ item.title }\n { ...slotProps }\n />\n ) : (\n <VDefaultsProvider\n key=\"chip-defaults\"\n defaults={{\n VChip: {\n closable: props.closableChips,\n size: 'small',\n text: item.title,\n },\n }}\n >\n { slots.chip?.({ item, index, props: slotProps }) }\n </VDefaultsProvider>\n )\n ) : (\n slots.selection?.({ item, index }) ?? (\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","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","vMenuRef","_menu","menu","get","value","set","v","ΨopenChildren","selectionIndex","cleared","color","items","transformIn","transformOut","textColorClasses","textColorStyles","model","transformed","multiple","form","_search","title","search","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","onMousedownControl","readonly","isReadonly","onKeydown","selectionStart","includes","key","preventDefault","focus","prev","setSelectionRange","next","onAfterLeave","index","findIndex","splice","onFocusin","onFocusout","relatedTarget","hasChips","chips","chip","hasList","prepend","append","textFieldProps","filterProps","externalValue","menuIcon","default","eager","menuProps","noDataText","onClick","isSelected","onChipClose","stopPropagation","slotProps","closableChips","closable","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 { makeVTextFieldProps } from '@/components/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 vMenuRef = ref<VMenu>()\n const _menu = useProxiedModel(props, 'menu')\n const menu = computed({\n get: () => _menu.value,\n set: v => {\n if (_menu.value && !v && vMenuRef.value?.ΨopenChildren) return\n _menu.value = v\n },\n })\n const selectionIndex = ref(-1)\n let cleared = false\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\n isPristine.value = !val\n },\n })\n watch(_search, value => {\n if (cleared) {\n // wait for clear to finish, VTextField sets _search to null\n // then search computed triggers and updates _search to ''\n nextTick(() => (cleared = false))\n } else if (isFocused.value && !menu.value) {\n menu.value = true\n }\n\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 cleared = true\n\n if (props.openOnClear) {\n menu.value = true\n }\n }\n function onMousedownControl () {\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 (\n selectionIndex.value > -1 ||\n ['Enter', 'ArrowDown', 'ArrowUp'].includes(e.key)\n ) {\n e.preventDefault()\n }\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 listRef.value?.focus('next')\n } else if (e.key === 'ArrowUp') {\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] = VTextField.filterProps(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 onMousedown:control={ onMousedownControl }\n onFocus={ () => isFocused.value = true }\n onBlur={ () => isFocused.value = false }\n onKeydown={ onKeydown }\n >\n {{\n ...slots,\n default: () => (\n <>\n <VMenu\n ref={ vMenuRef }\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 !slots.chip ? (\n <VChip\n key=\"chip\"\n closable={ props.closableChips }\n size=\"small\"\n text={ item.title }\n { ...slotProps }\n />\n ) : (\n <VDefaultsProvider\n key=\"chip-defaults\"\n defaults={{\n VChip: {\n closable: props.closableChips,\n size: 'small',\n text: item.title,\n },\n }}\n >\n { slots.chip?.({ item, index, props: slotProps }) }\n </VDefaultsProvider>\n )\n ) : (\n slots.selection?.({ item, index }) ?? (\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,19 +1,15 @@
|
|
|
1
1
|
.v-dialog {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
.v-dialog.v-overlay--scroll-blocked {
|
|
6
|
-
margin-inline-end: calc(24px + var(--v-scrollbar-offset));
|
|
2
|
+
align-items: center;
|
|
3
|
+
justify-content: center;
|
|
4
|
+
margin: auto;
|
|
7
5
|
}
|
|
8
6
|
.v-dialog > .v-overlay__content {
|
|
9
|
-
max-height: 100
|
|
10
|
-
width: 100
|
|
11
|
-
max-width: 100
|
|
7
|
+
max-height: calc(100% - 48px);
|
|
8
|
+
width: calc(100% - 48px);
|
|
9
|
+
max-width: calc(100% - 48px);
|
|
10
|
+
margin: 24px;
|
|
12
11
|
display: flex;
|
|
13
12
|
flex-direction: column;
|
|
14
|
-
top: 50%;
|
|
15
|
-
left: 50%;
|
|
16
|
-
transform: translate(-50%, -50%);
|
|
17
13
|
}
|
|
18
14
|
.v-dialog > .v-overlay__content > .v-card,
|
|
19
15
|
.v-dialog > .v-overlay__content > .v-sheet {
|
|
@@ -39,12 +35,10 @@
|
|
|
39
35
|
padding: 16px 24px 10px;
|
|
40
36
|
}
|
|
41
37
|
|
|
42
|
-
.v-dialog
|
|
43
|
-
margin: 0;
|
|
44
|
-
margin-inline-end: 0;
|
|
38
|
+
.v-dialog--fullscreen {
|
|
45
39
|
--v-scrollbar-offset: 0px;
|
|
46
40
|
}
|
|
47
|
-
.v-dialog
|
|
41
|
+
.v-dialog--fullscreen > .v-overlay__content {
|
|
48
42
|
border-radius: 0;
|
|
49
43
|
margin: 0;
|
|
50
44
|
padding: 0;
|
|
@@ -55,10 +49,9 @@
|
|
|
55
49
|
overflow-y: auto;
|
|
56
50
|
top: 0;
|
|
57
51
|
left: 0;
|
|
58
|
-
transform: none;
|
|
59
52
|
}
|
|
60
|
-
.v-dialog
|
|
61
|
-
.v-dialog
|
|
53
|
+
.v-dialog--fullscreen > .v-overlay__content > .v-card,
|
|
54
|
+
.v-dialog--fullscreen > .v-overlay__content > .v-sheet {
|
|
62
55
|
min-height: 100%;
|
|
63
56
|
min-width: 100%;
|
|
64
57
|
border-radius: 0;
|
|
@@ -97,9 +97,9 @@ export const VDialog = genericComponent()({
|
|
|
97
97
|
}, overlayProps, {
|
|
98
98
|
"modelValue": isActive.value,
|
|
99
99
|
"onUpdate:modelValue": $event => isActive.value = $event,
|
|
100
|
-
"aria-role": "dialog",
|
|
101
100
|
"aria-modal": "true",
|
|
102
|
-
"activatorProps": activatorProps.value
|
|
101
|
+
"activatorProps": activatorProps.value,
|
|
102
|
+
"role": "dialog"
|
|
103
103
|
}, scopeId), {
|
|
104
104
|
activator: slots.activator,
|
|
105
105
|
default: function () {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VDialog.mjs","names":["VDialogTransition","VDefaultsProvider","VOverlay","useProxiedModel","useScopeId","forwardRefs","computed","mergeProps","nextTick","ref","watch","genericComponent","IN_BROWSER","useRender","makeVOverlayProps","VDialog","name","props","fullscreen","Boolean","retainFocus","type","default","scrollable","origin","scrollStrategy","transition","component","zIndex","emits","value","setup","slots","isActive","scopeId","overlay","onFocusin","e","before","relatedTarget","after","target","contentEl","globalTop","document","includes","contains","focusable","querySelectorAll","filter","el","hasAttribute","matches","length","firstElement","lastElement","focus","val","addEventListener","removeEventListener","immediate","preventScroll","activatorEl","activatorProps","String","overlayProps","filterProps","activator","args"],"sources":["../../../src/components/VDialog/VDialog.tsx"],"sourcesContent":["// Styles\nimport './VDialog.sass'\n\n// Components\nimport { VDialogTransition } from '@/components/transitions'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VOverlay } from '@/components/VOverlay'\n\n// Composables\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useScopeId } from '@/composables/scopeId'\nimport { forwardRefs } from '@/composables/forwardRefs'\n\n// Utilities\nimport { computed, mergeProps, nextTick, ref, watch } from 'vue'\nimport { genericComponent, IN_BROWSER, useRender } from '@/util'\nimport { makeVOverlayProps } from '@/components/VOverlay/VOverlay'\n\n// Types\nimport type { OverlaySlots } from '@/components/VOverlay/VOverlay'\n\nexport const VDialog = genericComponent<OverlaySlots>()({\n name: 'VDialog',\n\n props: {\n fullscreen: Boolean,\n retainFocus: {\n type: Boolean,\n default: true,\n },\n scrollable: Boolean,\n\n ...makeVOverlayProps({\n origin: 'center center' as const,\n scrollStrategy: 'block' as const,\n transition: { component: VDialogTransition },\n zIndex: 2400,\n }),\n },\n\n emits: {\n 'update:modelValue': (value: boolean) => true,\n },\n\n setup (props, { slots }) {\n const isActive = useProxiedModel(props, 'modelValue')\n const { scopeId } = useScopeId()\n\n const overlay = ref<VOverlay>()\n function onFocusin (e: FocusEvent) {\n const before = e.relatedTarget as HTMLElement | null\n const after = e.target as HTMLElement | null\n\n if (\n before !== after &&\n overlay.value?.contentEl &&\n // We're the topmost dialog\n overlay.value?.globalTop &&\n // It isn't the document or the dialog body\n ![document, overlay.value.contentEl].includes(after!) &&\n // It isn't inside the dialog body\n !overlay.value.contentEl.contains(after)\n ) {\n const focusable = [...overlay.value.contentEl.querySelectorAll(\n 'button, [href], input:not([type=\"hidden\"]), select, textarea, [tabindex]:not([tabindex=\"-1\"])'\n )].filter(el => !el.hasAttribute('disabled') && !el.matches('[tabindex=\"-1\"]')) as HTMLElement[]\n\n if (!focusable.length) return\n\n const firstElement = focusable[0]\n const lastElement = focusable[focusable.length - 1]\n\n if (before === firstElement) {\n lastElement.focus()\n } else {\n firstElement.focus()\n }\n }\n }\n\n if (IN_BROWSER) {\n watch(() => isActive.value && props.retainFocus, val => {\n val\n ? document.addEventListener('focusin', onFocusin)\n : document.removeEventListener('focusin', onFocusin)\n }, { immediate: true })\n }\n\n watch(isActive, async val => {\n await nextTick()\n if (val) {\n overlay.value!.contentEl?.focus({ preventScroll: true })\n } else {\n overlay.value!.activatorEl?.focus({ preventScroll: true })\n }\n })\n\n const activatorProps = computed(() =>\n mergeProps({\n 'aria-haspopup': 'dialog',\n 'aria-expanded': String(isActive.value),\n }, props.activatorProps)\n )\n\n useRender(() => {\n const [overlayProps] = VOverlay.filterProps(props)\n\n return (\n <VOverlay\n ref={ overlay }\n class={[\n 'v-dialog',\n {\n 'v-dialog--fullscreen': props.fullscreen,\n 'v-dialog--scrollable': props.scrollable,\n },\n ]}\n { ...overlayProps }\n v-model={ isActive.value }\n aria-
|
|
1
|
+
{"version":3,"file":"VDialog.mjs","names":["VDialogTransition","VDefaultsProvider","VOverlay","useProxiedModel","useScopeId","forwardRefs","computed","mergeProps","nextTick","ref","watch","genericComponent","IN_BROWSER","useRender","makeVOverlayProps","VDialog","name","props","fullscreen","Boolean","retainFocus","type","default","scrollable","origin","scrollStrategy","transition","component","zIndex","emits","value","setup","slots","isActive","scopeId","overlay","onFocusin","e","before","relatedTarget","after","target","contentEl","globalTop","document","includes","contains","focusable","querySelectorAll","filter","el","hasAttribute","matches","length","firstElement","lastElement","focus","val","addEventListener","removeEventListener","immediate","preventScroll","activatorEl","activatorProps","String","overlayProps","filterProps","activator","args"],"sources":["../../../src/components/VDialog/VDialog.tsx"],"sourcesContent":["// Styles\nimport './VDialog.sass'\n\n// Components\nimport { VDialogTransition } from '@/components/transitions'\nimport { VDefaultsProvider } from '@/components/VDefaultsProvider'\nimport { VOverlay } from '@/components/VOverlay'\n\n// Composables\nimport { useProxiedModel } from '@/composables/proxiedModel'\nimport { useScopeId } from '@/composables/scopeId'\nimport { forwardRefs } from '@/composables/forwardRefs'\n\n// Utilities\nimport { computed, mergeProps, nextTick, ref, watch } from 'vue'\nimport { genericComponent, IN_BROWSER, useRender } from '@/util'\nimport { makeVOverlayProps } from '@/components/VOverlay/VOverlay'\n\n// Types\nimport type { OverlaySlots } from '@/components/VOverlay/VOverlay'\n\nexport const VDialog = genericComponent<OverlaySlots>()({\n name: 'VDialog',\n\n props: {\n fullscreen: Boolean,\n retainFocus: {\n type: Boolean,\n default: true,\n },\n scrollable: Boolean,\n\n ...makeVOverlayProps({\n origin: 'center center' as const,\n scrollStrategy: 'block' as const,\n transition: { component: VDialogTransition },\n zIndex: 2400,\n }),\n },\n\n emits: {\n 'update:modelValue': (value: boolean) => true,\n },\n\n setup (props, { slots }) {\n const isActive = useProxiedModel(props, 'modelValue')\n const { scopeId } = useScopeId()\n\n const overlay = ref<VOverlay>()\n function onFocusin (e: FocusEvent) {\n const before = e.relatedTarget as HTMLElement | null\n const after = e.target as HTMLElement | null\n\n if (\n before !== after &&\n overlay.value?.contentEl &&\n // We're the topmost dialog\n overlay.value?.globalTop &&\n // It isn't the document or the dialog body\n ![document, overlay.value.contentEl].includes(after!) &&\n // It isn't inside the dialog body\n !overlay.value.contentEl.contains(after)\n ) {\n const focusable = [...overlay.value.contentEl.querySelectorAll(\n 'button, [href], input:not([type=\"hidden\"]), select, textarea, [tabindex]:not([tabindex=\"-1\"])'\n )].filter(el => !el.hasAttribute('disabled') && !el.matches('[tabindex=\"-1\"]')) as HTMLElement[]\n\n if (!focusable.length) return\n\n const firstElement = focusable[0]\n const lastElement = focusable[focusable.length - 1]\n\n if (before === firstElement) {\n lastElement.focus()\n } else {\n firstElement.focus()\n }\n }\n }\n\n if (IN_BROWSER) {\n watch(() => isActive.value && props.retainFocus, val => {\n val\n ? document.addEventListener('focusin', onFocusin)\n : document.removeEventListener('focusin', onFocusin)\n }, { immediate: true })\n }\n\n watch(isActive, async val => {\n await nextTick()\n if (val) {\n overlay.value!.contentEl?.focus({ preventScroll: true })\n } else {\n overlay.value!.activatorEl?.focus({ preventScroll: true })\n }\n })\n\n const activatorProps = computed(() =>\n mergeProps({\n 'aria-haspopup': 'dialog',\n 'aria-expanded': String(isActive.value),\n }, props.activatorProps)\n )\n\n useRender(() => {\n const [overlayProps] = VOverlay.filterProps(props)\n\n return (\n <VOverlay\n ref={ overlay }\n class={[\n 'v-dialog',\n {\n 'v-dialog--fullscreen': props.fullscreen,\n 'v-dialog--scrollable': props.scrollable,\n },\n ]}\n { ...overlayProps }\n v-model={ isActive.value }\n aria-modal=\"true\"\n activatorProps={ activatorProps.value }\n role=\"dialog\"\n { ...scopeId }\n >\n {{\n activator: slots.activator,\n default: (...args) => (\n <VDefaultsProvider root>\n { slots.default?.(...args) }\n </VDefaultsProvider>\n ),\n }}\n </VOverlay>\n )\n })\n\n return forwardRefs({}, overlay)\n },\n})\n\nexport type VDialog = InstanceType<typeof VDialog>\n"],"mappings":"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"}
|
|
@@ -3,21 +3,17 @@
|
|
|
3
3
|
|
|
4
4
|
// Block
|
|
5
5
|
.v-dialog
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
&.v-overlay--scroll-blocked
|
|
10
|
-
margin-inline-end: calc(#{$dialog-margin} + var(--v-scrollbar-offset))
|
|
6
|
+
align-items: center
|
|
7
|
+
justify-content: center
|
|
8
|
+
margin: auto
|
|
11
9
|
|
|
12
10
|
> .v-overlay__content
|
|
13
|
-
max-height: 100%
|
|
14
|
-
width: 100%
|
|
15
|
-
max-width: 100%
|
|
11
|
+
max-height: calc(100% - #{$dialog-margin * 2})
|
|
12
|
+
width: calc(100% - #{$dialog-margin * 2})
|
|
13
|
+
max-width: calc(100% - #{$dialog-margin * 2})
|
|
14
|
+
margin: $dialog-margin
|
|
16
15
|
display: flex
|
|
17
16
|
flex-direction: column
|
|
18
|
-
top: 50%
|
|
19
|
-
left: 50%
|
|
20
|
-
transform: translate(-50%, -50%)
|
|
21
17
|
|
|
22
18
|
> .v-card,
|
|
23
19
|
> .v-sheet
|
|
@@ -43,9 +39,7 @@
|
|
|
43
39
|
line-height: inherit
|
|
44
40
|
padding: $dialog-card-text-padding
|
|
45
41
|
|
|
46
|
-
.v-dialog
|
|
47
|
-
margin: 0
|
|
48
|
-
margin-inline-end: 0
|
|
42
|
+
.v-dialog--fullscreen
|
|
49
43
|
--v-scrollbar-offset: 0px
|
|
50
44
|
|
|
51
45
|
> .v-overlay__content
|
|
@@ -59,7 +53,6 @@
|
|
|
59
53
|
overflow-y: auto
|
|
60
54
|
top: 0
|
|
61
55
|
left: 0
|
|
62
|
-
transform: none
|
|
63
56
|
|
|
64
57
|
> .v-card,
|
|
65
58
|
> .v-sheet
|
|
@@ -214,7 +214,11 @@ export const VField = genericComponent()({
|
|
|
214
214
|
"key": "clear"
|
|
215
215
|
}, {
|
|
216
216
|
default: () => [_withDirectives(_createVNode("div", {
|
|
217
|
-
"class": "v-field__clearable"
|
|
217
|
+
"class": "v-field__clearable",
|
|
218
|
+
"onMousedown": e => {
|
|
219
|
+
e.preventDefault();
|
|
220
|
+
e.stopPropagation();
|
|
221
|
+
}
|
|
218
222
|
}, [slots.clear ? slots.clear() : _createVNode(InputIcon, {
|
|
219
223
|
"name": "clear"
|
|
220
224
|
}, null)]), [[_vShow, props.dirty]])]
|