@vuetify/nightly 3.8.0-dev.2025-04-01 → 3.8.0-master.2025-04-02

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.
@@ -1,5 +1,5 @@
1
1
  /*!
2
- * Vuetify v3.8.0-dev.2025-04-01
2
+ * Vuetify v3.8.0-master.2025-04-02
3
3
  * Forged by John Leider
4
4
  * Released under the MIT License.
5
5
  */
@@ -12672,14 +12672,6 @@
12672
12672
  const vTextFieldRef = vue.ref();
12673
12673
  const vMenuRef = vue.ref();
12674
12674
  const vVirtualScrollRef = vue.ref();
12675
- const _menu = useProxiedModel(props, 'menu');
12676
- const menu = vue.computed({
12677
- get: () => _menu.value,
12678
- set: v => {
12679
- if (_menu.value && !v && vMenuRef.value?.ΨopenChildren.size) return;
12680
- _menu.value = v;
12681
- }
12682
- });
12683
12675
  const {
12684
12676
  items,
12685
12677
  transformIn,
@@ -12695,7 +12687,6 @@
12695
12687
  const form = useForm(props);
12696
12688
  const selectedValues = vue.computed(() => model.value.map(selection => selection.value));
12697
12689
  const isFocused = vue.shallowRef(false);
12698
- const label = vue.computed(() => menu.value ? props.closeText : props.openText);
12699
12690
  let keyboardLookupPrefix = '';
12700
12691
  let keyboardLookupLastTime;
12701
12692
  const displayItems = vue.computed(() => {
@@ -12705,6 +12696,16 @@
12705
12696
  return items.value;
12706
12697
  });
12707
12698
  const menuDisabled = vue.computed(() => props.hideNoData && !displayItems.value.length || form.isReadonly.value || form.isDisabled.value);
12699
+ const _menu = useProxiedModel(props, 'menu');
12700
+ const menu = vue.computed({
12701
+ get: () => _menu.value,
12702
+ set: v => {
12703
+ if (_menu.value && !v && vMenuRef.value?.ΨopenChildren.size) return;
12704
+ if (v && menuDisabled.value) return;
12705
+ _menu.value = v;
12706
+ }
12707
+ });
12708
+ const label = vue.computed(() => menu.value ? props.closeText : props.openText);
12708
12709
  const computedMenuProps = vue.computed(() => {
12709
12710
  return {
12710
12711
  ...props.menuProps,
@@ -13203,17 +13204,8 @@
13203
13204
  const listHasFocus = vue.shallowRef(false);
13204
13205
  const vMenuRef = vue.ref();
13205
13206
  const vVirtualScrollRef = vue.ref();
13206
- const _menu = useProxiedModel(props, 'menu');
13207
- const menu = vue.computed({
13208
- get: () => _menu.value,
13209
- set: v => {
13210
- if (_menu.value && !v && vMenuRef.value?.ΨopenChildren.size) return;
13211
- _menu.value = v;
13212
- }
13213
- });
13214
13207
  const selectionIndex = vue.shallowRef(-1);
13215
13208
  const color = vue.computed(() => vTextFieldRef.value?.color);
13216
- const label = vue.computed(() => menu.value ? props.closeText : props.openText);
13217
13209
  const {
13218
13210
  items,
13219
13211
  transformIn,
@@ -13250,6 +13242,16 @@
13250
13242
  return selectFirst && displayItems.value.length > 0 && !isPristine.value && !listHasFocus.value;
13251
13243
  });
13252
13244
  const menuDisabled = vue.computed(() => props.hideNoData && !displayItems.value.length || form.isReadonly.value || form.isDisabled.value);
13245
+ const _menu = useProxiedModel(props, 'menu');
13246
+ const menu = vue.computed({
13247
+ get: () => _menu.value,
13248
+ set: v => {
13249
+ if (_menu.value && !v && vMenuRef.value?.ΨopenChildren.size) return;
13250
+ if (v && menuDisabled.value) return;
13251
+ _menu.value = v;
13252
+ }
13253
+ });
13254
+ const label = vue.computed(() => menu.value ? props.closeText : props.openText);
13253
13255
  const listRef = vue.ref();
13254
13256
  const listEvents = useScrolling(listRef, vTextFieldRef);
13255
13257
  function onClear(e) {
@@ -17968,18 +17970,9 @@
17968
17970
  const listHasFocus = vue.shallowRef(false);
17969
17971
  const vMenuRef = vue.ref();
17970
17972
  const vVirtualScrollRef = vue.ref();
17971
- const _menu = useProxiedModel(props, 'menu');
17972
- const menu = vue.computed({
17973
- get: () => _menu.value,
17974
- set: v => {
17975
- if (_menu.value && !v && vMenuRef.value?.ΨopenChildren.size) return;
17976
- _menu.value = v;
17977
- }
17978
- });
17979
17973
  const selectionIndex = vue.shallowRef(-1);
17980
17974
  let cleared = false;
17981
17975
  const color = vue.computed(() => vTextFieldRef.value?.color);
17982
- const label = vue.computed(() => menu.value ? props.closeText : props.openText);
17983
17976
  const {
17984
17977
  items,
17985
17978
  transformIn,
@@ -18023,6 +18016,27 @@
18023
18016
  const counterValue = vue.computed(() => {
18024
18017
  return typeof props.counterValue === 'function' ? props.counterValue(model.value) : typeof props.counterValue === 'number' ? props.counterValue : props.multiple ? model.value.length : search.value.length;
18025
18018
  });
18019
+ const {
18020
+ filteredItems,
18021
+ getMatches
18022
+ } = useFilter(props, items, () => isPristine.value ? '' : search.value);
18023
+ const displayItems = vue.computed(() => {
18024
+ if (props.hideSelected) {
18025
+ return filteredItems.value.filter(filteredItem => !model.value.some(s => s.value === filteredItem.value));
18026
+ }
18027
+ return filteredItems.value;
18028
+ });
18029
+ const menuDisabled = vue.computed(() => props.hideNoData && !displayItems.value.length || form.isReadonly.value || form.isDisabled.value);
18030
+ const _menu = useProxiedModel(props, 'menu');
18031
+ const menu = vue.computed({
18032
+ get: () => _menu.value,
18033
+ set: v => {
18034
+ if (_menu.value && !v && vMenuRef.value?.ΨopenChildren.size) return;
18035
+ if (v && menuDisabled.value) return;
18036
+ _menu.value = v;
18037
+ }
18038
+ });
18039
+ const label = vue.computed(() => menu.value ? props.closeText : props.openText);
18026
18040
  vue.watch(_search, value => {
18027
18041
  if (cleared) {
18028
18042
  // wait for clear to finish, VTextField sets _search to null
@@ -18038,22 +18052,11 @@
18038
18052
  _search.value = value[0]?.title ?? '';
18039
18053
  }
18040
18054
  });
18041
- const {
18042
- filteredItems,
18043
- getMatches
18044
- } = useFilter(props, items, () => isPristine.value ? '' : search.value);
18045
- const displayItems = vue.computed(() => {
18046
- if (props.hideSelected) {
18047
- return filteredItems.value.filter(filteredItem => !model.value.some(s => s.value === filteredItem.value));
18048
- }
18049
- return filteredItems.value;
18050
- });
18051
18055
  const selectedValues = vue.computed(() => model.value.map(selection => selection.value));
18052
18056
  const highlightFirst = vue.computed(() => {
18053
18057
  const selectFirst = props.autoSelectFirst === true || props.autoSelectFirst === 'exact' && search.value === displayItems.value[0]?.title;
18054
18058
  return selectFirst && displayItems.value.length > 0 && !isPristine.value && !listHasFocus.value;
18055
18059
  });
18056
- const menuDisabled = vue.computed(() => props.hideNoData && !displayItems.value.length || form.isReadonly.value || form.isDisabled.value);
18057
18060
  const listRef = vue.ref();
18058
18061
  const listEvents = useScrolling(listRef, vTextFieldRef);
18059
18062
  function onClear(e) {
@@ -31534,7 +31537,7 @@
31534
31537
  };
31535
31538
  });
31536
31539
  }
31537
- const version$1 = "3.8.0-dev.2025-04-01";
31540
+ const version$1 = "3.8.0-master.2025-04-02";
31538
31541
  createVuetify$1.version = version$1;
31539
31542
 
31540
31543
  // Vue's inject() can only be used in setup
@@ -31819,7 +31822,7 @@
31819
31822
 
31820
31823
  /* eslint-disable local-rules/sort-imports */
31821
31824
 
31822
- const version = "3.8.0-dev.2025-04-01";
31825
+ const version = "3.8.0-master.2025-04-02";
31823
31826
 
31824
31827
  /* eslint-disable local-rules/sort-imports */
31825
31828