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.
Files changed (85) hide show
  1. package/dist/json/attributes.json +222 -6
  2. package/dist/json/importMap.json +50 -50
  3. package/dist/json/tags.json +60 -3
  4. package/dist/json/web-types.json +977 -80
  5. package/dist/vuetify-labs.css +5608 -5595
  6. package/dist/vuetify-labs.d.ts +273 -67
  7. package/dist/vuetify-labs.esm.js +97 -29
  8. package/dist/vuetify-labs.esm.js.map +1 -1
  9. package/dist/vuetify-labs.js +97 -29
  10. package/dist/vuetify-labs.min.css +2 -2
  11. package/dist/vuetify.css +4408 -4399
  12. package/dist/vuetify.d.ts +16 -14
  13. package/dist/vuetify.esm.js +31 -5
  14. package/dist/vuetify.esm.js.map +1 -1
  15. package/dist/vuetify.js +31 -5
  16. package/dist/vuetify.js.map +1 -1
  17. package/dist/vuetify.min.css +2 -2
  18. package/dist/vuetify.min.js +798 -795
  19. package/dist/vuetify.min.js.map +1 -1
  20. package/lib/blueprints/index.d.mts +2 -0
  21. package/lib/blueprints/md1.d.mts +2 -0
  22. package/lib/blueprints/md2.d.mts +2 -0
  23. package/lib/blueprints/md3.d.mts +2 -0
  24. package/lib/components/VAutocomplete/VAutocomplete.css +1 -1
  25. package/lib/components/VAutocomplete/VAutocomplete.sass +2 -2
  26. package/lib/components/VAutocomplete/_variables.scss +1 -0
  27. package/lib/components/VCard/VCard.css +3 -1
  28. package/lib/components/VCard/VCard.sass +2 -1
  29. package/lib/components/VCard/_variables.scss +7 -5
  30. package/lib/components/VChip/VChip.css +67 -67
  31. package/lib/components/VChip/_variables.scss +1 -1
  32. package/lib/components/VColorPicker/VColorPickerCanvas.mjs +1 -0
  33. package/lib/components/VColorPicker/VColorPickerCanvas.mjs.map +1 -1
  34. package/lib/components/VCombobox/VCombobox.mjs +3 -3
  35. package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
  36. package/lib/components/VField/VField.css +3 -0
  37. package/lib/components/VField/VField.sass +3 -0
  38. package/lib/components/VField/_variables.scss +1 -0
  39. package/lib/components/VList/VListItem.css +0 -4
  40. package/lib/components/VList/VListItem.sass +0 -5
  41. package/lib/components/VNavigationDrawer/VNavigationDrawer.css +5 -0
  42. package/lib/components/VNavigationDrawer/VNavigationDrawer.sass +4 -0
  43. package/lib/components/VTable/VTable.css +3 -0
  44. package/lib/components/VTable/VTable.sass +3 -0
  45. package/lib/components/VToolbar/_variables.scss +6 -3
  46. package/lib/entry-bundler.mjs +1 -1
  47. package/lib/framework.mjs +1 -1
  48. package/lib/index.d.mts +16 -14
  49. package/lib/labs/VDataTable/VDataTable.css +0 -6
  50. package/lib/labs/VDataTable/VDataTable.sass +0 -1
  51. package/lib/labs/VDataTable/VDataTableFooter.mjs +12 -4
  52. package/lib/labs/VDataTable/VDataTableFooter.mjs.map +1 -1
  53. package/lib/labs/VDataTable/index.d.mts +48 -48
  54. package/lib/labs/VDatePicker/VDatePickerMonth.mjs +14 -2
  55. package/lib/labs/VDatePicker/VDatePickerMonth.mjs.map +1 -1
  56. package/lib/labs/VDatePicker/index.d.mts +18 -0
  57. package/lib/labs/VDateRangePicker/index.d.mts +12 -0
  58. package/lib/labs/VOtpInput/VOtpInput.css +3 -2
  59. package/lib/labs/VOtpInput/VOtpInput.mjs +7 -4
  60. package/lib/labs/VOtpInput/VOtpInput.mjs.map +1 -1
  61. package/lib/labs/VOtpInput/VOtpInput.sass +9 -8
  62. package/lib/labs/VOtpInput/_variables.scss +9 -0
  63. package/lib/labs/VStepper/VStepper.css +9 -0
  64. package/lib/labs/VStepper/VStepper.mjs +1 -2
  65. package/lib/labs/VStepper/VStepper.mjs.map +1 -1
  66. package/lib/labs/VStepper/VStepper.sass +17 -8
  67. package/lib/labs/VStepper/VStepperActions.mjs +34 -13
  68. package/lib/labs/VStepper/VStepperActions.mjs.map +1 -1
  69. package/lib/labs/VStepper/VStepperItem.mjs.map +1 -1
  70. package/lib/labs/VStepper/VStepperItem.sass +15 -15
  71. package/lib/labs/VStepper/_variables.scss +24 -1
  72. package/lib/labs/VStepper/index.d.mts +205 -19
  73. package/lib/labs/components.d.mts +271 -67
  74. package/lib/labs/date/DateAdapter.mjs.map +1 -1
  75. package/lib/labs/date/adapters/vuetify.d.mts +4 -0
  76. package/lib/labs/date/adapters/vuetify.mjs +18 -1
  77. package/lib/labs/date/adapters/vuetify.mjs.map +1 -1
  78. package/lib/labs/date/index.d.mts +4 -0
  79. package/lib/locale/de.mjs +20 -20
  80. package/lib/locale/de.mjs.map +1 -1
  81. package/lib/locale/nl.mjs +22 -22
  82. package/lib/locale/nl.mjs.map +1 -1
  83. package/lib/util/helpers.mjs +4 -0
  84. package/lib/util/helpers.mjs.map +1 -1
  85. 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;
@@ -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;
@@ -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;
@@ -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;
@@ -35,7 +35,7 @@
35
35
  align-items: center;
36
36
  letter-spacing: inherit;
37
37
  line-height: inherit;
38
- max-width: 90%;
38
+ max-width: calc(100% - 2px);
39
39
  }
40
40
  .v-autocomplete__selection {
41
41
  margin-top: var(--v-input-chips-margin-top);
@@ -28,7 +28,7 @@
28
28
 
29
29
  .v-field--dirty
30
30
  .v-autocomplete__selection
31
- margin-inline-end: 2px
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: 90%
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
  }
@@ -64,7 +64,8 @@
64
64
  &:hover::before
65
65
  opacity: 0
66
66
 
67
- @include tools.elevation(0)
67
+ &:hover
68
+ @include tools.elevation($card-hover-elevation)
68
69
 
69
70
  &--link
70
71
  cursor: pointer
@@ -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: 18px;
20
+ --v-chip-height: 20px;
21
21
  font-size: 0.625rem;
22
- padding: 0 7px;
22
+ padding: 0 8px;
23
23
  }
24
24
  .v-chip.v-chip--size-x-small .v-avatar {
25
- --v-avatar-height: 12px;
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: 18px;
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: -4.9px;
33
- margin-inline-end: 3.5px;
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: -7px;
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: 3.5px;
41
- margin-inline-end: -4.9px;
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: -7px;
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: 10.5px;
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: -3.5px;
54
- margin-inline-end: 3.5px;
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: 3.5px;
59
- margin-inline-end: -3.5px;
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: 7px;
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: 24px;
69
+ --v-chip-height: 26px;
70
70
  font-size: 0.75rem;
71
- padding: 0 9px;
71
+ padding: 0 10px;
72
72
  }
73
73
  .v-chip.v-chip--size-small .v-avatar {
74
- --v-avatar-height: 18px;
74
+ --v-avatar-height: 20px;
75
75
  }
76
76
  .v-chip--pill.v-chip.v-chip--size-small .v-avatar {
77
- --v-avatar-height: 24px;
77
+ --v-avatar-height: 26px;
78
78
  }
79
79
 
80
80
  .v-chip.v-chip--size-small .v-avatar--start {
81
- margin-inline-start: -6.3px;
82
- margin-inline-end: 4.5px;
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: -9px;
85
+ margin-inline-start: -10px;
86
86
  }
87
87
 
88
88
  .v-chip.v-chip--size-small .v-avatar--end {
89
- margin-inline-start: 4.5px;
90
- margin-inline-end: -6.3px;
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: -9px;
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: 13.5px;
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: -4.5px;
103
- margin-inline-end: 4.5px;
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: 4.5px;
108
- margin-inline-end: -4.5px;
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: 9px;
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: 30px;
118
+ --v-chip-height: 32px;
119
119
  font-size: 0.875rem;
120
- padding: 0 11px;
120
+ padding: 0 12px;
121
121
  }
122
122
  .v-chip.v-chip--size-default .v-avatar {
123
- --v-avatar-height: 24px;
123
+ --v-avatar-height: 26px;
124
124
  }
125
125
  .v-chip--pill.v-chip.v-chip--size-default .v-avatar {
126
- --v-avatar-height: 30px;
126
+ --v-avatar-height: 32px;
127
127
  }
128
128
 
129
129
  .v-chip.v-chip--size-default .v-avatar--start {
130
- margin-inline-start: -7.7px;
131
- margin-inline-end: 5.5px;
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: -11px;
134
+ margin-inline-start: -12px;
135
135
  }
136
136
 
137
137
  .v-chip.v-chip--size-default .v-avatar--end {
138
- margin-inline-start: 5.5px;
139
- margin-inline-end: -7.7px;
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: -11px;
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: 16.5px;
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: -5.5px;
152
- margin-inline-end: 5.5px;
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: 5.5px;
157
- margin-inline-end: -5.5px;
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: 11px;
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: 36px;
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: 30px;
172
+ --v-avatar-height: 32px;
173
173
  }
174
174
  .v-chip--pill.v-chip.v-chip--size-large .v-avatar {
175
- --v-avatar-height: 36px;
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: 42px;
216
+ --v-chip-height: 44px;
217
217
  font-size: 1.125rem;
218
- padding: 0 16px;
218
+ padding: 0 17px;
219
219
  }
220
220
  .v-chip.v-chip--size-x-large .v-avatar {
221
- --v-avatar-height: 36px;
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: 42px;
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.2px;
229
- margin-inline-end: 8px;
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: -16px;
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: 8px;
237
- margin-inline-end: -11.2px;
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: -16px;
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: 24px;
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: -8px;
250
- margin-inline-end: 8px;
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: 8px;
255
- margin-inline-end: -8px;
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: 16px;
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: 30px !default;
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;
@@ -53,6 +53,7 @@ export const VColorPickerCanvas = defineComponent({
53
53
  x,
54
54
  y
55
55
  } = val;
56
+ _dotPosition.value = val;
56
57
  emit('update:color', {
57
58
  h: props.color?.h ?? 0,
58
59
  s: clamp(x, 0, canvasWidth.value) / canvasWidth.value,
@@ -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)) {