@dimailn/vuetify 2.7.2-alpha13 → 2.7.2-alpha15

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 (67) hide show
  1. package/dist/vuetify.js +134 -132
  2. package/dist/vuetify.js.map +1 -1
  3. package/dist/vuetify.min.css +1 -1
  4. package/dist/vuetify.min.js +2 -2
  5. package/es5/components/VAppBar/VAppBar.js +7 -12
  6. package/es5/components/VAppBar/VAppBar.js.map +1 -1
  7. package/es5/components/VAutocomplete/VAutocomplete.js +9 -6
  8. package/es5/components/VAutocomplete/VAutocomplete.js.map +1 -1
  9. package/es5/components/VGrid/VContainer.js +3 -1
  10. package/es5/components/VGrid/VContainer.js.map +1 -1
  11. package/es5/components/VItemGroup/VItem.js +17 -18
  12. package/es5/components/VItemGroup/VItem.js.map +1 -1
  13. package/es5/components/VRadioGroup/VRadioGroup.js +3 -3
  14. package/es5/components/VRadioGroup/VRadioGroup.js.map +1 -1
  15. package/es5/components/VTextField/VTextField.js +4 -1
  16. package/es5/components/VTextField/VTextField.js.map +1 -1
  17. package/es5/components/VToolbar/VToolbar.js +2 -3
  18. package/es5/components/VToolbar/VToolbar.js.map +1 -1
  19. package/es5/directives/intersect/index.js +20 -7
  20. package/es5/directives/intersect/index.js.map +1 -1
  21. package/es5/directives/mutate/index.js +13 -13
  22. package/es5/directives/mutate/index.js.map +1 -1
  23. package/es5/directives/resize/index.js +8 -8
  24. package/es5/directives/resize/index.js.map +1 -1
  25. package/es5/directives/scroll/index.js +10 -9
  26. package/es5/directives/scroll/index.js.map +1 -1
  27. package/es5/directives/touch/index.js +4 -4
  28. package/es5/directives/touch/index.js.map +1 -1
  29. package/es5/framework.js +1 -1
  30. package/lib/components/VAppBar/VAppBar.js +7 -11
  31. package/lib/components/VAppBar/VAppBar.js.map +1 -1
  32. package/lib/components/VAutocomplete/VAutocomplete.js +10 -7
  33. package/lib/components/VAutocomplete/VAutocomplete.js.map +1 -1
  34. package/lib/components/VGrid/VContainer.js +3 -1
  35. package/lib/components/VGrid/VContainer.js.map +1 -1
  36. package/lib/components/VItemGroup/VItem.js +20 -18
  37. package/lib/components/VItemGroup/VItem.js.map +1 -1
  38. package/lib/components/VRadioGroup/VRadioGroup.js +3 -5
  39. package/lib/components/VRadioGroup/VRadioGroup.js.map +1 -1
  40. package/lib/components/VTextField/VTextField.js +4 -1
  41. package/lib/components/VTextField/VTextField.js.map +1 -1
  42. package/lib/components/VToolbar/VToolbar.js +4 -3
  43. package/lib/components/VToolbar/VToolbar.js.map +1 -1
  44. package/lib/directives/intersect/index.js +20 -7
  45. package/lib/directives/intersect/index.js.map +1 -1
  46. package/lib/directives/mutate/index.js +13 -13
  47. package/lib/directives/mutate/index.js.map +1 -1
  48. package/lib/directives/resize/index.js +8 -8
  49. package/lib/directives/resize/index.js.map +1 -1
  50. package/lib/directives/scroll/index.js +10 -9
  51. package/lib/directives/scroll/index.js.map +1 -1
  52. package/lib/directives/touch/index.js +4 -4
  53. package/lib/directives/touch/index.js.map +1 -1
  54. package/lib/framework.js +1 -1
  55. package/package.json +1 -1
  56. package/src/components/VAppBar/VAppBar.ts +11 -13
  57. package/src/components/VAutocomplete/VAutocomplete.ts +12 -5
  58. package/src/components/VGrid/VContainer.ts +1 -1
  59. package/src/components/VItemGroup/VItem.ts +25 -23
  60. package/src/components/VRadioGroup/VRadioGroup.ts +6 -7
  61. package/src/components/VTextField/VTextField.ts +3 -2
  62. package/src/components/VToolbar/VToolbar.ts +4 -5
  63. package/src/directives/intersect/index.ts +81 -42
  64. package/src/directives/mutate/index.ts +58 -49
  65. package/src/directives/resize/index.ts +33 -14
  66. package/src/directives/scroll/index.ts +36 -20
  67. package/src/directives/touch/index.ts +37 -27
package/dist/vuetify.js CHANGED
@@ -493,17 +493,17 @@ __webpack_require__.r(__webpack_exports__);
493
493
 
494
494
  "use strict";
495
495
  __webpack_require__.r(__webpack_exports__);
496
- /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! vue */ "vue");
497
- /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(vue__WEBPACK_IMPORTED_MODULE_0__);
498
- /* harmony import */ var _VAppBar_sass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./VAppBar.sass */ "./src/components/VAppBar/VAppBar.sass");
499
- /* harmony import */ var _VAppBar_sass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_VAppBar_sass__WEBPACK_IMPORTED_MODULE_1__);
500
- /* harmony import */ var _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../VToolbar/VToolbar */ "./src/components/VToolbar/VToolbar.ts");
501
- /* harmony import */ var _directives_scroll__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../directives/scroll */ "./src/directives/scroll/index.ts");
502
- /* harmony import */ var _mixins_applicationable__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../mixins/applicationable */ "./src/mixins/applicationable/index.ts");
503
- /* harmony import */ var _mixins_scrollable__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../../mixins/scrollable */ "./src/mixins/scrollable/index.ts");
504
- /* harmony import */ var _mixins_ssr_bootable__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../mixins/ssr-bootable */ "./src/mixins/ssr-bootable/index.ts");
505
- /* harmony import */ var _mixins_toggleable__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../../mixins/toggleable */ "./src/mixins/toggleable/index.ts");
506
- /* harmony import */ var _util_helpers__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../../util/helpers */ "./src/util/helpers.ts");
496
+ /* harmony import */ var _VAppBar_sass__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./VAppBar.sass */ "./src/components/VAppBar/VAppBar.sass");
497
+ /* harmony import */ var _VAppBar_sass__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_VAppBar_sass__WEBPACK_IMPORTED_MODULE_0__);
498
+ /* harmony import */ var _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../VToolbar/VToolbar */ "./src/components/VToolbar/VToolbar.ts");
499
+ /* harmony import */ var _directives_scroll__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../directives/scroll */ "./src/directives/scroll/index.ts");
500
+ /* harmony import */ var _mixins_applicationable__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../mixins/applicationable */ "./src/mixins/applicationable/index.ts");
501
+ /* harmony import */ var _mixins_scrollable__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../mixins/scrollable */ "./src/mixins/scrollable/index.ts");
502
+ /* harmony import */ var _mixins_ssr_bootable__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../../mixins/ssr-bootable */ "./src/mixins/ssr-bootable/index.ts");
503
+ /* harmony import */ var _mixins_toggleable__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../mixins/toggleable */ "./src/mixins/toggleable/index.ts");
504
+ /* harmony import */ var _util_helpers__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../../util/helpers */ "./src/util/helpers.ts");
505
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! vue */ "vue");
506
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_8___default = /*#__PURE__*/__webpack_require__.n(vue__WEBPACK_IMPORTED_MODULE_8__);
507
507
  /* harmony import */ var _util_mixins__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../../util/mixins */ "./src/util/mixins.ts");
508
508
  var __assign = undefined && undefined.__assign || function () {
509
509
  __assign = Object.assign || function (t) {
@@ -519,9 +519,8 @@ var __assign = undefined && undefined.__assign || function () {
519
519
  };
520
520
 
521
521
  return __assign.apply(this, arguments);
522
- };
522
+ }; // Styles
523
523
 
524
- // Styles
525
524
 
526
525
  // Extensions
527
526
 
@@ -536,13 +535,14 @@ var __assign = undefined && undefined.__assign || function () {
536
535
 
537
536
 
538
537
 
539
- var baseMixins = Object(_util_mixins__WEBPACK_IMPORTED_MODULE_9__["default"])(_VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_2__["default"], _mixins_scrollable__WEBPACK_IMPORTED_MODULE_5__["default"], _mixins_ssr_bootable__WEBPACK_IMPORTED_MODULE_6__["default"], _mixins_toggleable__WEBPACK_IMPORTED_MODULE_7__["default"], Object(_mixins_applicationable__WEBPACK_IMPORTED_MODULE_4__["default"])('top', ['clippedLeft', 'clippedRight', 'computedHeight', 'invertedScroll', 'isExtended', 'isProminent', 'value']));
538
+
539
+ var baseMixins = Object(_util_mixins__WEBPACK_IMPORTED_MODULE_9__["default"])(_VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_1__["default"], _mixins_scrollable__WEBPACK_IMPORTED_MODULE_4__["default"], _mixins_ssr_bootable__WEBPACK_IMPORTED_MODULE_5__["default"], _mixins_toggleable__WEBPACK_IMPORTED_MODULE_6__["default"], Object(_mixins_applicationable__WEBPACK_IMPORTED_MODULE_3__["default"])('top', ['clippedLeft', 'clippedRight', 'computedHeight', 'invertedScroll', 'isExtended', 'isProminent', 'value']));
540
540
  /* @vue/component */
541
541
 
542
542
  /* harmony default export */ __webpack_exports__["default"] = (baseMixins.extend({
543
543
  name: 'v-app-bar',
544
544
  directives: {
545
- Scroll: _directives_scroll__WEBPACK_IMPORTED_MODULE_3__["default"]
545
+ Scroll: _directives_scroll__WEBPACK_IMPORTED_MODULE_2__["default"]
546
546
  },
547
547
  provide: function provide() {
548
548
  return {
@@ -574,13 +574,13 @@ var baseMixins = Object(_util_mixins__WEBPACK_IMPORTED_MODULE_9__["default"])(_V
574
574
  return !this.bottom ? 'top' : 'bottom';
575
575
  },
576
576
  canScroll: function canScroll() {
577
- return _mixins_scrollable__WEBPACK_IMPORTED_MODULE_5__["default"].computed.canScroll.call(this) && (this.invertedScroll || this.elevateOnScroll || this.hideOnScroll || this.collapseOnScroll || this.isBooted || // If falsy, user has provided an
577
+ return _mixins_scrollable__WEBPACK_IMPORTED_MODULE_4__["default"].computed.canScroll.call(this) && (this.invertedScroll || this.elevateOnScroll || this.hideOnScroll || this.collapseOnScroll || this.isBooted || // If falsy, user has provided an
578
578
  // explicit value which should
579
579
  // overwrite anything we do
580
580
  !this.value);
581
581
  },
582
582
  classes: function classes() {
583
- return __assign(__assign({}, _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_2__["default"].computed.classes.call(this)), {
583
+ return __assign(__assign({}, _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_1__["default"].computed.classes.call(this)), {
584
584
  'v-toolbar--collapse': this.collapse || this.collapseOnScroll,
585
585
  'v-app-bar': true,
586
586
  'v-app-bar--clipped': this.clippedLeft || this.clippedRight,
@@ -597,7 +597,7 @@ var baseMixins = Object(_util_mixins__WEBPACK_IMPORTED_MODULE_9__["default"])(_V
597
597
  return Math.max((threshold - this.currentScroll) / threshold, 0);
598
598
  },
599
599
  computedContentHeight: function computedContentHeight() {
600
- if (!this.shrinkOnScroll) return _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_2__["default"].computed.computedContentHeight.call(this);
600
+ if (!this.shrinkOnScroll) return _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_1__["default"].computed.computedContentHeight.call(this);
601
601
  var min = this.dense ? 48 : 56;
602
602
  var max = this.computedOriginalHeight;
603
603
  return min + (max - min) * this.scrollRatio;
@@ -621,7 +621,7 @@ var baseMixins = Object(_util_mixins__WEBPACK_IMPORTED_MODULE_9__["default"])(_V
621
621
  return this.scrollRatio;
622
622
  },
623
623
  computedOriginalHeight: function computedOriginalHeight() {
624
- var height = _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_2__["default"].computed.computedContentHeight.call(this);
624
+ var height = _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_1__["default"].computed.computedContentHeight.call(this);
625
625
  if (this.isExtended) height += parseInt(this.extensionHeight);
626
626
  return height;
627
627
  },
@@ -652,21 +652,21 @@ var baseMixins = Object(_util_mixins__WEBPACK_IMPORTED_MODULE_9__["default"])(_V
652
652
  },
653
653
  isCollapsed: function isCollapsed() {
654
654
  if (!this.collapseOnScroll) {
655
- return _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_2__["default"].computed.isCollapsed.call(this);
655
+ return _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_1__["default"].computed.isCollapsed.call(this);
656
656
  }
657
657
 
658
658
  return this.currentScroll > 0;
659
659
  },
660
660
  isProminent: function isProminent() {
661
- return _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_2__["default"].computed.isProminent.call(this) || this.shrinkOnScroll;
661
+ return _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_1__["default"].computed.isProminent.call(this) || this.shrinkOnScroll;
662
662
  },
663
663
  styles: function styles() {
664
- return __assign(__assign({}, _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_2__["default"].computed.styles.call(this)), {
665
- fontSize: Object(_util_helpers__WEBPACK_IMPORTED_MODULE_8__["convertToUnit"])(this.computedFontSize, 'rem'),
666
- marginTop: Object(_util_helpers__WEBPACK_IMPORTED_MODULE_8__["convertToUnit"])(this.computedMarginTop),
667
- transform: "translateY(" + Object(_util_helpers__WEBPACK_IMPORTED_MODULE_8__["convertToUnit"])(this.computedTransform) + ")",
668
- left: Object(_util_helpers__WEBPACK_IMPORTED_MODULE_8__["convertToUnit"])(this.computedLeft),
669
- right: Object(_util_helpers__WEBPACK_IMPORTED_MODULE_8__["convertToUnit"])(this.computedRight)
664
+ return __assign(__assign({}, _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_1__["default"].computed.styles.call(this)), {
665
+ fontSize: Object(_util_helpers__WEBPACK_IMPORTED_MODULE_7__["convertToUnit"])(this.computedFontSize, 'rem'),
666
+ marginTop: Object(_util_helpers__WEBPACK_IMPORTED_MODULE_7__["convertToUnit"])(this.computedMarginTop),
667
+ transform: "translateY(" + Object(_util_helpers__WEBPACK_IMPORTED_MODULE_7__["convertToUnit"])(this.computedTransform) + ")",
668
+ left: Object(_util_helpers__WEBPACK_IMPORTED_MODULE_7__["convertToUnit"])(this.computedLeft),
669
+ right: Object(_util_helpers__WEBPACK_IMPORTED_MODULE_7__["convertToUnit"])(this.computedRight)
670
670
  });
671
671
  }
672
672
  },
@@ -694,8 +694,8 @@ var baseMixins = Object(_util_mixins__WEBPACK_IMPORTED_MODULE_9__["default"])(_V
694
694
  },
695
695
  methods: {
696
696
  genBackground: function genBackground() {
697
- var render = _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_2__["default"].methods.genBackground.call(this);
698
- render.data = this._b(render.data || {}, render.tag, {
697
+ var render = _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_1__["default"].methods.genBackground.call(this);
698
+ render.props = Object(vue__WEBPACK_IMPORTED_MODULE_8__["mergeProps"])(render.props || {}, {
699
699
  style: {
700
700
  opacity: this.computedOpacity
701
701
  }
@@ -720,18 +720,14 @@ var baseMixins = Object(_util_mixins__WEBPACK_IMPORTED_MODULE_9__["default"])(_V
720
720
  }
721
721
  },
722
722
  render: function render() {
723
- var render = _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_2__["default"].render.call(this, vue__WEBPACK_IMPORTED_MODULE_0__["h"]);
724
- render.data = render.data || {};
723
+ var render = _VToolbar_VToolbar__WEBPACK_IMPORTED_MODULE_1__["default"].render.call(this);
725
724
 
726
725
  if (this.canScroll) {
727
- render.data.directives = render.data.directives || [];
728
- render.data.directives.push({
729
- arg: this.scrollTarget,
730
- name: 'scroll',
731
- value: this.onScroll
732
- });
726
+ render.key = 'v-app-bar-scroll';
727
+ return Object(vue__WEBPACK_IMPORTED_MODULE_8__["withDirectives"])(render, [[_directives_scroll__WEBPACK_IMPORTED_MODULE_2__["default"], this.onScroll, this.scrollTarget]]);
733
728
  }
734
729
 
730
+ render.key = 'v-app-bar-no-scroll';
735
731
  return render;
736
732
  }
737
733
  }));
@@ -908,10 +904,9 @@ __webpack_require__.r(__webpack_exports__);
908
904
  /* harmony import */ var _VAutocomplete_sass__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_VAutocomplete_sass__WEBPACK_IMPORTED_MODULE_0__);
909
905
  /* harmony import */ var _VSelect_VSelect__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../VSelect/VSelect */ "./src/components/VSelect/VSelect.ts");
910
906
  /* harmony import */ var _VTextField_VTextField__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../VTextField/VTextField */ "./src/components/VTextField/VTextField.ts");
911
- /* harmony import */ var _util_mergeData__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../util/mergeData */ "./src/util/mergeData.ts");
907
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! vue */ "vue");
908
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(vue__WEBPACK_IMPORTED_MODULE_3__);
912
909
  /* harmony import */ var _util_helpers__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../util/helpers */ "./src/util/helpers.ts");
913
- /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! vue */ "vue");
914
- /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(vue__WEBPACK_IMPORTED_MODULE_5__);
915
910
  var __assign = undefined && undefined.__assign || function () {
916
911
  __assign = Object.assign || function (t) {
917
912
  for (var s, i = 1, n = arguments.length; i < n; i++) {
@@ -935,8 +930,6 @@ var __assign = undefined && undefined.__assign || function () {
935
930
  // Utilities
936
931
 
937
932
 
938
- // Types
939
-
940
933
 
941
934
 
942
935
  var defaultMenuProps = __assign(__assign({}, _VSelect_VSelect__WEBPACK_IMPORTED_MODULE_1__["defaultMenuProps"]), {
@@ -947,7 +940,7 @@ var defaultMenuProps = __assign(__assign({}, _VSelect_VSelect__WEBPACK_IMPORTED_
947
940
  /* @vue/component */
948
941
 
949
942
 
950
- /* harmony default export */ __webpack_exports__["default"] = (Object(vue__WEBPACK_IMPORTED_MODULE_5__["defineComponent"])({
943
+ /* harmony default export */ __webpack_exports__["default"] = (Object(vue__WEBPACK_IMPORTED_MODULE_3__["defineComponent"])({
951
944
  name: 'v-autocomplete',
952
945
  extends: _VSelect_VSelect__WEBPACK_IMPORTED_MODULE_1__["default"],
953
946
  props: {
@@ -1198,9 +1191,14 @@ var defaultMenuProps = __assign(__assign({}, _VSelect_VSelect__WEBPACK_IMPORTED_
1198
1191
  },
1199
1192
  genInput: function genInput() {
1200
1193
  var input = _VTextField_VTextField__WEBPACK_IMPORTED_MODULE_2__["default"].methods.genInput.call(this);
1201
- input.data = Object(_util_mergeData__WEBPACK_IMPORTED_MODULE_3__["default"])(input.props, {
1202
- 'aria-activedescendant': Object(_util_helpers__WEBPACK_IMPORTED_MODULE_4__["getObjectValueByPath"])(this.$refs.menu, 'activeTile.id'),
1203
- autocomplete: Object(_util_helpers__WEBPACK_IMPORTED_MODULE_4__["getObjectValueByPath"])(input.data, 'attrs.autocomplete', 'off'),
1194
+ var ariaActiveDescendant = Object(_util_helpers__WEBPACK_IMPORTED_MODULE_4__["getObjectValueByPath"])(this.$refs.menu, 'activeTile.id');
1195
+ var autocomplete = Object(_util_helpers__WEBPACK_IMPORTED_MODULE_4__["getObjectValueByPath"])(input.props, 'autocomplete', 'off'); // в оригинале class не пробрасывался в инпут
1196
+
1197
+ input.props = Object(vue__WEBPACK_IMPORTED_MODULE_3__["mergeProps"])(__assign(__assign({}, input.props), {
1198
+ class: undefined
1199
+ }), {
1200
+ 'aria-activedescendant': ariaActiveDescendant,
1201
+ autocomplete: autocomplete,
1204
1202
  value: this.internalSearch
1205
1203
  });
1206
1204
  return input;
@@ -16492,6 +16490,8 @@ __webpack_require__.r(__webpack_exports__);
16492
16490
  }
16493
16491
  },
16494
16492
  render: function render() {
16493
+ var _a, _b;
16494
+
16495
16495
  var classes; // const { attrs } = data
16496
16496
 
16497
16497
  var attrs = this.$attrs;
@@ -16522,7 +16522,7 @@ __webpack_require__.r(__webpack_exports__);
16522
16522
  class: Array({
16523
16523
  'container--fluid': this.fluid
16524
16524
  }).concat(classes || []).concat('container')
16525
- }), this.$slots.default());
16525
+ }), (_b = (_a = this.$slots).default) === null || _b === void 0 ? void 0 : _b.call(_a));
16526
16526
  }
16527
16527
  }));
16528
16528
 
@@ -18053,29 +18053,12 @@ __webpack_require__.r(__webpack_exports__);
18053
18053
  /* harmony import */ var _util_console__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../util/console */ "./src/util/console.ts");
18054
18054
  /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! vue */ "vue");
18055
18055
  /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(vue__WEBPACK_IMPORTED_MODULE_4__);
18056
- var __assign = undefined && undefined.__assign || function () {
18057
- __assign = Object.assign || function (t) {
18058
- for (var s, i = 1, n = arguments.length; i < n; i++) {
18059
- s = arguments[i];
18060
-
18061
- for (var p in s) {
18062
- if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
18063
- }
18064
- }
18065
-
18066
- return t;
18067
- };
18068
-
18069
- return __assign.apply(this, arguments);
18070
- }; // Styles
18071
-
18072
-
18056
+ // Styles
18073
18057
  // Mixins
18074
18058
 
18075
18059
  // Utilities
18076
18060
 
18077
18061
 
18078
- // Types
18079
18062
 
18080
18063
 
18081
18064
  /* @vue/component */
@@ -18106,31 +18089,34 @@ var BaseItem = Object(vue__WEBPACK_IMPORTED_MODULE_4__["defineComponent"])({
18106
18089
  return null;
18107
18090
  }
18108
18091
 
18109
- var element;
18110
- /* istanbul ignore else */
18092
+ var slotContent = this.$slots.default({
18093
+ active: this.isActive,
18094
+ toggle: this.toggle
18095
+ });
18111
18096
 
18112
- if (this.$slots.default) {
18113
- element = this.$slots.default({
18114
- active: this.isActive,
18115
- toggle: this.toggle
18116
- });
18097
+ if (!slotContent || slotContent.length === 0) {
18098
+ Object(_util_console__WEBPACK_IMPORTED_MODULE_3__["consoleWarn"])('v-item slot returned empty content', this);
18099
+ return null;
18117
18100
  }
18118
18101
 
18119
- if (Array.isArray(element) && element.length === 1) {
18120
- element = element[0];
18102
+ var element = slotContent[0];
18103
+
18104
+ if (!element) {
18105
+ Object(_util_console__WEBPACK_IMPORTED_MODULE_3__["consoleWarn"])('v-item should contain at least one element', this);
18106
+ return null;
18121
18107
  }
18122
18108
 
18123
- if (!element || Array.isArray(element) || !element.tag) {
18124
- Object(_util_console__WEBPACK_IMPORTED_MODULE_3__["consoleWarn"])('v-item should only contain a single element', this);
18109
+ if (!element.type) {
18110
+ Object(_util_console__WEBPACK_IMPORTED_MODULE_3__["consoleWarn"])('v-item should only contain valid VNode elements', this);
18125
18111
  return element;
18126
18112
  }
18127
18113
 
18128
- element.data = this._b(element.data || {}, element.tag, {
18129
- class: (_a = {}, _a[this.activeClass] = this.isActive, _a['v-item--disabled'] = this.disabled, _a)
18114
+ element.props = Object(vue__WEBPACK_IMPORTED_MODULE_4__["mergeProps"])(element.props || {}, {
18115
+ class: (_a = {}, _a[this.activeClass] = this.isActive, _a["v-item--disabled"] = this.disabled, _a)
18130
18116
  });
18131
18117
 
18132
18118
  if (this.disabled) {
18133
- element.data.attrs = __assign(__assign({}, element.data.attrs), {
18119
+ element.props = Object(vue__WEBPACK_IMPORTED_MODULE_4__["mergeProps"])(element.props || {}, {
18134
18120
  tabindex: -1
18135
18121
  });
18136
18122
  }
@@ -22815,9 +22801,9 @@ __webpack_require__.r(__webpack_exports__);
22815
22801
  /* harmony import */ var _VRadioGroup_sass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_VRadioGroup_sass__WEBPACK_IMPORTED_MODULE_1__);
22816
22802
  /* harmony import */ var _VInput__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../VInput */ "./src/components/VInput/index.ts");
22817
22803
  /* harmony import */ var _VItemGroup_VItemGroup__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../VItemGroup/VItemGroup */ "./src/components/VItemGroup/VItemGroup.ts");
22818
- /* harmony import */ var _util_mixins__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../util/mixins */ "./src/util/mixins.ts");
22819
- /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! vue */ "vue");
22820
- /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(vue__WEBPACK_IMPORTED_MODULE_5__);
22804
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! vue */ "vue");
22805
+ /* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(vue__WEBPACK_IMPORTED_MODULE_4__);
22806
+ /* harmony import */ var _util_mixins__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../../util/mixins */ "./src/util/mixins.ts");
22821
22807
  var __assign = undefined && undefined.__assign || function () {
22822
22808
  __assign = Object.assign || function (t) {
22823
22809
  for (var s, i = 1, n = arguments.length; i < n; i++) {
@@ -22839,11 +22825,11 @@ var __assign = undefined && undefined.__assign || function () {
22839
22825
  // Extensions
22840
22826
 
22841
22827
 
22842
- // Types
22828
+ // Utilities
22843
22829
 
22844
22830
 
22845
22831
 
22846
- var baseMixins = Object(_util_mixins__WEBPACK_IMPORTED_MODULE_4__["default"])(_VInput__WEBPACK_IMPORTED_MODULE_2__["default"], _VItemGroup_VItemGroup__WEBPACK_IMPORTED_MODULE_3__["BaseItemGroup"]);
22832
+ var baseMixins = Object(_util_mixins__WEBPACK_IMPORTED_MODULE_5__["default"])(_VInput__WEBPACK_IMPORTED_MODULE_2__["default"], _VItemGroup_VItemGroup__WEBPACK_IMPORTED_MODULE_3__["BaseItemGroup"]);
22847
22833
  /* @vue/component */
22848
22834
 
22849
22835
  /* harmony default export */ __webpack_exports__["default"] = (baseMixins.extend({
@@ -22880,7 +22866,7 @@ var baseMixins = Object(_util_mixins__WEBPACK_IMPORTED_MODULE_4__["default"])(_V
22880
22866
  },
22881
22867
  methods: {
22882
22868
  genDefaultSlot: function genDefaultSlot() {
22883
- return Object(vue__WEBPACK_IMPORTED_MODULE_5__["h"])('div', {
22869
+ return Object(vue__WEBPACK_IMPORTED_MODULE_4__["h"])('div', {
22884
22870
  class: 'v-input--radio-group__input',
22885
22871
  id: this.id,
22886
22872
  role: 'radiogroup',
@@ -22905,7 +22891,7 @@ var baseMixins = Object(_util_mixins__WEBPACK_IMPORTED_MODULE_4__["default"])(_V
22905
22891
  },
22906
22892
  render: function render() {
22907
22893
  var vnode = _VInput__WEBPACK_IMPORTED_MODULE_2__["default"].render.call(this);
22908
- vnode.props = __assign(__assign({}, vnode.props), this.attrs$);
22894
+ vnode.props = Object(vue__WEBPACK_IMPORTED_MODULE_4__["mergeProps"])(vnode.props, this.attrs$);
22909
22895
  return vnode;
22910
22896
  }
22911
22897
  }));
@@ -29509,6 +29495,7 @@ var dirtyTypes = ['color', 'file', 'time', 'date', 'datetime-local', 'week', 'mo
29509
29495
  genLabel: function genLabel() {
29510
29496
  if (!this.showLabel) return null;
29511
29497
  var data = {
29498
+ ref: "label",
29512
29499
  absolute: true,
29513
29500
  color: this.validationState,
29514
29501
  dark: this.dark,
@@ -29635,8 +29622,10 @@ var dirtyTypes = ['color', 'file', 'time', 'date', 'datetime-local', 'week', 'mo
29635
29622
  _VInput__WEBPACK_IMPORTED_MODULE_1__["default"].methods.onMouseUp.call(this, e);
29636
29623
  },
29637
29624
  setLabelWidth: function setLabelWidth() {
29625
+ var _a, _b, _c, _d;
29626
+
29638
29627
  if (!this.outlined) return;
29639
- this.labelWidth = this.$refs.label ? Math.min(this.$refs.label.scrollWidth * 0.75 + 6, this.$el.offsetWidth - 24) : 0;
29628
+ this.labelWidth = ((_b = (_a = this.$refs) === null || _a === void 0 ? void 0 : _a.label) === null || _b === void 0 ? void 0 : _b.$el) ? Math.min(((_d = (_c = this.$refs) === null || _c === void 0 ? void 0 : _c.label) === null || _d === void 0 ? void 0 : _d.$el.scrollWidth) * 0.75 + 6, this.$el.offsetWidth - 24) : 0;
29640
29629
  },
29641
29630
  setPrefixWidth: function setPrefixWidth() {
29642
29631
  if (!this.$refs.prefix) return;
@@ -31219,12 +31208,11 @@ var __read = undefined && undefined.__read || function (o, n) {
31219
31208
  var children = [this.genContent()];
31220
31209
  var data = this.setBackgroundColor(this.color, {
31221
31210
  class: this.classes,
31222
- style: this.styles,
31223
- on: this.$listeners
31211
+ style: this.styles
31224
31212
  });
31225
31213
  if (this.isExtended) children.push(this.genExtension());
31226
31214
  if (this.src || this.$slots.img) children.unshift(this.genBackground());
31227
- return Object(vue__WEBPACK_IMPORTED_MODULE_0__["h"])(this.tag, data, children);
31215
+ return Object(vue__WEBPACK_IMPORTED_MODULE_0__["h"])(this.tag, __assign(__assign({}, this.attrs$), data), children);
31228
31216
  }
31229
31217
  }));
31230
31218
 
@@ -34307,18 +34295,22 @@ __webpack_require__.r(__webpack_exports__);
34307
34295
  /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Intersect", function() { return Intersect; });
34308
34296
  function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
34309
34297
 
34310
- function inserted(el, binding, vnode) {
34311
- if (typeof window === 'undefined' || !('IntersectionObserver' in window)) return;
34298
+ function mounted(el, binding, vnode) {
34299
+ if (typeof window === 'undefined' || !('IntersectionObserver' in window)) {
34300
+ return;
34301
+ }
34302
+
34312
34303
  var modifiers = binding.modifiers || {};
34313
34304
  var value = binding.value;
34314
34305
 
34315
- var _a = _typeof(value) === 'object' ? value : {
34306
+ var _a = _typeof(value) === 'object' && value !== null && 'handler' in value ? value : {
34316
34307
  handler: value,
34317
34308
  options: {}
34318
34309
  },
34319
34310
  handler = _a.handler,
34320
34311
  options = _a.options;
34321
34312
 
34313
+ if (!handler) return;
34322
34314
  var observer = new IntersectionObserver(function (entries, observer) {
34323
34315
  var _a;
34324
34316
 
@@ -34339,7 +34331,7 @@ function inserted(el, binding, vnode) {
34339
34331
  handler(entries, observer, isIntersecting);
34340
34332
  }
34341
34333
 
34342
- if (isIntersecting && modifiers.once) unbind(el, binding, vnode);else _observe.init = true;
34334
+ if (isIntersecting && modifiers.once) unmounted(el, binding, vnode);else _observe.init = true;
34343
34335
  }, options);
34344
34336
  el._observe = Object(el._observe);
34345
34337
  el._observe[vnode.ctx.uid] = {
@@ -34349,7 +34341,15 @@ function inserted(el, binding, vnode) {
34349
34341
  observer.observe(el);
34350
34342
  }
34351
34343
 
34352
- function unbind(el, binding, vnode) {
34344
+ function updated(el, binding, vnode) {
34345
+ // Если значение изменилось, пересоздаем observer
34346
+ if (binding.value !== binding.oldValue) {
34347
+ unmounted(el, binding, vnode);
34348
+ mounted(el, binding, vnode);
34349
+ }
34350
+ }
34351
+
34352
+ function unmounted(el, binding, vnode) {
34353
34353
  var _a;
34354
34354
 
34355
34355
  var observe = (_a = el._observe) === null || _a === void 0 ? void 0 : _a[vnode.ctx.uid];
@@ -34359,8 +34359,9 @@ function unbind(el, binding, vnode) {
34359
34359
  }
34360
34360
 
34361
34361
  var Intersect = {
34362
- mounted: inserted,
34363
- unmounted: unbind
34362
+ mounted: mounted,
34363
+ updated: updated,
34364
+ unmounted: unmounted
34364
34365
  };
34365
34366
  /* harmony default export */ __webpack_exports__["default"] = (Intersect);
34366
34367
 
@@ -34391,7 +34392,7 @@ var __rest = undefined && undefined.__rest || function (s, e) {
34391
34392
  return t;
34392
34393
  };
34393
34394
 
34394
- function inserted(el, binding, vnode) {
34395
+ function mounted(el, binding, vnode) {
34395
34396
  var modifiers = binding.modifiers || {};
34396
34397
  var value = binding.value;
34397
34398
  var callback = _typeof(value) === 'object' ? value.handler : value;
@@ -34401,14 +34402,14 @@ function inserted(el, binding, vnode) {
34401
34402
 
34402
34403
  var hasModifiers = Object.keys(modifierKeys).length > 0; // Options take top priority
34403
34404
 
34404
- var options = _typeof(value) === 'object' && value.options ? value.options : hasModifiers // If we have modifiers, use only those provided
34405
- ? {
34405
+ var options = _typeof(value) === 'object' && value.options ? value.options : hasModifiers ? {
34406
+ // If we have modifiers, use only those provided
34406
34407
  attributes: modifierKeys.attr,
34407
34408
  childList: modifierKeys.child,
34408
34409
  subtree: modifierKeys.sub,
34409
34410
  characterData: modifierKeys.char
34410
- } // Defaults to everything on
34411
- : {
34411
+ } : {
34412
+ // Defaults to everything on
34412
34413
  attributes: true,
34413
34414
  childList: true,
34414
34415
  subtree: true,
@@ -34420,28 +34421,28 @@ function inserted(el, binding, vnode) {
34420
34421
 
34421
34422
  callback(mutationsList, observer); // If has the once modifier, unbind
34422
34423
 
34423
- once && unbind(el, binding, vnode);
34424
+ once && unmounted(el, binding, vnode);
34424
34425
  });
34425
34426
  observer.observe(el, options);
34426
34427
  el._mutate = Object(el._mutate);
34427
- el._mutate[vnode.context._uid] = {
34428
+ el._mutate[vnode.ctx.uid] = {
34428
34429
  observer: observer
34429
34430
  };
34430
34431
  }
34431
34432
 
34432
- function unbind(el, binding, vnode) {
34433
+ function unmounted(el, binding, vnode) {
34433
34434
  var _a;
34434
34435
 
34435
- if (!((_a = el._mutate) === null || _a === void 0 ? void 0 : _a[vnode.context._uid])) return;
34436
+ if (!((_a = el._mutate) === null || _a === void 0 ? void 0 : _a[vnode.ctx.uid])) return;
34436
34437
 
34437
- el._mutate[vnode.context._uid].observer.disconnect();
34438
+ el._mutate[vnode.ctx.uid].observer.disconnect();
34438
34439
 
34439
- delete el._mutate[vnode.context._uid];
34440
+ delete el._mutate[vnode.ctx.uid];
34440
34441
  }
34441
34442
 
34442
34443
  var Mutate = {
34443
- inserted: inserted,
34444
- unbind: unbind
34444
+ mounted: mounted,
34445
+ unmounted: unmounted
34445
34446
  };
34446
34447
  /* harmony default export */ __webpack_exports__["default"] = (Mutate);
34447
34448
 
@@ -34457,14 +34458,14 @@ var Mutate = {
34457
34458
  "use strict";
34458
34459
  __webpack_require__.r(__webpack_exports__);
34459
34460
  /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Resize", function() { return Resize; });
34460
- function inserted(el, binding, vnode) {
34461
+ function mounted(el, binding, vnode) {
34461
34462
  var callback = binding.value;
34462
34463
  var options = binding.options || {
34463
34464
  passive: true
34464
34465
  };
34465
34466
  window.addEventListener('resize', callback, options);
34466
34467
  el._onResize = Object(el._onResize);
34467
- el._onResize[vnode.context._uid] = {
34468
+ el._onResize[vnode.ctx.uid] = {
34468
34469
  callback: callback,
34469
34470
  options: options
34470
34471
  };
@@ -34474,20 +34475,20 @@ function inserted(el, binding, vnode) {
34474
34475
  }
34475
34476
  }
34476
34477
 
34477
- function unbind(el, binding, vnode) {
34478
+ function unmounted(el, binding, vnode) {
34478
34479
  var _a;
34479
34480
 
34480
- if (!((_a = el._onResize) === null || _a === void 0 ? void 0 : _a[vnode.context._uid])) return;
34481
- var _b = el._onResize[vnode.context._uid],
34481
+ if (!((_a = el._onResize) === null || _a === void 0 ? void 0 : _a[vnode.ctx.uid])) return;
34482
+ var _b = el._onResize[vnode.ctx.uid],
34482
34483
  callback = _b.callback,
34483
34484
  options = _b.options;
34484
34485
  window.removeEventListener('resize', callback, options);
34485
- delete el._onResize[vnode.context._uid];
34486
+ delete el._onResize[vnode.ctx.uid];
34486
34487
  }
34487
34488
 
34488
34489
  var Resize = {
34489
- inserted: inserted,
34490
- unbind: unbind
34490
+ mounted: mounted,
34491
+ unmounted: unmounted
34491
34492
  };
34492
34493
  /* harmony default export */ __webpack_exports__["default"] = (Resize);
34493
34494
 
@@ -34913,7 +34914,7 @@ __webpack_require__.r(__webpack_exports__);
34913
34914
  /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Scroll", function() { return Scroll; });
34914
34915
  function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
34915
34916
 
34916
- function inserted(el, binding, vnode) {
34917
+ function mounted(el, binding, vnode) {
34917
34918
  var _a = (binding.modifiers || {}).self,
34918
34919
  self = _a === void 0 ? false : _a;
34919
34920
  var value = binding.value;
@@ -34924,8 +34925,9 @@ function inserted(el, binding, vnode) {
34924
34925
  var target = self ? el : binding.arg ? document.querySelector(binding.arg) : window;
34925
34926
  if (!target) return;
34926
34927
  target.addEventListener('scroll', handler, options);
34927
- el._onScroll = Object(el._onScroll);
34928
- el._onScroll[vnode.context._uid] = {
34928
+ el._onScroll = Object(el._onScroll); // В Vue 3 используем vnode.ctx.uid вместо vnode.context._uid
34929
+
34930
+ el._onScroll[vnode.ctx.uid] = {
34929
34931
  handler: handler,
34930
34932
  options: options,
34931
34933
  // Don't reference self
@@ -34933,22 +34935,22 @@ function inserted(el, binding, vnode) {
34933
34935
  };
34934
34936
  }
34935
34937
 
34936
- function unbind(el, binding, vnode) {
34938
+ function unmounted(el, binding, vnode) {
34937
34939
  var _a;
34938
34940
 
34939
- if (!((_a = el._onScroll) === null || _a === void 0 ? void 0 : _a[vnode.context._uid])) return;
34940
- var _b = el._onScroll[vnode.context._uid],
34941
+ if (!((_a = el._onScroll) === null || _a === void 0 ? void 0 : _a[vnode.ctx.uid])) return;
34942
+ var _b = el._onScroll[vnode.ctx.uid],
34941
34943
  handler = _b.handler,
34942
34944
  options = _b.options,
34943
34945
  _c = _b.target,
34944
34946
  target = _c === void 0 ? el : _c;
34945
34947
  target.removeEventListener('scroll', handler, options);
34946
- delete el._onScroll[vnode.context._uid];
34948
+ delete el._onScroll[vnode.ctx.uid];
34947
34949
  }
34948
34950
 
34949
34951
  var Scroll = {
34950
- inserted: inserted,
34951
- unbind: unbind
34952
+ mounted: mounted,
34953
+ unmounted: unmounted
34952
34954
  };
34953
34955
  /* harmony default export */ __webpack_exports__["default"] = (Scroll);
34954
34956
 
@@ -35043,7 +35045,7 @@ function createHandlers(value) {
35043
35045
  };
35044
35046
  }
35045
35047
 
35046
- function inserted(el, binding, vnode) {
35048
+ function mounted(el, binding, vnode) {
35047
35049
  var value = binding.value;
35048
35050
  var target = value.parent ? el.parentElement : el;
35049
35051
  var options = value.options || {
@@ -35059,7 +35061,7 @@ function inserted(el, binding, vnode) {
35059
35061
  });
35060
35062
  }
35061
35063
 
35062
- function unbind(el, binding, vnode) {
35064
+ function unmounted(el, binding, vnode) {
35063
35065
  var target = binding.value.parent ? el.parentElement : el;
35064
35066
  if (!target || !target._touchHandlers) return;
35065
35067
  var handlers = target._touchHandlers[vnode.ctx.uid];
@@ -35070,8 +35072,8 @@ function unbind(el, binding, vnode) {
35070
35072
  }
35071
35073
 
35072
35074
  var Touch = {
35073
- mounted: inserted,
35074
- unmounted: unbind
35075
+ mounted: mounted,
35076
+ unmounted: unmounted
35075
35077
  };
35076
35078
  /* harmony default export */ __webpack_exports__["default"] = (Object(_util_make_directive_activatable__WEBPACK_IMPORTED_MODULE_1__["default"])(Touch));
35077
35079
 
@@ -35144,7 +35146,7 @@ function () {
35144
35146
 
35145
35147
  Vuetify.install = _install__WEBPACK_IMPORTED_MODULE_0__["install"];
35146
35148
  Vuetify.installed = false;
35147
- Vuetify.version = "2.7.2-alpha13";
35149
+ Vuetify.version = "2.7.2-alpha15";
35148
35150
  Vuetify.config = {
35149
35151
  silent: false
35150
35152
  };