vuetify 3.3.20 → 3.3.22
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 +222 -6
- package/dist/json/importMap.json +50 -50
- package/dist/json/tags.json +60 -3
- package/dist/json/web-types.json +977 -80
- package/dist/vuetify-labs.css +5608 -5595
- package/dist/vuetify-labs.d.ts +273 -67
- package/dist/vuetify-labs.esm.js +97 -29
- package/dist/vuetify-labs.esm.js.map +1 -1
- package/dist/vuetify-labs.js +97 -29
- package/dist/vuetify-labs.min.css +2 -2
- package/dist/vuetify.css +4408 -4399
- package/dist/vuetify.d.ts +16 -14
- package/dist/vuetify.esm.js +31 -5
- package/dist/vuetify.esm.js.map +1 -1
- package/dist/vuetify.js +31 -5
- package/dist/vuetify.js.map +1 -1
- package/dist/vuetify.min.css +2 -2
- package/dist/vuetify.min.js +798 -795
- package/dist/vuetify.min.js.map +1 -1
- package/lib/blueprints/index.d.mts +2 -0
- package/lib/blueprints/md1.d.mts +2 -0
- package/lib/blueprints/md2.d.mts +2 -0
- package/lib/blueprints/md3.d.mts +2 -0
- package/lib/components/VAutocomplete/VAutocomplete.css +1 -1
- package/lib/components/VAutocomplete/VAutocomplete.sass +2 -2
- package/lib/components/VAutocomplete/_variables.scss +1 -0
- package/lib/components/VCard/VCard.css +3 -1
- package/lib/components/VCard/VCard.sass +2 -1
- package/lib/components/VCard/_variables.scss +7 -5
- package/lib/components/VChip/VChip.css +67 -67
- package/lib/components/VChip/_variables.scss +1 -1
- package/lib/components/VColorPicker/VColorPickerCanvas.mjs +1 -0
- package/lib/components/VColorPicker/VColorPickerCanvas.mjs.map +1 -1
- package/lib/components/VCombobox/VCombobox.mjs +3 -3
- package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
- package/lib/components/VField/VField.css +3 -0
- package/lib/components/VField/VField.sass +3 -0
- package/lib/components/VField/_variables.scss +1 -0
- package/lib/components/VList/VListItem.css +0 -4
- package/lib/components/VList/VListItem.sass +0 -5
- package/lib/components/VNavigationDrawer/VNavigationDrawer.css +5 -0
- package/lib/components/VNavigationDrawer/VNavigationDrawer.sass +4 -0
- package/lib/components/VTable/VTable.css +3 -0
- package/lib/components/VTable/VTable.sass +3 -0
- package/lib/components/VToolbar/_variables.scss +6 -3
- package/lib/entry-bundler.mjs +1 -1
- package/lib/framework.mjs +1 -1
- package/lib/index.d.mts +16 -14
- package/lib/labs/VDataTable/VDataTable.css +0 -6
- package/lib/labs/VDataTable/VDataTable.sass +0 -1
- package/lib/labs/VDataTable/VDataTableFooter.mjs +12 -4
- package/lib/labs/VDataTable/VDataTableFooter.mjs.map +1 -1
- package/lib/labs/VDataTable/index.d.mts +48 -48
- package/lib/labs/VDatePicker/VDatePickerMonth.mjs +14 -2
- package/lib/labs/VDatePicker/VDatePickerMonth.mjs.map +1 -1
- package/lib/labs/VDatePicker/index.d.mts +18 -0
- package/lib/labs/VDateRangePicker/index.d.mts +12 -0
- package/lib/labs/VOtpInput/VOtpInput.css +3 -2
- package/lib/labs/VOtpInput/VOtpInput.mjs +7 -4
- package/lib/labs/VOtpInput/VOtpInput.mjs.map +1 -1
- package/lib/labs/VOtpInput/VOtpInput.sass +9 -8
- package/lib/labs/VOtpInput/_variables.scss +9 -0
- package/lib/labs/VStepper/VStepper.css +9 -0
- package/lib/labs/VStepper/VStepper.mjs +1 -2
- package/lib/labs/VStepper/VStepper.mjs.map +1 -1
- package/lib/labs/VStepper/VStepper.sass +17 -8
- package/lib/labs/VStepper/VStepperActions.mjs +34 -13
- package/lib/labs/VStepper/VStepperActions.mjs.map +1 -1
- package/lib/labs/VStepper/VStepperItem.mjs.map +1 -1
- package/lib/labs/VStepper/VStepperItem.sass +15 -15
- package/lib/labs/VStepper/_variables.scss +24 -1
- package/lib/labs/VStepper/index.d.mts +205 -19
- package/lib/labs/components.d.mts +271 -67
- package/lib/labs/date/DateAdapter.mjs.map +1 -1
- package/lib/labs/date/adapters/vuetify.d.mts +4 -0
- package/lib/labs/date/adapters/vuetify.mjs +18 -1
- package/lib/labs/date/adapters/vuetify.mjs.map +1 -1
- package/lib/labs/date/index.d.mts +4 -0
- package/lib/locale/de.mjs +20 -20
- package/lib/locale/de.mjs.map +1 -1
- package/lib/locale/nl.mjs +22 -22
- package/lib/locale/nl.mjs.map +1 -1
- package/lib/util/helpers.mjs +4 -0
- package/lib/util/helpers.mjs.map +1 -1
- package/package.json +2 -2
|
@@ -146,6 +146,8 @@ interface DateAdapter<T> {
|
|
|
146
146
|
date(value?: any): T | null;
|
|
147
147
|
format(date: T, formatString: string): string;
|
|
148
148
|
toJsDate(value: T): Date;
|
|
149
|
+
parseISO(date: string): T;
|
|
150
|
+
toISO(date: T): string;
|
|
149
151
|
startOfDay(date: T): T;
|
|
150
152
|
endOfDay(date: T): T;
|
|
151
153
|
startOfMonth(date: T): T;
|
package/lib/blueprints/md1.d.mts
CHANGED
|
@@ -146,6 +146,8 @@ interface DateAdapter<T> {
|
|
|
146
146
|
date(value?: any): T | null;
|
|
147
147
|
format(date: T, formatString: string): string;
|
|
148
148
|
toJsDate(value: T): Date;
|
|
149
|
+
parseISO(date: string): T;
|
|
150
|
+
toISO(date: T): string;
|
|
149
151
|
startOfDay(date: T): T;
|
|
150
152
|
endOfDay(date: T): T;
|
|
151
153
|
startOfMonth(date: T): T;
|
package/lib/blueprints/md2.d.mts
CHANGED
|
@@ -146,6 +146,8 @@ interface DateAdapter<T> {
|
|
|
146
146
|
date(value?: any): T | null;
|
|
147
147
|
format(date: T, formatString: string): string;
|
|
148
148
|
toJsDate(value: T): Date;
|
|
149
|
+
parseISO(date: string): T;
|
|
150
|
+
toISO(date: T): string;
|
|
149
151
|
startOfDay(date: T): T;
|
|
150
152
|
endOfDay(date: T): T;
|
|
151
153
|
startOfMonth(date: T): T;
|
package/lib/blueprints/md3.d.mts
CHANGED
|
@@ -146,6 +146,8 @@ interface DateAdapter<T> {
|
|
|
146
146
|
date(value?: any): T | null;
|
|
147
147
|
format(date: T, formatString: string): string;
|
|
148
148
|
toJsDate(value: T): Date;
|
|
149
|
+
parseISO(date: string): T;
|
|
150
|
+
toISO(date: T): string;
|
|
149
151
|
startOfDay(date: T): T;
|
|
150
152
|
endOfDay(date: T): T;
|
|
151
153
|
startOfMonth(date: T): T;
|
|
@@ -28,7 +28,7 @@
|
|
|
28
28
|
|
|
29
29
|
.v-field--dirty
|
|
30
30
|
.v-autocomplete__selection
|
|
31
|
-
margin-inline-end:
|
|
31
|
+
margin-inline-end: $autocomplete-selection-gap
|
|
32
32
|
|
|
33
33
|
.v-autocomplete__selection-text
|
|
34
34
|
overflow: hidden
|
|
@@ -50,7 +50,7 @@
|
|
|
50
50
|
align-items: center
|
|
51
51
|
letter-spacing: inherit
|
|
52
52
|
line-height: inherit
|
|
53
|
-
max-width:
|
|
53
|
+
max-width: calc(100% - $autocomplete-selection-gap)
|
|
54
54
|
|
|
55
55
|
&__selection
|
|
56
56
|
margin-top: var(--v-input-chips-margin-top)
|
|
@@ -5,6 +5,7 @@ $autocomplete-content-border-radius: 4px !default;
|
|
|
5
5
|
$autocomplete-content-elevation: 4 !default;
|
|
6
6
|
$autocomplete-focused-input: 64px !default;
|
|
7
7
|
$autocomplete-line-height: 1.75 !default;
|
|
8
|
+
$autocomplete-selection-gap: 2px !default;
|
|
8
9
|
$autocomplete-transition: .2s settings.$standard-easing !default;
|
|
9
10
|
$autocomplete-chips-control-min-height: 64px !default;
|
|
10
11
|
$autocomplete-chips-margin-top: 2px !default;
|
|
@@ -101,7 +101,6 @@
|
|
|
101
101
|
}
|
|
102
102
|
.v-card--hover {
|
|
103
103
|
cursor: pointer;
|
|
104
|
-
box-shadow: 0px 0px 0px 0px var(--v-shadow-key-umbra-opacity, rgba(0, 0, 0, 0.2)), 0px 0px 0px 0px var(--v-shadow-key-penumbra-opacity, rgba(0, 0, 0, 0.14)), 0px 0px 0px 0px var(--v-shadow-key-penumbra-opacity, rgba(0, 0, 0, 0.12));
|
|
105
104
|
}
|
|
106
105
|
.v-card--hover::before, .v-card--hover::after {
|
|
107
106
|
border-radius: inherit;
|
|
@@ -131,6 +130,9 @@
|
|
|
131
130
|
.v-card--hover:hover::before {
|
|
132
131
|
opacity: 0;
|
|
133
132
|
}
|
|
133
|
+
.v-card--hover:hover {
|
|
134
|
+
box-shadow: 0px 5px 5px -3px var(--v-shadow-key-umbra-opacity, rgba(0, 0, 0, 0.2)), 0px 8px 10px 1px var(--v-shadow-key-penumbra-opacity, rgba(0, 0, 0, 0.14)), 0px 3px 14px 2px var(--v-shadow-key-penumbra-opacity, rgba(0, 0, 0, 0.12));
|
|
135
|
+
}
|
|
134
136
|
.v-card--link {
|
|
135
137
|
cursor: pointer;
|
|
136
138
|
}
|
|
@@ -7,9 +7,6 @@ $card-actions-flex: none !default;
|
|
|
7
7
|
$card-actions-min-height: 52px !default;
|
|
8
8
|
$card-actions-padding: .5rem !default;
|
|
9
9
|
$card-append-padding-inline-start: 1rem !default;
|
|
10
|
-
$card-avatar-align-self: flex-start !default;
|
|
11
|
-
$card-avatar-header-padding: 0 !default;
|
|
12
|
-
$card-avatar-padding: .5rem 1rem !default;
|
|
13
10
|
$card-background: rgb(var(--v-theme-surface)) !default;
|
|
14
11
|
$card-border-color: settings.$border-color-root !default;
|
|
15
12
|
$card-border-radius: settings.$border-radius-root !default;
|
|
@@ -49,7 +46,6 @@ $card-title-letter-spacing: tools.map-deep-get(settings.$typography, 'h6', 'lett
|
|
|
49
46
|
$card-title-line-height: tools.map-deep-get(settings.$typography, 'h6', 'line-height') !default;
|
|
50
47
|
$card-title-overflow-wrap: normal !default;
|
|
51
48
|
$card-title-overflow: hidden !default;
|
|
52
|
-
$card-title-padding-top: 1rem !default;
|
|
53
49
|
$card-title-padding: .5rem 1rem !default;
|
|
54
50
|
$card-title-text-overflow: ellipsis !default;
|
|
55
51
|
$card-title-text-transform: none !default;
|
|
@@ -82,7 +78,6 @@ $card-text-font-size: tools.map-deep-get(settings.$typography, 'body-2', 'size')
|
|
|
82
78
|
$card-text-font-weight: tools.map-deep-get(settings.$typography, 'body-2', 'weight') !default;
|
|
83
79
|
$card-text-letter-spacing: tools.map-deep-get(settings.$typography, 'body-2', 'letter-spacing') !default;
|
|
84
80
|
$card-text-line-height: tools.map-deep-get(settings.$typography, 'body-2', 'line-height') !default;
|
|
85
|
-
$card-text-padding-bottom: 1rem !default;
|
|
86
81
|
$card-text-padding: 1rem !default;
|
|
87
82
|
$card-text-text-transform: tools.map-deep-get(settings.$typography, 'body-2', 'text-transform') !default;
|
|
88
83
|
|
|
@@ -122,3 +117,10 @@ $card-variants: (
|
|
|
122
117
|
$card-plain-opacity,
|
|
123
118
|
'v-card'
|
|
124
119
|
) !default;
|
|
120
|
+
|
|
121
|
+
// Deprecated
|
|
122
|
+
$card-avatar-align-self: flex-start !default;
|
|
123
|
+
$card-avatar-header-padding: 0 !default;
|
|
124
|
+
$card-avatar-padding: .5rem 1rem !default;
|
|
125
|
+
$card-title-padding-top: 1rem !default;
|
|
126
|
+
$card-text-padding-bottom: 1rem !default;
|
|
@@ -17,162 +17,162 @@
|
|
|
17
17
|
}
|
|
18
18
|
.v-chip.v-chip--size-x-small {
|
|
19
19
|
--v-chip-size: 0.625rem;
|
|
20
|
-
--v-chip-height:
|
|
20
|
+
--v-chip-height: 20px;
|
|
21
21
|
font-size: 0.625rem;
|
|
22
|
-
padding: 0
|
|
22
|
+
padding: 0 8px;
|
|
23
23
|
}
|
|
24
24
|
.v-chip.v-chip--size-x-small .v-avatar {
|
|
25
|
-
--v-avatar-height:
|
|
25
|
+
--v-avatar-height: 14px;
|
|
26
26
|
}
|
|
27
27
|
.v-chip--pill.v-chip.v-chip--size-x-small .v-avatar {
|
|
28
|
-
--v-avatar-height:
|
|
28
|
+
--v-avatar-height: 20px;
|
|
29
29
|
}
|
|
30
30
|
|
|
31
31
|
.v-chip.v-chip--size-x-small .v-avatar--start {
|
|
32
|
-
margin-inline-start: -
|
|
33
|
-
margin-inline-end:
|
|
32
|
+
margin-inline-start: -5.6px;
|
|
33
|
+
margin-inline-end: 4px;
|
|
34
34
|
}
|
|
35
35
|
.v-chip--pill.v-chip.v-chip--size-x-small .v-avatar--start {
|
|
36
|
-
margin-inline-start: -
|
|
36
|
+
margin-inline-start: -8px;
|
|
37
37
|
}
|
|
38
38
|
|
|
39
39
|
.v-chip.v-chip--size-x-small .v-avatar--end {
|
|
40
|
-
margin-inline-start:
|
|
41
|
-
margin-inline-end: -
|
|
40
|
+
margin-inline-start: 4px;
|
|
41
|
+
margin-inline-end: -5.6px;
|
|
42
42
|
}
|
|
43
43
|
.v-chip--pill.v-chip.v-chip--size-x-small .v-avatar--end {
|
|
44
|
-
margin-inline-end: -
|
|
44
|
+
margin-inline-end: -8px;
|
|
45
45
|
}
|
|
46
46
|
|
|
47
47
|
.v-chip--pill.v-chip.v-chip--size-x-small .v-avatar--end + .v-chip__close {
|
|
48
|
-
margin-inline-start:
|
|
48
|
+
margin-inline-start: 12px;
|
|
49
49
|
}
|
|
50
50
|
|
|
51
51
|
.v-chip.v-chip--size-x-small .v-icon--start,
|
|
52
52
|
.v-chip.v-chip--size-x-small .v-chip__filter {
|
|
53
|
-
margin-inline-start: -
|
|
54
|
-
margin-inline-end:
|
|
53
|
+
margin-inline-start: -4px;
|
|
54
|
+
margin-inline-end: 4px;
|
|
55
55
|
}
|
|
56
56
|
.v-chip.v-chip--size-x-small .v-icon--end,
|
|
57
57
|
.v-chip.v-chip--size-x-small .v-chip__close {
|
|
58
|
-
margin-inline-start:
|
|
59
|
-
margin-inline-end: -
|
|
58
|
+
margin-inline-start: 4px;
|
|
59
|
+
margin-inline-end: -4px;
|
|
60
60
|
}
|
|
61
61
|
.v-chip.v-chip--size-x-small .v-icon--end + .v-chip__close,
|
|
62
62
|
.v-chip.v-chip--size-x-small .v-avatar--end + .v-chip__close,
|
|
63
63
|
.v-chip.v-chip--size-x-small .v-chip__append + .v-chip__close {
|
|
64
|
-
margin-inline-start:
|
|
64
|
+
margin-inline-start: 8px;
|
|
65
65
|
}
|
|
66
66
|
|
|
67
67
|
.v-chip.v-chip--size-small {
|
|
68
68
|
--v-chip-size: 0.75rem;
|
|
69
|
-
--v-chip-height:
|
|
69
|
+
--v-chip-height: 26px;
|
|
70
70
|
font-size: 0.75rem;
|
|
71
|
-
padding: 0
|
|
71
|
+
padding: 0 10px;
|
|
72
72
|
}
|
|
73
73
|
.v-chip.v-chip--size-small .v-avatar {
|
|
74
|
-
--v-avatar-height:
|
|
74
|
+
--v-avatar-height: 20px;
|
|
75
75
|
}
|
|
76
76
|
.v-chip--pill.v-chip.v-chip--size-small .v-avatar {
|
|
77
|
-
--v-avatar-height:
|
|
77
|
+
--v-avatar-height: 26px;
|
|
78
78
|
}
|
|
79
79
|
|
|
80
80
|
.v-chip.v-chip--size-small .v-avatar--start {
|
|
81
|
-
margin-inline-start: -
|
|
82
|
-
margin-inline-end:
|
|
81
|
+
margin-inline-start: -7px;
|
|
82
|
+
margin-inline-end: 5px;
|
|
83
83
|
}
|
|
84
84
|
.v-chip--pill.v-chip.v-chip--size-small .v-avatar--start {
|
|
85
|
-
margin-inline-start: -
|
|
85
|
+
margin-inline-start: -10px;
|
|
86
86
|
}
|
|
87
87
|
|
|
88
88
|
.v-chip.v-chip--size-small .v-avatar--end {
|
|
89
|
-
margin-inline-start:
|
|
90
|
-
margin-inline-end: -
|
|
89
|
+
margin-inline-start: 5px;
|
|
90
|
+
margin-inline-end: -7px;
|
|
91
91
|
}
|
|
92
92
|
.v-chip--pill.v-chip.v-chip--size-small .v-avatar--end {
|
|
93
|
-
margin-inline-end: -
|
|
93
|
+
margin-inline-end: -10px;
|
|
94
94
|
}
|
|
95
95
|
|
|
96
96
|
.v-chip--pill.v-chip.v-chip--size-small .v-avatar--end + .v-chip__close {
|
|
97
|
-
margin-inline-start:
|
|
97
|
+
margin-inline-start: 15px;
|
|
98
98
|
}
|
|
99
99
|
|
|
100
100
|
.v-chip.v-chip--size-small .v-icon--start,
|
|
101
101
|
.v-chip.v-chip--size-small .v-chip__filter {
|
|
102
|
-
margin-inline-start: -
|
|
103
|
-
margin-inline-end:
|
|
102
|
+
margin-inline-start: -5px;
|
|
103
|
+
margin-inline-end: 5px;
|
|
104
104
|
}
|
|
105
105
|
.v-chip.v-chip--size-small .v-icon--end,
|
|
106
106
|
.v-chip.v-chip--size-small .v-chip__close {
|
|
107
|
-
margin-inline-start:
|
|
108
|
-
margin-inline-end: -
|
|
107
|
+
margin-inline-start: 5px;
|
|
108
|
+
margin-inline-end: -5px;
|
|
109
109
|
}
|
|
110
110
|
.v-chip.v-chip--size-small .v-icon--end + .v-chip__close,
|
|
111
111
|
.v-chip.v-chip--size-small .v-avatar--end + .v-chip__close,
|
|
112
112
|
.v-chip.v-chip--size-small .v-chip__append + .v-chip__close {
|
|
113
|
-
margin-inline-start:
|
|
113
|
+
margin-inline-start: 10px;
|
|
114
114
|
}
|
|
115
115
|
|
|
116
116
|
.v-chip.v-chip--size-default {
|
|
117
117
|
--v-chip-size: 0.875rem;
|
|
118
|
-
--v-chip-height:
|
|
118
|
+
--v-chip-height: 32px;
|
|
119
119
|
font-size: 0.875rem;
|
|
120
|
-
padding: 0
|
|
120
|
+
padding: 0 12px;
|
|
121
121
|
}
|
|
122
122
|
.v-chip.v-chip--size-default .v-avatar {
|
|
123
|
-
--v-avatar-height:
|
|
123
|
+
--v-avatar-height: 26px;
|
|
124
124
|
}
|
|
125
125
|
.v-chip--pill.v-chip.v-chip--size-default .v-avatar {
|
|
126
|
-
--v-avatar-height:
|
|
126
|
+
--v-avatar-height: 32px;
|
|
127
127
|
}
|
|
128
128
|
|
|
129
129
|
.v-chip.v-chip--size-default .v-avatar--start {
|
|
130
|
-
margin-inline-start: -
|
|
131
|
-
margin-inline-end:
|
|
130
|
+
margin-inline-start: -8.4px;
|
|
131
|
+
margin-inline-end: 6px;
|
|
132
132
|
}
|
|
133
133
|
.v-chip--pill.v-chip.v-chip--size-default .v-avatar--start {
|
|
134
|
-
margin-inline-start: -
|
|
134
|
+
margin-inline-start: -12px;
|
|
135
135
|
}
|
|
136
136
|
|
|
137
137
|
.v-chip.v-chip--size-default .v-avatar--end {
|
|
138
|
-
margin-inline-start:
|
|
139
|
-
margin-inline-end: -
|
|
138
|
+
margin-inline-start: 6px;
|
|
139
|
+
margin-inline-end: -8.4px;
|
|
140
140
|
}
|
|
141
141
|
.v-chip--pill.v-chip.v-chip--size-default .v-avatar--end {
|
|
142
|
-
margin-inline-end: -
|
|
142
|
+
margin-inline-end: -12px;
|
|
143
143
|
}
|
|
144
144
|
|
|
145
145
|
.v-chip--pill.v-chip.v-chip--size-default .v-avatar--end + .v-chip__close {
|
|
146
|
-
margin-inline-start:
|
|
146
|
+
margin-inline-start: 18px;
|
|
147
147
|
}
|
|
148
148
|
|
|
149
149
|
.v-chip.v-chip--size-default .v-icon--start,
|
|
150
150
|
.v-chip.v-chip--size-default .v-chip__filter {
|
|
151
|
-
margin-inline-start: -
|
|
152
|
-
margin-inline-end:
|
|
151
|
+
margin-inline-start: -6px;
|
|
152
|
+
margin-inline-end: 6px;
|
|
153
153
|
}
|
|
154
154
|
.v-chip.v-chip--size-default .v-icon--end,
|
|
155
155
|
.v-chip.v-chip--size-default .v-chip__close {
|
|
156
|
-
margin-inline-start:
|
|
157
|
-
margin-inline-end: -
|
|
156
|
+
margin-inline-start: 6px;
|
|
157
|
+
margin-inline-end: -6px;
|
|
158
158
|
}
|
|
159
159
|
.v-chip.v-chip--size-default .v-icon--end + .v-chip__close,
|
|
160
160
|
.v-chip.v-chip--size-default .v-avatar--end + .v-chip__close,
|
|
161
161
|
.v-chip.v-chip--size-default .v-chip__append + .v-chip__close {
|
|
162
|
-
margin-inline-start:
|
|
162
|
+
margin-inline-start: 12px;
|
|
163
163
|
}
|
|
164
164
|
|
|
165
165
|
.v-chip.v-chip--size-large {
|
|
166
166
|
--v-chip-size: 1rem;
|
|
167
|
-
--v-chip-height:
|
|
167
|
+
--v-chip-height: 38px;
|
|
168
168
|
font-size: 1rem;
|
|
169
169
|
padding: 0 14px;
|
|
170
170
|
}
|
|
171
171
|
.v-chip.v-chip--size-large .v-avatar {
|
|
172
|
-
--v-avatar-height:
|
|
172
|
+
--v-avatar-height: 32px;
|
|
173
173
|
}
|
|
174
174
|
.v-chip--pill.v-chip.v-chip--size-large .v-avatar {
|
|
175
|
-
--v-avatar-height:
|
|
175
|
+
--v-avatar-height: 38px;
|
|
176
176
|
}
|
|
177
177
|
|
|
178
178
|
.v-chip.v-chip--size-large .v-avatar--start {
|
|
@@ -213,51 +213,51 @@
|
|
|
213
213
|
|
|
214
214
|
.v-chip.v-chip--size-x-large {
|
|
215
215
|
--v-chip-size: 1.125rem;
|
|
216
|
-
--v-chip-height:
|
|
216
|
+
--v-chip-height: 44px;
|
|
217
217
|
font-size: 1.125rem;
|
|
218
|
-
padding: 0
|
|
218
|
+
padding: 0 17px;
|
|
219
219
|
}
|
|
220
220
|
.v-chip.v-chip--size-x-large .v-avatar {
|
|
221
|
-
--v-avatar-height:
|
|
221
|
+
--v-avatar-height: 38px;
|
|
222
222
|
}
|
|
223
223
|
.v-chip--pill.v-chip.v-chip--size-x-large .v-avatar {
|
|
224
|
-
--v-avatar-height:
|
|
224
|
+
--v-avatar-height: 44px;
|
|
225
225
|
}
|
|
226
226
|
|
|
227
227
|
.v-chip.v-chip--size-x-large .v-avatar--start {
|
|
228
|
-
margin-inline-start: -11.
|
|
229
|
-
margin-inline-end:
|
|
228
|
+
margin-inline-start: -11.9px;
|
|
229
|
+
margin-inline-end: 8.5px;
|
|
230
230
|
}
|
|
231
231
|
.v-chip--pill.v-chip.v-chip--size-x-large .v-avatar--start {
|
|
232
|
-
margin-inline-start: -
|
|
232
|
+
margin-inline-start: -17px;
|
|
233
233
|
}
|
|
234
234
|
|
|
235
235
|
.v-chip.v-chip--size-x-large .v-avatar--end {
|
|
236
|
-
margin-inline-start:
|
|
237
|
-
margin-inline-end: -11.
|
|
236
|
+
margin-inline-start: 8.5px;
|
|
237
|
+
margin-inline-end: -11.9px;
|
|
238
238
|
}
|
|
239
239
|
.v-chip--pill.v-chip.v-chip--size-x-large .v-avatar--end {
|
|
240
|
-
margin-inline-end: -
|
|
240
|
+
margin-inline-end: -17px;
|
|
241
241
|
}
|
|
242
242
|
|
|
243
243
|
.v-chip--pill.v-chip.v-chip--size-x-large .v-avatar--end + .v-chip__close {
|
|
244
|
-
margin-inline-start:
|
|
244
|
+
margin-inline-start: 25.5px;
|
|
245
245
|
}
|
|
246
246
|
|
|
247
247
|
.v-chip.v-chip--size-x-large .v-icon--start,
|
|
248
248
|
.v-chip.v-chip--size-x-large .v-chip__filter {
|
|
249
|
-
margin-inline-start: -
|
|
250
|
-
margin-inline-end:
|
|
249
|
+
margin-inline-start: -8.5px;
|
|
250
|
+
margin-inline-end: 8.5px;
|
|
251
251
|
}
|
|
252
252
|
.v-chip.v-chip--size-x-large .v-icon--end,
|
|
253
253
|
.v-chip.v-chip--size-x-large .v-chip__close {
|
|
254
|
-
margin-inline-start:
|
|
255
|
-
margin-inline-end: -
|
|
254
|
+
margin-inline-start: 8.5px;
|
|
255
|
+
margin-inline-end: -8.5px;
|
|
256
256
|
}
|
|
257
257
|
.v-chip.v-chip--size-x-large .v-icon--end + .v-chip__close,
|
|
258
258
|
.v-chip.v-chip--size-x-large .v-avatar--end + .v-chip__close,
|
|
259
259
|
.v-chip.v-chip--size-x-large .v-chip__append + .v-chip__close {
|
|
260
|
-
margin-inline-start:
|
|
260
|
+
margin-inline-start: 17px;
|
|
261
261
|
}
|
|
262
262
|
|
|
263
263
|
.v-chip.v-chip--density-default {
|
|
@@ -17,7 +17,7 @@ $chip-disabled-opacity: 0.3 !default;
|
|
|
17
17
|
$chip-elevation: 1 !default;
|
|
18
18
|
$chip-font-size: tools.map-deep-get(settings.$typography, "button", "size") !default;
|
|
19
19
|
$chip-font-weight: 400 !default;
|
|
20
|
-
$chip-height:
|
|
20
|
+
$chip-height: 32px !default;
|
|
21
21
|
$chip-icon-font-size: 1.25rem !default;
|
|
22
22
|
$chip-label-border-radius: settings.$border-radius-root !default;
|
|
23
23
|
$chip-max-width: 100% !default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VColorPickerCanvas.mjs","names":["makeComponentProps","useResizeObserver","computed","onMounted","ref","shallowRef","watch","clamp","convertToUnit","defineComponent","getEventCoordinates","propsFactory","useRender","makeVColorPickerCanvasProps","color","type","Object","disabled","Boolean","dotSize","Number","String","default","height","width","VColorPickerCanvas","name","props","emits","hue","setup","_ref","emit","isInteracting","canvasRef","canvasWidth","parseFloat","canvasHeight","_dotPosition","x","y","dotPosition","get","value","set","val","h","s","v","a","dotStyles","radius","parseInt","transform","resizeRef","entries","offsetParent","contentRect","updateDotPosition","rect","left","top","handleMouseDown","e","preventDefault","handleMouseMove","window","addEventListener","handleMouseUp","coords","clientX","clientY","getBoundingClientRect","removeEventListener","updateCanvas","canvas","ctx","getContext","saturationGradient","createLinearGradient","addColorStop","fillStyle","fillRect","valueGradient","immediate","newVal","oldVal","flush","deep","_createVNode","class","style"],"sources":["../../../src/components/VColorPicker/VColorPickerCanvas.tsx"],"sourcesContent":["// Styles\nimport './VColorPickerCanvas.sass'\n\n// Composables\nimport { makeComponentProps } from '@/composables/component'\nimport { useResizeObserver } from '@/composables/resizeObserver'\n\n// Utilities\nimport { computed, onMounted, ref, shallowRef, watch } from 'vue'\nimport { clamp, convertToUnit, defineComponent, getEventCoordinates, propsFactory, useRender } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { HSV } from '@/util'\n\nexport const makeVColorPickerCanvasProps = propsFactory({\n color: {\n type: Object as PropType<HSV | null>,\n },\n disabled: Boolean,\n dotSize: {\n type: [Number, String],\n default: 10,\n },\n height: {\n type: [Number, String],\n default: 150,\n },\n width: {\n type: [Number, String],\n default: 300,\n },\n\n ...makeComponentProps(),\n}, 'VColorPickerCanvas')\n\nexport const VColorPickerCanvas = defineComponent({\n name: 'VColorPickerCanvas',\n\n props: makeVColorPickerCanvasProps(),\n\n emits: {\n 'update:color': (color: HSV) => true,\n 'update:position': (hue: any) => true,\n },\n\n setup (props, { emit }) {\n const isInteracting = shallowRef(false)\n const canvasRef = ref<HTMLCanvasElement | null>()\n const canvasWidth = shallowRef(parseFloat(props.width))\n const canvasHeight = shallowRef(parseFloat(props.height))\n\n const _dotPosition = ref({ x: 0, y: 0 })\n const dotPosition = computed({\n get: () => _dotPosition.value,\n set (val) {\n if (!canvasRef.value) return\n\n const { x, y } = val\n\n emit('update:color', {\n h: props.color?.h ?? 0,\n s: clamp(x, 0, canvasWidth.value) / canvasWidth.value,\n v: 1 - clamp(y, 0, canvasHeight.value) / canvasHeight.value,\n a: props.color?.a ?? 1,\n })\n },\n })\n\n const dotStyles = computed(() => {\n const { x, y } = dotPosition.value\n const radius = parseInt(props.dotSize, 10) / 2\n\n return {\n width: convertToUnit(props.dotSize),\n height: convertToUnit(props.dotSize),\n transform: `translate(${convertToUnit(x - radius)}, ${convertToUnit(y - radius)})`,\n }\n })\n\n const { resizeRef } = useResizeObserver(entries => {\n if (!resizeRef.value?.offsetParent) return\n\n const { width, height } = entries[0].contentRect\n\n canvasWidth.value = width\n canvasHeight.value = height\n })\n\n function updateDotPosition (x: number, y: number, rect: DOMRect) {\n const { left, top, width, height } = rect\n dotPosition.value = {\n x: clamp(x - left, 0, width),\n y: clamp(y - top, 0, height),\n }\n }\n\n function handleMouseDown (e: MouseEvent | TouchEvent) {\n if (e.type === 'mousedown') {\n // Prevent text selection while dragging\n e.preventDefault()\n }\n\n if (props.disabled) return\n\n handleMouseMove(e)\n\n window.addEventListener('mousemove', handleMouseMove)\n window.addEventListener('mouseup', handleMouseUp)\n window.addEventListener('touchmove', handleMouseMove)\n window.addEventListener('touchend', handleMouseUp)\n }\n\n function handleMouseMove (e: MouseEvent | TouchEvent) {\n if (props.disabled || !canvasRef.value) return\n\n isInteracting.value = true\n\n const coords = getEventCoordinates(e)\n\n updateDotPosition(coords.clientX, coords.clientY, canvasRef.value.getBoundingClientRect())\n }\n\n function handleMouseUp () {\n window.removeEventListener('mousemove', handleMouseMove)\n window.removeEventListener('mouseup', handleMouseUp)\n window.removeEventListener('touchmove', handleMouseMove)\n window.removeEventListener('touchend', handleMouseUp)\n }\n\n function updateCanvas () {\n if (!canvasRef.value) return\n\n const canvas = canvasRef.value\n const ctx = canvas.getContext('2d')\n\n if (!ctx) return\n\n const saturationGradient = ctx.createLinearGradient(0, 0, canvas.width, 0)\n saturationGradient.addColorStop(0, 'hsla(0, 0%, 100%, 1)') // white\n saturationGradient.addColorStop(1, `hsla(${props.color?.h ?? 0}, 100%, 50%, 1)`)\n ctx.fillStyle = saturationGradient\n ctx.fillRect(0, 0, canvas.width, canvas.height)\n\n const valueGradient = ctx.createLinearGradient(0, 0, 0, canvas.height)\n valueGradient.addColorStop(0, 'hsla(0, 0%, 100%, 0)') // transparent\n valueGradient.addColorStop(1, 'hsla(0, 0%, 0%, 1)') // black\n ctx.fillStyle = valueGradient\n ctx.fillRect(0, 0, canvas.width, canvas.height)\n }\n\n watch(() => props.color?.h, updateCanvas, { immediate: true })\n watch(() => [canvasWidth.value, canvasHeight.value], (newVal, oldVal) => {\n updateCanvas()\n _dotPosition.value = {\n x: dotPosition.value.x * newVal[0] / oldVal[0],\n y: dotPosition.value.y * newVal[1] / oldVal[1],\n }\n }, { flush: 'post' })\n\n watch(() => props.color, () => {\n if (isInteracting.value) {\n isInteracting.value = false\n return\n }\n\n _dotPosition.value = props.color ? {\n x: props.color.s * canvasWidth.value,\n y: (1 - props.color.v) * canvasHeight.value,\n } : { x: 0, y: 0 }\n }, { deep: true, immediate: true })\n\n onMounted(() => updateCanvas())\n\n useRender(() => (\n <div\n ref={ resizeRef }\n class={[\n 'v-color-picker-canvas',\n props.class,\n ]}\n style={ props.style }\n onMousedown={ handleMouseDown }\n onTouchstartPassive={ handleMouseDown }\n >\n <canvas\n ref={ canvasRef }\n width={ canvasWidth.value }\n height={ canvasHeight.value }\n />\n { props.color && (\n <div\n class={[\n 'v-color-picker-canvas__dot',\n {\n 'v-color-picker-canvas__dot--disabled': props.disabled,\n },\n ]}\n style={ dotStyles.value }\n />\n )}\n </div>\n ))\n\n return {}\n },\n})\n\nexport type VColorPickerCanvas = InstanceType<typeof VColorPickerCanvas>\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"VColorPickerCanvas.mjs","names":["makeComponentProps","useResizeObserver","computed","onMounted","ref","shallowRef","watch","clamp","convertToUnit","defineComponent","getEventCoordinates","propsFactory","useRender","makeVColorPickerCanvasProps","color","type","Object","disabled","Boolean","dotSize","Number","String","default","height","width","VColorPickerCanvas","name","props","emits","hue","setup","_ref","emit","isInteracting","canvasRef","canvasWidth","parseFloat","canvasHeight","_dotPosition","x","y","dotPosition","get","value","set","val","h","s","v","a","dotStyles","radius","parseInt","transform","resizeRef","entries","offsetParent","contentRect","updateDotPosition","rect","left","top","handleMouseDown","e","preventDefault","handleMouseMove","window","addEventListener","handleMouseUp","coords","clientX","clientY","getBoundingClientRect","removeEventListener","updateCanvas","canvas","ctx","getContext","saturationGradient","createLinearGradient","addColorStop","fillStyle","fillRect","valueGradient","immediate","newVal","oldVal","flush","deep","_createVNode","class","style"],"sources":["../../../src/components/VColorPicker/VColorPickerCanvas.tsx"],"sourcesContent":["// Styles\nimport './VColorPickerCanvas.sass'\n\n// Composables\nimport { makeComponentProps } from '@/composables/component'\nimport { useResizeObserver } from '@/composables/resizeObserver'\n\n// Utilities\nimport { computed, onMounted, ref, shallowRef, watch } from 'vue'\nimport { clamp, convertToUnit, defineComponent, getEventCoordinates, propsFactory, useRender } from '@/util'\n\n// Types\nimport type { PropType } from 'vue'\nimport type { HSV } from '@/util'\n\nexport const makeVColorPickerCanvasProps = propsFactory({\n color: {\n type: Object as PropType<HSV | null>,\n },\n disabled: Boolean,\n dotSize: {\n type: [Number, String],\n default: 10,\n },\n height: {\n type: [Number, String],\n default: 150,\n },\n width: {\n type: [Number, String],\n default: 300,\n },\n\n ...makeComponentProps(),\n}, 'VColorPickerCanvas')\n\nexport const VColorPickerCanvas = defineComponent({\n name: 'VColorPickerCanvas',\n\n props: makeVColorPickerCanvasProps(),\n\n emits: {\n 'update:color': (color: HSV) => true,\n 'update:position': (hue: any) => true,\n },\n\n setup (props, { emit }) {\n const isInteracting = shallowRef(false)\n const canvasRef = ref<HTMLCanvasElement | null>()\n const canvasWidth = shallowRef(parseFloat(props.width))\n const canvasHeight = shallowRef(parseFloat(props.height))\n\n const _dotPosition = ref({ x: 0, y: 0 })\n const dotPosition = computed({\n get: () => _dotPosition.value,\n set (val) {\n if (!canvasRef.value) return\n\n const { x, y } = val\n _dotPosition.value = val\n\n emit('update:color', {\n h: props.color?.h ?? 0,\n s: clamp(x, 0, canvasWidth.value) / canvasWidth.value,\n v: 1 - clamp(y, 0, canvasHeight.value) / canvasHeight.value,\n a: props.color?.a ?? 1,\n })\n },\n })\n\n const dotStyles = computed(() => {\n const { x, y } = dotPosition.value\n const radius = parseInt(props.dotSize, 10) / 2\n\n return {\n width: convertToUnit(props.dotSize),\n height: convertToUnit(props.dotSize),\n transform: `translate(${convertToUnit(x - radius)}, ${convertToUnit(y - radius)})`,\n }\n })\n\n const { resizeRef } = useResizeObserver(entries => {\n if (!resizeRef.value?.offsetParent) return\n\n const { width, height } = entries[0].contentRect\n\n canvasWidth.value = width\n canvasHeight.value = height\n })\n\n function updateDotPosition (x: number, y: number, rect: DOMRect) {\n const { left, top, width, height } = rect\n dotPosition.value = {\n x: clamp(x - left, 0, width),\n y: clamp(y - top, 0, height),\n }\n }\n\n function handleMouseDown (e: MouseEvent | TouchEvent) {\n if (e.type === 'mousedown') {\n // Prevent text selection while dragging\n e.preventDefault()\n }\n\n if (props.disabled) return\n\n handleMouseMove(e)\n\n window.addEventListener('mousemove', handleMouseMove)\n window.addEventListener('mouseup', handleMouseUp)\n window.addEventListener('touchmove', handleMouseMove)\n window.addEventListener('touchend', handleMouseUp)\n }\n\n function handleMouseMove (e: MouseEvent | TouchEvent) {\n if (props.disabled || !canvasRef.value) return\n\n isInteracting.value = true\n\n const coords = getEventCoordinates(e)\n\n updateDotPosition(coords.clientX, coords.clientY, canvasRef.value.getBoundingClientRect())\n }\n\n function handleMouseUp () {\n window.removeEventListener('mousemove', handleMouseMove)\n window.removeEventListener('mouseup', handleMouseUp)\n window.removeEventListener('touchmove', handleMouseMove)\n window.removeEventListener('touchend', handleMouseUp)\n }\n\n function updateCanvas () {\n if (!canvasRef.value) return\n\n const canvas = canvasRef.value\n const ctx = canvas.getContext('2d')\n\n if (!ctx) return\n\n const saturationGradient = ctx.createLinearGradient(0, 0, canvas.width, 0)\n saturationGradient.addColorStop(0, 'hsla(0, 0%, 100%, 1)') // white\n saturationGradient.addColorStop(1, `hsla(${props.color?.h ?? 0}, 100%, 50%, 1)`)\n ctx.fillStyle = saturationGradient\n ctx.fillRect(0, 0, canvas.width, canvas.height)\n\n const valueGradient = ctx.createLinearGradient(0, 0, 0, canvas.height)\n valueGradient.addColorStop(0, 'hsla(0, 0%, 100%, 0)') // transparent\n valueGradient.addColorStop(1, 'hsla(0, 0%, 0%, 1)') // black\n ctx.fillStyle = valueGradient\n ctx.fillRect(0, 0, canvas.width, canvas.height)\n }\n\n watch(() => props.color?.h, updateCanvas, { immediate: true })\n watch(() => [canvasWidth.value, canvasHeight.value], (newVal, oldVal) => {\n updateCanvas()\n _dotPosition.value = {\n x: dotPosition.value.x * newVal[0] / oldVal[0],\n y: dotPosition.value.y * newVal[1] / oldVal[1],\n }\n }, { flush: 'post' })\n\n watch(() => props.color, () => {\n if (isInteracting.value) {\n isInteracting.value = false\n return\n }\n\n _dotPosition.value = props.color ? {\n x: props.color.s * canvasWidth.value,\n y: (1 - props.color.v) * canvasHeight.value,\n } : { x: 0, y: 0 }\n }, { deep: true, immediate: true })\n\n onMounted(() => updateCanvas())\n\n useRender(() => (\n <div\n ref={ resizeRef }\n class={[\n 'v-color-picker-canvas',\n props.class,\n ]}\n style={ props.style }\n onMousedown={ handleMouseDown }\n onTouchstartPassive={ handleMouseDown }\n >\n <canvas\n ref={ canvasRef }\n width={ canvasWidth.value }\n height={ canvasHeight.value }\n />\n { props.color && (\n <div\n class={[\n 'v-color-picker-canvas__dot',\n {\n 'v-color-picker-canvas__dot--disabled': props.disabled,\n },\n ]}\n style={ dotStyles.value }\n />\n )}\n </div>\n ))\n\n return {}\n },\n})\n\nexport type VColorPickerCanvas = InstanceType<typeof VColorPickerCanvas>\n"],"mappings":"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"}
|
|
@@ -23,7 +23,7 @@ import { useLocale } from "../../composables/locale.mjs";
|
|
|
23
23
|
import { useProxiedModel } from "../../composables/proxiedModel.mjs";
|
|
24
24
|
import { makeTransitionProps } from "../../composables/transition.mjs"; // Utilities
|
|
25
25
|
import { computed, mergeProps, nextTick, ref, shallowRef, watch } from 'vue';
|
|
26
|
-
import { genericComponent, IN_BROWSER, noop, omit, propsFactory, useRender, wrapInArray } from "../../util/index.mjs"; // Types
|
|
26
|
+
import { genericComponent, IN_BROWSER, isComposingIgnoreKey, noop, omit, propsFactory, useRender, wrapInArray } from "../../util/index.mjs"; // Types
|
|
27
27
|
function highlightResult(text, matches, length) {
|
|
28
28
|
if (matches == null) return text;
|
|
29
29
|
if (Array.isArray(matches)) throw new Error('Multiple matches is not implemented');
|
|
@@ -110,7 +110,7 @@ export const VCombobox = genericComponent()({
|
|
|
110
110
|
return _search.value;
|
|
111
111
|
},
|
|
112
112
|
set: val => {
|
|
113
|
-
_search.value = val;
|
|
113
|
+
_search.value = val ?? '';
|
|
114
114
|
if (!props.multiple) {
|
|
115
115
|
model.value = [transformItem(props, val)];
|
|
116
116
|
}
|
|
@@ -183,7 +183,7 @@ export const VCombobox = genericComponent()({
|
|
|
183
183
|
menu.value = !menu.value;
|
|
184
184
|
}
|
|
185
185
|
function onKeydown(e) {
|
|
186
|
-
if (props.readonly || form?.isReadonly.value) return;
|
|
186
|
+
if (isComposingIgnoreKey(e) || props.readonly || form?.isReadonly.value) return;
|
|
187
187
|
const selectionStart = vTextFieldRef.value.selectionStart;
|
|
188
188
|
const length = model.value.length;
|
|
189
189
|
if (selectionIndex.value > -1 || ['Enter', 'ArrowDown', 'ArrowUp'].includes(e.key)) {
|