eco-vue-js 0.10.39 → 0.10.41

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 (158) hide show
  1. package/dist/components/ActionsBar/WActionsBar.vue.d.ts +0 -1
  2. package/dist/components/ActionsBar/WActionsBar.vue.d.ts.map +1 -1
  3. package/dist/components/ActionsBar/WActionsBar.vue.js +24 -38
  4. package/dist/components/ActionsBar/WActionsBarFilter.vue.d.ts +24 -0
  5. package/dist/components/ActionsBar/WActionsBarFilter.vue.d.ts.map +1 -0
  6. package/dist/components/ActionsBar/WActionsBarFilter.vue.js +25 -0
  7. package/dist/components/ActionsBar/WActionsBarFilter.vue2.js +5 -0
  8. package/dist/components/ActionsBar/use/useActionsBarFilter.d.ts +12 -0
  9. package/dist/components/ActionsBar/use/useActionsBarFilter.d.ts.map +1 -0
  10. package/dist/components/ActionsBar/use/useActionsBarFilter.js +20 -0
  11. package/dist/components/BottomSheet/WBottomSheet.vue.d.ts.map +1 -1
  12. package/dist/components/BottomSheet/WBottomSheet.vue.js +16 -14
  13. package/dist/components/Button/WButtonDropdown.vue.d.ts.map +1 -1
  14. package/dist/components/Button/WButtonDropdown.vue.js +2 -4
  15. package/dist/components/Button/WButtonTab.vue.d.ts +42 -0
  16. package/dist/components/Button/WButtonTab.vue.d.ts.map +1 -0
  17. package/dist/components/Button/WButtonTab.vue.js +135 -0
  18. package/dist/components/Button/WButtonTab.vue2.js +5 -0
  19. package/dist/components/DatePicker/WDatePicker.vue.d.ts.map +1 -1
  20. package/dist/components/DatePicker/WDatePicker.vue.js +4 -2
  21. package/dist/components/DatePicker/WDatePickerSingle.vue.d.ts.map +1 -1
  22. package/dist/components/DatePicker/WDatePickerSingle.vue.js +4 -2
  23. package/dist/components/DatePicker/components/CalendarDay.vue.d.ts +1 -0
  24. package/dist/components/DatePicker/components/CalendarDay.vue.d.ts.map +1 -1
  25. package/dist/components/DatePicker/components/CalendarDay.vue.js +4 -2
  26. package/dist/components/DatePicker/components/CalendarMonth.vue.d.ts +1 -0
  27. package/dist/components/DatePicker/components/CalendarMonth.vue.d.ts.map +1 -1
  28. package/dist/components/DatePicker/components/CalendarMonth.vue.js +7 -4
  29. package/dist/components/DatePicker/components/CalendarWeek.vue.d.ts +1 -0
  30. package/dist/components/DatePicker/components/CalendarWeek.vue.d.ts.map +1 -1
  31. package/dist/components/DatePicker/components/CalendarWeek.vue.js +6 -3
  32. package/dist/components/DropdownMenu/WDropdownMenu.vue.d.ts.map +1 -1
  33. package/dist/components/DropdownMenu/WDropdownMenu.vue.js +4 -6
  34. package/dist/components/DropdownMenu/types.d.ts +0 -1
  35. package/dist/components/DropdownMenu/types.d.ts.map +1 -1
  36. package/dist/components/Expansion/WExpansionItem.vue.d.ts +1 -0
  37. package/dist/components/Expansion/WExpansionItem.vue.d.ts.map +1 -1
  38. package/dist/components/Expansion/WExpansionItem.vue.js +16 -15
  39. package/dist/components/FieldWrapper/WFieldWrapper.vue.js +1 -1
  40. package/dist/components/Form/WForm.vue.d.ts.map +1 -1
  41. package/dist/components/Form/WForm.vue.js +3 -2
  42. package/dist/components/FormAsync/WFormAsyncSelect.vue.js +0 -1
  43. package/dist/components/FormAsync/WFormAsyncSelectInfiniteSingle.vue.js +0 -1
  44. package/dist/components/FormAsync/WFormAsyncSelectSingle.vue.js +0 -1
  45. package/dist/components/FormAsync/WFormAsyncSelectStringified.vue.js +0 -1
  46. package/dist/components/HeaderBar/WHeaderBar.vue.d.ts +1 -18
  47. package/dist/components/HeaderBar/WHeaderBar.vue.d.ts.map +1 -1
  48. package/dist/components/HeaderBar/WHeaderBar.vue.js +30 -79
  49. package/dist/components/HeaderBar/WHeaderBarSearch.vue.d.ts +27 -0
  50. package/dist/components/HeaderBar/WHeaderBarSearch.vue.d.ts.map +1 -0
  51. package/dist/components/HeaderBar/WHeaderBarSearch.vue.js +24 -0
  52. package/dist/components/HeaderBar/WHeaderBarSearch.vue2.js +5 -0
  53. package/dist/components/HeaderBar/use/useHeaderSearch.d.ts +10 -0
  54. package/dist/components/HeaderBar/use/useHeaderSearch.d.ts.map +1 -0
  55. package/dist/components/HeaderBar/use/useHeaderSearch.js +14 -0
  56. package/dist/components/HeaderBar/use/useHeaderSearchVisible.d.ts +5 -0
  57. package/dist/components/HeaderBar/use/useHeaderSearchVisible.d.ts.map +1 -0
  58. package/dist/components/HeaderBar/use/useHeaderSearchVisible.js +14 -0
  59. package/dist/components/InfiniteList/WInfiniteListWrapper.vue.d.ts.map +1 -1
  60. package/dist/components/InfiniteList/WInfiniteListWrapper.vue.js +12 -20
  61. package/dist/components/InfiniteList/components/InfiniteListPages.vue.js +1 -1
  62. package/dist/components/InfiniteList/use/useInfiniteListHeader.d.ts +8 -8
  63. package/dist/components/InfiniteList/use/useInfiniteListHeader.d.ts.map +1 -1
  64. package/dist/components/InfiniteList/use/useInfiniteListHeader.js +16 -3
  65. package/dist/components/Input/WInput.vue.d.ts +2 -1
  66. package/dist/components/Input/WInput.vue.d.ts.map +1 -1
  67. package/dist/components/Input/WInput.vue.js +15 -5
  68. package/dist/components/Input/WInputDate.vue.d.ts +2 -0
  69. package/dist/components/Input/WInputDate.vue.d.ts.map +1 -1
  70. package/dist/components/Input/WInputDate.vue.js +0 -1
  71. package/dist/components/Input/WInputOptions.vue.js +0 -1
  72. package/dist/components/Input/WInputSuggest.vue.d.ts +1 -0
  73. package/dist/components/Input/WInputSuggest.vue.d.ts.map +1 -1
  74. package/dist/components/Input/WInputSuggest.vue.js +5 -3
  75. package/dist/components/List/WList.vue.d.ts +11 -2
  76. package/dist/components/List/WList.vue.d.ts.map +1 -1
  77. package/dist/components/List/WList.vue.js +266 -228
  78. package/dist/components/List/WListHeader.vue.js +1 -1
  79. package/dist/components/List/WListHeaderItem.vue.d.ts +6 -2
  80. package/dist/components/List/WListHeaderItem.vue.d.ts.map +1 -1
  81. package/dist/components/List/WListHeaderItem.vue.js +22 -10
  82. package/dist/components/List/components/HeaderSort.vue.d.ts +3 -1
  83. package/dist/components/List/components/HeaderSort.vue.d.ts.map +1 -1
  84. package/dist/components/List/components/HeaderSort.vue.js +4 -3
  85. package/dist/components/List/components/HeaderSortItem.vue.d.ts +7 -5
  86. package/dist/components/List/components/HeaderSortItem.vue.d.ts.map +1 -1
  87. package/dist/components/List/components/HeaderSortItem.vue.js +23 -10
  88. package/dist/components/List/components/ListFilterGlobal.vue.d.ts +25 -0
  89. package/dist/components/List/components/ListFilterGlobal.vue.d.ts.map +1 -0
  90. package/dist/components/List/components/ListFilterGlobal.vue.js +154 -0
  91. package/dist/components/List/components/ListFilterGlobal.vue2.js +5 -0
  92. package/dist/components/List/components/ListFilterGlobalItem.vue.d.ts +29 -0
  93. package/dist/components/List/components/ListFilterGlobalItem.vue.d.ts.map +1 -0
  94. package/dist/components/List/components/ListFilterGlobalItem.vue.js +49 -0
  95. package/dist/components/List/components/ListFilterGlobalItem.vue2.js +5 -0
  96. package/dist/components/List/components/ListFilterLocal.vue.d.ts +23 -0
  97. package/dist/components/List/components/ListFilterLocal.vue.d.ts.map +1 -0
  98. package/dist/components/List/components/ListFilterLocal.vue.js +148 -0
  99. package/dist/components/List/components/ListFilterLocal.vue2.js +5 -0
  100. package/dist/components/List/components/ListFilterSelect.vue.d.ts +21 -0
  101. package/dist/components/List/components/ListFilterSelect.vue.d.ts.map +1 -0
  102. package/dist/components/List/components/ListFilterSelect.vue.js +72 -0
  103. package/dist/components/List/components/ListFilterSelect.vue2.js +5 -0
  104. package/dist/components/List/models/utils.d.ts +3 -0
  105. package/dist/components/List/models/utils.d.ts.map +1 -0
  106. package/dist/components/List/models/utils.js +7 -0
  107. package/dist/components/List/types.d.ts +11 -0
  108. package/dist/components/List/types.d.ts.map +1 -1
  109. package/dist/components/Modal/WModal.vue.d.ts.map +1 -1
  110. package/dist/components/Modal/WModal.vue.js +8 -7
  111. package/dist/components/Modal/WModalStepper.vue.d.ts +28 -52
  112. package/dist/components/Modal/WModalStepper.vue.d.ts.map +1 -1
  113. package/dist/components/Modal/WModalWrapper.vue.d.ts +102 -0
  114. package/dist/components/Modal/WModalWrapper.vue.d.ts.map +1 -1
  115. package/dist/components/Modal/WModalWrapper.vue.js +15 -5
  116. package/dist/components/Modal/models/injection.d.ts +1 -1
  117. package/dist/components/Modal/models/injection.d.ts.map +1 -1
  118. package/dist/components/Modal/models/injection.js +2 -2
  119. package/dist/components/Nav/WNavBar.vue.d.ts.map +1 -1
  120. package/dist/components/Nav/WNavBar.vue.js +13 -8
  121. package/dist/components/Select/WSelect.vue.d.ts.map +1 -1
  122. package/dist/components/Select/WSelect.vue.js +1 -1
  123. package/dist/components/Select/WSelectAsync.vue.d.ts.map +1 -1
  124. package/dist/components/Select/WSelectAsync.vue.js +6 -2
  125. package/dist/components/Select/WSelectAsyncList.vue.d.ts +2 -2
  126. package/dist/components/Select/WSelectAsyncSingle.vue.js +0 -1
  127. package/dist/components/Select/WSelectSingle.vue.js +0 -1
  128. package/dist/components/Select/WSelectStringified.vue.js +0 -1
  129. package/dist/components/Select/components/SelectAsyncList.vue.d.ts +2 -2
  130. package/dist/components/Tabs/WTabs.vue.d.ts +18 -45
  131. package/dist/components/Tabs/WTabs.vue.d.ts.map +1 -1
  132. package/dist/components/Tabs/WTabs.vue.js +9 -18
  133. package/dist/components/Tabs/components/TabItem.vue.d.ts +1 -1
  134. package/dist/components/Tabs/components/TabItem.vue.d.ts.map +1 -1
  135. package/dist/components/Tabs/components/TabTitleButton.vue.d.ts +2 -14
  136. package/dist/components/Tabs/components/TabTitleButton.vue.d.ts.map +1 -1
  137. package/dist/components/Tabs/components/TabTitleButton.vue.js +19 -119
  138. package/dist/components/Tabs/types.d.ts +2 -1
  139. package/dist/components/Tabs/types.d.ts.map +1 -1
  140. package/dist/imports/componentsPlugin.d.ts +4 -1
  141. package/dist/imports/componentsPlugin.d.ts.map +1 -1
  142. package/dist/main.js +6 -3
  143. package/dist/types/global.d.ts +19 -4
  144. package/dist/utils/api.d.ts +14 -0
  145. package/dist/utils/api.d.ts.map +1 -1
  146. package/dist/utils/api.js +46 -2
  147. package/dist/utils/dateTime.d.ts +1 -0
  148. package/dist/utils/dateTime.d.ts.map +1 -1
  149. package/dist/utils/dateTime.js +4 -1
  150. package/dist/utils/utils.d.ts +16 -1
  151. package/dist/utils/utils.d.ts.map +1 -1
  152. package/dist/utils/utils.js +42 -1
  153. package/package.json +10 -1
  154. package/tailwind-base/plugins/default.ts +7 -4
  155. package/tailwind-base/theme/sizes.ts +6 -0
  156. package/dist/components/List/use/useOrdering.d.ts +0 -7
  157. package/dist/components/List/use/useOrdering.d.ts.map +0 -1
  158. package/dist/components/List/use/useOrdering.js +0 -36
@@ -13,7 +13,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
13
13
  isHoverEnabled: { type: Boolean },
14
14
  disabled: { type: Boolean },
15
15
  minDate: {},
16
- maxDate: {}
16
+ maxDate: {},
17
+ isToday: { type: Boolean }
17
18
  },
18
19
  emits: ["click:day", "hover:day"],
19
20
  setup(__props) {
@@ -84,7 +85,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
84
85
  class: normalizeClass(["square-9 relative flex items-center justify-center rounded-full", {
85
86
  "w-ripple w-ripple-hover": !isDisabled.value,
86
87
  "opacity-50": isDisabled.value,
87
- "bg-primary dark:bg-primary-dark font-semibold": isSelected.value
88
+ "bg-primary dark:bg-primary-dark text-default font-semibold": isSelected.value,
89
+ "bg-negative dark:bg-negative-dark text-default font-semibold": !isSelected.value && _ctx.isToday
88
90
  }])
89
91
  }, [
90
92
  createElementVNode("div", _hoisted_1, toDisplayString(_ctx.startOfDay.getDate()), 1)
@@ -9,6 +9,7 @@ type __VLS_Props = {
9
9
  minDate?: Date;
10
10
  maxDate?: Date;
11
11
  disabled?: boolean;
12
+ today: Date | undefined;
12
13
  };
13
14
  declare const _default: import('vue').DefineComponent<__VLS_Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {} & {
14
15
  "click:day": (value: Date) => any;
@@ -1 +1 @@
1
- {"version":3,"file":"CalendarMonth.vue.d.ts","sourceRoot":"","sources":["../../../../../src/components/DatePicker/components/CalendarMonth.vue"],"names":[],"mappings":"AA8BA;AA2IA,OAAO,KAAK,EAAC,SAAS,EAAC,MAAM,iBAAiB,CAAA;AAI9C,OAAO,EAAC,OAAO,EAAwC,MAAM,kBAAkB,CAAA;AAI/E,KAAK,WAAW,GAAG;IACjB,YAAY,EAAE,IAAI,CAAA;IAClB,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,SAAS,CAAC,EAAE,SAAS,CAAA;IACrB,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,cAAc,EAAE,OAAO,CAAA;IACvB,OAAO,CAAC,EAAE,IAAI,CAAA;IACd,OAAO,CAAC,EAAE,IAAI,CAAA;IACd,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAC;;;;;;;;AA4LF,wBAQG"}
1
+ {"version":3,"file":"CalendarMonth.vue.d.ts","sourceRoot":"","sources":["../../../../../src/components/DatePicker/components/CalendarMonth.vue"],"names":[],"mappings":"AA+BA;AA+IA,OAAO,KAAK,EAAC,SAAS,EAAC,MAAM,iBAAiB,CAAA;AAI9C,OAAO,EAAC,OAAO,EAAoD,MAAM,kBAAkB,CAAA;AAI3F,KAAK,WAAW,GAAG;IACjB,YAAY,EAAE,IAAI,CAAA;IAClB,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,SAAS,CAAC,EAAE,SAAS,CAAA;IACrB,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,cAAc,EAAE,OAAO,CAAA;IACvB,OAAO,CAAC,EAAE,IAAI,CAAA;IACd,OAAO,CAAC,EAAE,IAAI,CAAA;IACd,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,KAAK,EAAE,IAAI,GAAG,SAAS,CAAA;CACxB,CAAC;;;;;;;;AAkMF,wBAQG"}
@@ -1,5 +1,5 @@
1
- import { defineComponent, computed, createElementBlock, openBlock, createElementVNode, Fragment, renderList, toDisplayString, createBlock } from 'vue';
2
- import { getStartOfWeek, weekdayShortFormatter } from '../../../utils/dateTime.js';
1
+ import { defineComponent, computed, createElementBlock, openBlock, createElementVNode, Fragment, renderList, toDisplayString, createBlock, unref } from 'vue';
2
+ import { getStartOfWeek, weekdayShortFormatter, isSameDate } from '../../../utils/dateTime.js';
3
3
  import _sfc_main$1 from './CalendarWeek.vue.js';
4
4
 
5
5
  const _hoisted_1 = { class: "text-accent mb-2 flex text-xs font-semibold" };
@@ -13,11 +13,13 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
13
13
  isHoverEnabled: { type: Boolean },
14
14
  minDate: {},
15
15
  maxDate: {},
16
- disabled: { type: Boolean }
16
+ disabled: { type: Boolean },
17
+ today: {}
17
18
  },
18
19
  emits: ["click:day", "hover:day"],
19
20
  setup(__props) {
20
21
  const props = __props;
22
+ const toWeek = computed(() => props.today ? getStartOfWeek(props.today) : void 0);
21
23
  const startDayOfWeekPrepared = computed(() => props.startDayOfWeek || 1);
22
24
  const startOfFirstWeek = computed(() => {
23
25
  return getStartOfWeek(props.startOfMonth, startDayOfWeekPrepared.value);
@@ -94,9 +96,10 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
94
96
  "min-date": _ctx.minDate,
95
97
  "max-date": _ctx.maxDate,
96
98
  disabled: isDisabled.value,
99
+ today: _ctx.today && toWeek.value && unref(isSameDate)(toWeek.value, week) ? _ctx.today : void 0,
97
100
  "onClick:day": _cache[0] || (_cache[0] = ($event) => _ctx.$emit("click:day", $event)),
98
101
  "onHover:day": _cache[1] || (_cache[1] = ($event) => _ctx.$emit("hover:day", $event))
99
- }, null, 8, ["start-of-month", "start-of-week", "date-range", "is-between", "is-hover-enabled", "min-date", "max-date", "disabled"]);
102
+ }, null, 8, ["start-of-month", "start-of-week", "date-range", "is-between", "is-hover-enabled", "min-date", "max-date", "disabled", "today"]);
100
103
  }), 128))
101
104
  ]);
102
105
  };
@@ -8,6 +8,7 @@ type __VLS_Props = {
8
8
  minDate?: Date;
9
9
  maxDate?: Date;
10
10
  disabled?: boolean;
11
+ today: Date | undefined;
11
12
  };
12
13
  declare const _default: import('vue').DefineComponent<__VLS_Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {} & {
13
14
  "click:day": (value: Date) => any;
@@ -1 +1 @@
1
- {"version":3,"file":"CalendarWeek.vue.d.ts","sourceRoot":"","sources":["../../../../../src/components/DatePicker/components/CalendarWeek.vue"],"names":[],"mappings":"AAmBA;AA4GA,OAAO,KAAK,EAAC,SAAS,EAAC,MAAM,iBAAiB,CAAA;AAM9C,KAAK,WAAW,GAAG;IACjB,YAAY,EAAE,IAAI,CAAA;IAClB,WAAW,EAAE,IAAI,CAAA;IACjB,SAAS,CAAC,EAAE,SAAS,CAAA;IACrB,SAAS,EAAE,OAAO,CAAA;IAClB,cAAc,EAAE,OAAO,CAAA;IACvB,OAAO,CAAC,EAAE,IAAI,CAAA;IACd,OAAO,CAAC,EAAE,IAAI,CAAA;IACd,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAC;;;;;;;;AAiKF,wBAQG"}
1
+ {"version":3,"file":"CalendarWeek.vue.d.ts","sourceRoot":"","sources":["../../../../../src/components/DatePicker/components/CalendarWeek.vue"],"names":[],"mappings":"AAoBA;AAgHA,OAAO,KAAK,EAAC,SAAS,EAAC,MAAM,iBAAiB,CAAA;AAQ9C,KAAK,WAAW,GAAG;IACjB,YAAY,EAAE,IAAI,CAAA;IAClB,WAAW,EAAE,IAAI,CAAA;IACjB,SAAS,CAAC,EAAE,SAAS,CAAA;IACrB,SAAS,EAAE,OAAO,CAAA;IAClB,cAAc,EAAE,OAAO,CAAA;IACvB,OAAO,CAAC,EAAE,IAAI,CAAA;IACd,OAAO,CAAC,EAAE,IAAI,CAAA;IACd,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,KAAK,EAAE,IAAI,GAAG,SAAS,CAAA;CACxB,CAAC;;;;;;;;AAoKF,wBAQG"}
@@ -1,4 +1,5 @@
1
- import { defineComponent, computed, createElementBlock, openBlock, Fragment, renderList, createBlock } from 'vue';
1
+ import { defineComponent, computed, createElementBlock, openBlock, Fragment, renderList, createBlock, unref } from 'vue';
2
+ import { isSameDate } from '../../../utils/dateTime.js';
2
3
  import _sfc_main$1 from './CalendarDay.vue.js';
3
4
 
4
5
  const _hoisted_1 = { class: "flex" };
@@ -12,7 +13,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
12
13
  isHoverEnabled: { type: Boolean },
13
14
  minDate: {},
14
15
  maxDate: {},
15
- disabled: { type: Boolean }
16
+ disabled: { type: Boolean },
17
+ today: {}
16
18
  },
17
19
  emits: ["click:day", "hover:day"],
18
20
  setup(__props) {
@@ -72,9 +74,10 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
72
74
  "min-date": _ctx.minDate,
73
75
  "max-date": _ctx.maxDate,
74
76
  disabled: isDisabled.value,
77
+ "is-today": _ctx.today ? unref(isSameDate)(_ctx.today, day) : false,
75
78
  "onClick:day": _cache[0] || (_cache[0] = ($event) => _ctx.$emit("click:day", $event)),
76
79
  "onHover:day": _cache[1] || (_cache[1] = ($event) => _ctx.$emit("hover:day", $event))
77
- }, null, 8, ["start-of-month", "start-of-day", "date-range", "is-between", "is-week-out-of-month", "is-hover-enabled", "min-date", "max-date", "disabled"]);
80
+ }, null, 8, ["start-of-month", "start-of-day", "date-range", "is-between", "is-week-out-of-month", "is-hover-enabled", "min-date", "max-date", "disabled", "is-today"]);
78
81
  }), 128))
79
82
  ]);
80
83
  };
@@ -1 +1 @@
1
- {"version":3,"file":"WDropdownMenu.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/DropdownMenu/WDropdownMenu.vue"],"names":[],"mappings":"AAgCA;AAsEA,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,SAAS,CAAA;AAC9C,OAAO,KAAK,EAAC,wBAAwB,EAAC,MAAM,6BAA6B,CAAA;AAEzE,OAAO,EAAC,KAAK,KAAK,EAAmC,MAAM,KAAK,CAAA;AAwChE,iBAAS,cAAc;WA2FT,OAAO,IAA6B;;iBA5GvC,MAAM,KAAK,EAAE;kBACZ,CAAC,KAAK,EAAE,wBAAwB,KAAK,KAAK,EAAE;;iBAD7C,MAAM,KAAK,EAAE;kBACZ,CAAC,KAAK,EAAE,wBAAwB,KAAK,KAAK,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wCAsJsljB,GAAG,8CAA8C,GAAG,yBAAyB,GAAG,6DAAmC,GAAG;;;;;;;;;;;;;;EAtCnwjB;AAaD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCAwBynjB,GAAG,8CAA8C,GAAG,yBAAyB,GAAG,6DAAmC,GAAG;;;;;;;;;;;;OAflwjB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAQpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
1
+ {"version":3,"file":"WDropdownMenu.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/DropdownMenu/WDropdownMenu.vue"],"names":[],"mappings":"AAgCA;AAqEA,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,SAAS,CAAA;AAC9C,OAAO,KAAK,EAAC,wBAAwB,EAAC,MAAM,6BAA6B,CAAA;AAEzE,OAAO,EAAC,KAAK,KAAK,EAAmC,MAAM,KAAK,CAAA;AAuChE,iBAAS,cAAc;WA2FT,OAAO,IAA6B;;iBA5GvC,MAAM,KAAK,EAAE;kBACZ,CAAC,KAAK,EAAE,wBAAwB,KAAK,KAAK,EAAE;;iBAD7C,MAAM,KAAK,EAAE;kBACZ,CAAC,KAAK,EAAE,wBAAwB,KAAK,KAAK,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wCAuJonjB,GAAG,8CAA8C,GAAG,yBAAyB,GAAG,6DAAmC,GAAG;;;;;;;;;;;;;;EAvCjyjB;AAcD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oCAwBupjB,GAAG,8CAA8C,GAAG,yBAAyB,GAAG,6DAAmC,GAAG;;;;;;;;;;;;OAfhyjB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAQpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
@@ -1,13 +1,11 @@
1
1
  import { defineComponent, inject, useTemplateRef, computed, createElementBlock, openBlock, Fragment, createBlock, resolveDynamicComponent, unref, mergeProps, Teleport, createCommentVNode, normalizeStyle, withCtx, renderSlot, normalizeProps, guardReactiveProps } from 'vue';
2
2
  import _sfc_main$1 from '../Dropdown/WDropdown.vue.js';
3
- import { wBaseZInfex } from '../Modal/models/injection.js';
4
- import { unwrapSlots } from '../../utils/utils.js';
3
+ import { wBaseZIndex, unwrapSlots, BASE_ZINDEX_DROPDOWN } from '../../utils/utils.js';
5
4
 
6
5
  const _sfc_main = /* @__PURE__ */ defineComponent({
7
6
  __name: "WDropdownMenu",
8
7
  props: {
9
8
  isOpen: { type: Boolean },
10
- teleport: { type: Boolean },
11
9
  parentElement: {},
12
10
  maxHeight: {},
13
11
  maxWidth: {},
@@ -17,7 +15,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
17
15
  },
18
16
  emits: ["update:rect"],
19
17
  setup(__props, { expose: __expose }) {
20
- const baseZInfex = inject(wBaseZInfex, 0);
18
+ const baseZIndex = inject(wBaseZIndex, 0);
21
19
  const containerRef = useTemplateRef("container");
22
20
  const dropdownRef = useTemplateRef("dropdown");
23
21
  const element = computed(() => containerRef.value instanceof HTMLElement ? containerRef.value : containerRef.value?.$el);
@@ -31,7 +29,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
31
29
  (openBlock(), createBlock(resolveDynamicComponent(unref(unwrapSlots)(_ctx.$slots.toggle?.() ?? [])[0]), mergeProps({ ref: "container" }, _ctx.$attrs), null, 16)),
32
30
  (openBlock(), createBlock(Teleport, {
33
31
  to: "body",
34
- disabled: !_ctx.teleport || !_ctx.isOpen
32
+ disabled: !_ctx.isOpen
35
33
  }, [
36
34
  (_ctx.parentElement || element.value) && _ctx.isOpen ? (openBlock(), createBlock(_sfc_main$1, {
37
35
  key: 0,
@@ -42,7 +40,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
42
40
  "max-height": _ctx.maxHeight,
43
41
  "max-width": _ctx.maxWidth,
44
42
  "emit-update": _ctx.emitUpdate,
45
- style: normalizeStyle({ zIndex: _ctx.teleport ? unref(baseZInfex) + 2 : 2 }),
43
+ style: normalizeStyle({ zIndex: unref(baseZIndex) + unref(BASE_ZINDEX_DROPDOWN) }),
46
44
  "onUpdate:rect": _cache[0] || (_cache[0] = ($event) => _ctx.$emit("update:rect"))
47
45
  }, {
48
46
  default: withCtx((defaultScope) => [
@@ -1,7 +1,6 @@
1
1
  import { DropdownProps } from '../Dropdown/types';
2
2
  export interface DropdownMenuProps extends Omit<DropdownProps, 'parentElement'> {
3
3
  isOpen: boolean;
4
- teleport?: boolean;
5
4
  parentElement?: DropdownProps['parentElement'];
6
5
  }
7
6
  //# sourceMappingURL=types.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/DropdownMenu/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,aAAa,EAAC,MAAM,mBAAmB,CAAA;AAEpD,MAAM,WAAW,iBAAkB,SAAQ,IAAI,CAAC,aAAa,EAAE,eAAe,CAAC;IAC7E,MAAM,EAAE,OAAO,CAAA;IACf,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,aAAa,CAAC,EAAE,aAAa,CAAC,eAAe,CAAC,CAAA;CAC/C"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/DropdownMenu/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,aAAa,EAAC,MAAM,mBAAmB,CAAA;AAEpD,MAAM,WAAW,iBAAkB,SAAQ,IAAI,CAAC,aAAa,EAAE,eAAe,CAAC;IAC7E,MAAM,EAAE,OAAO,CAAA;IACf,aAAa,CAAC,EAAE,aAAa,CAAC,eAAe,CAAC,CAAA;CAC/C"}
@@ -5,6 +5,7 @@ type __VLS_Props = {
5
5
  icon?: SVGComponent;
6
6
  hasFlag?: boolean;
7
7
  minTitle?: boolean;
8
+ toggleClass?: string;
8
9
  };
9
10
  declare function __VLS_template(): {
10
11
  attrs: Partial<{}>;
@@ -1 +1 @@
1
- {"version":3,"file":"WExpansionItem.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/Expansion/WExpansionItem.vue"],"names":[],"mappings":"AAuDA;AA4FA,OAAO,EAAC,KAAK,KAAK,EAAiB,MAAM,KAAK,CAAA;AAM9C,KAAK,WAAW,GAAG;IACjB,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,IAAI,CAAC,EAAE,YAAY,CAAA;IACnB,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAC;AAyBF,iBAAS,cAAc;WA0HT,OAAO,IAA6B;;kBA1ItC,MAAM,KAAK,EAAE;gBACf,MAAM,KAAK,EAAE;;kBADX,MAAM,KAAK,EAAE;gBACf,MAAM,KAAK,EAAE;;;;;;EA8ItB;AAYD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;;;;;;OAQnB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAQpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
1
+ {"version":3,"file":"WExpansionItem.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/Expansion/WExpansionItem.vue"],"names":[],"mappings":"AAqDA;AA2FA,OAAO,EAAC,KAAK,KAAK,EAAiB,MAAM,KAAK,CAAA;AAM9C,KAAK,WAAW,GAAG;IACjB,MAAM,CAAC,EAAE,OAAO,CAAA;IAChB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,IAAI,CAAC,EAAE,YAAY,CAAA;IACnB,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,WAAW,CAAC,EAAE,MAAM,CAAA;CACrB,CAAC;AAyBF,iBAAS,cAAc;WA2HT,OAAO,IAA6B;;kBA3ItC,MAAM,KAAK,EAAE;gBACf,MAAM,KAAK,EAAE;;kBADX,MAAM,KAAK,EAAE;gBACf,MAAM,KAAK,EAAE;;;;;;EA+ItB;AAYD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;;;;;;OAQnB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAQpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
@@ -1,13 +1,12 @@
1
- import { defineComponent, useTemplateRef, createElementBlock, openBlock, Fragment, createBlock, createVNode, resolveDynamicComponent, withKeys, withCtx, createCommentVNode, createElementVNode, normalizeClass, createTextVNode, toDisplayString, Transition, unref, renderSlot } from 'vue';
1
+ import { defineComponent, useTemplateRef, createElementBlock, openBlock, Fragment, createBlock, createVNode, resolveDynamicComponent, withKeys, normalizeClass, withCtx, createElementVNode, createCommentVNode, createTextVNode, toDisplayString, Transition, unref, renderSlot } from 'vue';
2
2
  import IconArrow from '../../assets/icons/default/IconArrow.svg.js';
3
3
  import _sfc_main$1 from './WExpansion.vue.js';
4
4
 
5
- const _hoisted_1 = { class: "col-start-2 mr-2" };
6
- const _hoisted_2 = {
5
+ const _hoisted_1 = {
7
6
  key: 0,
8
7
  class: "square-2 bg-info dark:bg-info-dark absolute right-0 top-0 rounded-full"
9
8
  };
10
- const _hoisted_3 = { class: "col-start-3 ml-auto flex items-center justify-center" };
9
+ const _hoisted_2 = { class: "col-start-3 ml-auto flex items-center justify-center" };
11
10
  const _sfc_main = /* @__PURE__ */ defineComponent({
12
11
  __name: "WExpansionItem",
13
12
  props: {
@@ -15,7 +14,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
15
14
  title: {},
16
15
  icon: {},
17
16
  hasFlag: { type: Boolean },
18
- minTitle: { type: Boolean }
17
+ minTitle: { type: Boolean },
18
+ toggleClass: {}
19
19
  },
20
20
  emits: ["toggle"],
21
21
  setup(__props, { emit: __emit }) {
@@ -32,7 +32,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
32
32
  ref: "button",
33
33
  role: "button",
34
34
  tabindex: "0",
35
- class: "w-ripple w-ripple-hover -px--inner-margin -mx---inner-margin relative grid cursor-pointer select-none grid-cols-[auto,1fr,auto] items-center py-3 text-start",
35
+ class: normalizeClass(["w-ripple w-ripple-hover -px--inner-margin relative grid cursor-pointer select-none grid-cols-[1fr,auto] items-center gap-2 py-3 text-start", _ctx.toggleClass]),
36
36
  onClick: toggle,
37
37
  onKeydown: [
38
38
  withKeys(toggle, ["enter"]),
@@ -40,11 +40,12 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
40
40
  ]
41
41
  }, {
42
42
  default: withCtx(() => [
43
- _ctx.icon ? (openBlock(), createBlock(resolveDynamicComponent(_ctx.icon), {
44
- key: 0,
45
- class: "square-[1.5em] mr-2"
46
- })) : createCommentVNode("", true),
47
- createElementVNode("div", _hoisted_1, [
43
+ createElementVNode("div", null, [
44
+ _ctx.icon ? (openBlock(), createBlock(resolveDynamicComponent(_ctx.icon), {
45
+ key: 0,
46
+ class: "square-[1.25em] -mt-1 inline"
47
+ })) : createCommentVNode("", true),
48
+ _cache[0] || (_cache[0] = createTextVNode()),
48
49
  createElementVNode("span", {
49
50
  class: normalizeClass(["relative pr-4 font-semibold", { "text-xs": _ctx.minTitle }])
50
51
  }, [
@@ -56,23 +57,23 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
56
57
  "leave-to-class": "opacity-0"
57
58
  }, {
58
59
  default: withCtx(() => [
59
- _ctx.hasFlag ? (openBlock(), createElementBlock("div", _hoisted_2)) : createCommentVNode("", true)
60
+ _ctx.hasFlag ? (openBlock(), createElementBlock("div", _hoisted_1)) : createCommentVNode("", true)
60
61
  ]),
61
62
  _: 1
62
63
  })
63
64
  ], 2)
64
65
  ]),
65
- createElementVNode("div", _hoisted_3, [
66
+ createElementVNode("div", _hoisted_2, [
66
67
  createVNode(unref(IconArrow), {
67
68
  class: normalizeClass(["text-accent square-[1.25em] transition-transform", { "rotate-180": _ctx.isOpen }])
68
69
  }, null, 8, ["class"])
69
70
  ])
70
71
  ]),
71
72
  _: 1
72
- }, 544)),
73
+ }, 40, ["class"])),
73
74
  createVNode(_sfc_main$1, {
74
75
  "is-open": _ctx.isOpen,
75
- class: normalizeClass([_ctx.$attrs.class, "-px--inner-margin -mx---inner-margin py-2"])
76
+ class: normalizeClass([_ctx.$attrs.class, "py-2"])
76
77
  }, {
77
78
  default: withCtx(() => [
78
79
  renderSlot(_ctx.$slots, "default")
@@ -70,7 +70,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
70
70
  return (_ctx, _cache) => {
71
71
  return openBlock(), createElementBlock("div", mergeProps({ class: "group/field relative" }, { class: _ctx.$attrs.class, style: _ctx.$attrs.style }, {
72
72
  class: {
73
- "mb-[1.125rem] mt-1": !_ctx.noMargin && !_ctx.subgrid,
73
+ "mb-[1.125rem]": !_ctx.noMargin && !_ctx.subgrid,
74
74
  "col-span-full grid grid-cols-subgrid": _ctx.subgrid
75
75
  },
76
76
  onClick: _cache[0] || (_cache[0] = ($event) => _ctx.$emit("click", $event))
@@ -1 +1 @@
1
- {"version":3,"file":"WForm.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/WForm.vue"],"names":[],"mappings":"AAKA;AA+KA,OAAO,EAAC,KAAK,YAAY,EAAiB,MAAM,gBAAgB,CAAA;AAGhE,KAAK,WAAW,GAAG;IACjB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,KAAK,CAAC,EAAE,OAAO,CAAA;CAChB,CAAC;AA0KF,iBAAS,cAAc;WA6BT,OAAO,IAA6B;;yBAVrB,GAAG;;;;EAe/B;AAUD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;kFASnB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAQpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
1
+ {"version":3,"file":"WForm.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/WForm.vue"],"names":[],"mappings":"AAKA;AAiLA,OAAO,EAAC,KAAK,YAAY,EAAiB,MAAM,gBAAgB,CAAA;AAGhE,KAAK,WAAW,GAAG;IACjB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,KAAK,CAAC,EAAE,OAAO,CAAA;CAChB,CAAC;AA4KF,iBAAS,cAAc;WA6BT,OAAO,IAA6B;;yBAVrB,GAAG;;;;EAe/B;AAUD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;;kFASnB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAQpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
@@ -1,4 +1,4 @@
1
- import { defineComponent, toRef, computed, provide, inject, watch, onBeforeUnmount, createBlock, openBlock, resolveDynamicComponent, withCtx, renderSlot } from 'vue';
1
+ import { defineComponent, toRef, computed, inject, provide, watch, onBeforeUnmount, createBlock, openBlock, resolveDynamicComponent, withCtx, renderSlot } from 'vue';
2
2
  import _sfc_main$1 from '../EmptyComponent/WEmptyComponent.vue.js';
3
3
  import { wFormTitleUpdater, wFormUnlistener, wFormErrorMessageUpdater, wFormHasChangesUpdater, wFormHasValueUpdater, wFormHasShownUpdater, wFormInitModelUpdater, wFormInvalidateUpdater, wFormValidateUpdater } from './models/injection.js';
4
4
  import { compileMessage } from './models/utils.js';
@@ -82,6 +82,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
82
82
  });
83
83
  }
84
84
  );
85
+ const unlistenerInjected = inject(wFormUnlistener, void 0);
85
86
  const unlistener = (key) => {
86
87
  titleMap.unlistener(key);
87
88
  errorMessageMap.unlistener(key);
@@ -91,9 +92,9 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
91
92
  validateMap.unlistener(key);
92
93
  invalidateMap.unlistener(key);
93
94
  initModelMap.unlistener(key);
95
+ if (!props.name) unlistenerInjected?.(key);
94
96
  };
95
97
  provide(wFormUnlistener, unlistener);
96
- const unlistenerInjected = inject(wFormUnlistener, void 0);
97
98
  watch(errorMessageMap.map, () => emit("update:is-valid", isValid.value));
98
99
  watch(hasChangesMap.value, (value) => emit("update:has-changes", value));
99
100
  watch(hasValueMap.value, (value) => emit("update:has-value", value));
@@ -60,7 +60,6 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
60
60
  filterValue: {},
61
61
  subgrid: { type: Boolean },
62
62
  seamless: { type: Boolean },
63
- teleport: { type: Boolean },
64
63
  parentElement: {},
65
64
  maxHeight: {},
66
65
  maxWidth: {},
@@ -65,7 +65,6 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
65
65
  filterValue: {},
66
66
  subgrid: { type: Boolean },
67
67
  seamless: { type: Boolean },
68
- teleport: { type: Boolean },
69
68
  parentElement: {},
70
69
  maxHeight: {},
71
70
  maxWidth: {},
@@ -61,7 +61,6 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
61
61
  filterValue: {},
62
62
  subgrid: { type: Boolean },
63
63
  seamless: { type: Boolean },
64
- teleport: { type: Boolean },
65
64
  parentElement: {},
66
65
  maxHeight: {},
67
66
  maxWidth: {},
@@ -61,7 +61,6 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
61
61
  filterValue: {},
62
62
  subgrid: { type: Boolean },
63
63
  seamless: { type: Boolean },
64
- teleport: { type: Boolean },
65
64
  parentElement: {},
66
65
  maxHeight: {},
67
66
  maxWidth: {},
@@ -1,22 +1,13 @@
1
1
  type __VLS_Props = {
2
2
  title?: string;
3
- search?: string;
4
- searchEnabled?: boolean;
5
3
  };
6
4
  declare function __VLS_template(): {
7
5
  attrs: Partial<{}>;
8
6
  slots: {
9
7
  title?(_: {}): any;
10
- search?(_: {}): any;
11
- search?(_: {}): any;
12
8
  };
13
9
  refs: {
14
10
  element: HTMLDivElement;
15
- input: import('vue').ShallowUnwrapRef<{
16
- focus: () => void;
17
- blur: () => void;
18
- fieldRef: import('vue').ComputedRef<HTMLDivElement | null | undefined>;
19
- }> | null;
20
11
  };
21
12
  rootEl: HTMLDivElement;
22
13
  };
@@ -25,16 +16,8 @@ declare const __VLS_component: import('vue').DefineComponent<__VLS_Props, {}, {}
25
16
  "update:search": (value: string | undefined) => any;
26
17
  }, string, import('vue').PublicProps, Readonly<__VLS_Props> & Readonly<{
27
18
  "onUpdate:search"?: ((value: string | undefined) => any) | undefined;
28
- }>, {
29
- title: string;
30
- search: string;
31
- }, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {
19
+ }>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {
32
20
  element: HTMLDivElement;
33
- input: import('vue').ShallowUnwrapRef<{
34
- focus: () => void;
35
- blur: () => void;
36
- fieldRef: import('vue').ComputedRef<HTMLDivElement | null | undefined>;
37
- }> | null;
38
21
  }, HTMLDivElement>;
39
22
  declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, __VLS_TemplateResult["slots"]>;
40
23
  export default _default;
@@ -1 +1 @@
1
- {"version":3,"file":"WHeaderBar.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/HeaderBar/WHeaderBar.vue"],"names":[],"mappings":"AAsFA;AA2KA,KAAK,WAAW,GAAG;IACf,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,aAAa,CAAC,EAAE,OAAO,CAAA;CACxB,CAAC;AA+DJ,iBAAS,cAAc;WA+LT,OAAO,IAA6B;;uBAdvB,GAAG;wBACD,GAAG;wBACH,GAAG;;;;;;;;;;;EAiB/B;AAqBD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;;;;;WA5RT,MAAM;YACL,MAAM;;;;;;;;kBAqSjB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAapG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
1
+ {"version":3,"file":"WHeaderBar.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/HeaderBar/WHeaderBar.vue"],"names":[],"mappings":"AAoDA;AA+GA,KAAK,WAAW,GAAG;IACjB,KAAK,CAAC,EAAE,MAAM,CAAA;CACf,CAAC;AAqCF,iBAAS,cAAc;WAqFT,OAAO,IAA6B;;uBAXvB,GAAG;;;;;;EAgB7B;AAgBD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;;;;;;kBASnB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAQpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
@@ -1,47 +1,29 @@
1
- import { defineComponent, useTemplateRef, ref, watch, toRef, onMounted, onBeforeUnmount, createElementBlock, openBlock, withDirectives, createCommentVNode, normalizeStyle, normalizeClass, unref, createElementVNode, renderSlot, createTextVNode, toDisplayString, createVNode, vShow, createBlock, markRaw, createSlots, withCtx, Fragment, nextTick } from 'vue';
2
- import _sfc_main$2 from '../Input/WInput.vue.js';
3
- import _sfc_main$1 from '../Input/WInputSuggest.vue.js';
1
+ import { defineComponent, provide, useTemplateRef, ref, onMounted, onBeforeUnmount, createElementBlock, openBlock, normalizeStyle, unref, withDirectives, createCommentVNode, normalizeClass, createElementVNode, renderSlot, createTextVNode, toDisplayString, createVNode, vShow, Fragment, renderList, createBlock, resolveDynamicComponent } from 'vue';
4
2
  import IconSearch from '../../assets/icons/sax/IconSearch.svg.js';
5
- import { useIsMobile } from '../../utils/mobile.js';
3
+ import { wBaseZIndex, BASE_ZINDEX_HEADER_BAR } from '../../utils/utils.js';
6
4
  import { useHeader } from './use/useHeader.js';
5
+ import { useHeaderSearch } from './use/useHeaderSearch.js';
6
+ import { useHeaderSearchVisible } from './use/useHeaderSearchVisible.js';
7
7
 
8
- const _hoisted_1 = {
9
- ref: "element",
10
- class: "-h--header-height fixed inset-x-0 top-0 z-10 flex print:hidden"
11
- };
12
- const _hoisted_2 = { class: "text-accent sm:text-2.5xl flex-1 truncate text-xl font-semibold" };
13
- const _hoisted_3 = { class: "w-ripple w-ripple-hover sm-not:-px--inner-margin relative flex h-full items-center px-[--w-list-padding,1rem]" };
14
- const _hoisted_4 = {
8
+ const _hoisted_1 = { class: "text-accent sm:text-2.5xl flex-1 truncate text-xl font-semibold" };
9
+ const _hoisted_2 = { class: "w-ripple w-ripple-hover sm-not:-px--inner-margin relative flex h-full items-center px-[--w-list-padding,1rem]" };
10
+ const _hoisted_3 = {
15
11
  key: 0,
16
- class: "xl-not:pl-[3.75rem] -px--inner-margin relative flex w-full flex-1 items-center gap-2"
12
+ class: "xl-not:-pl--header-height -px--inner-margin grid items-center"
17
13
  };
18
14
  const _sfc_main = /* @__PURE__ */ defineComponent({
19
15
  __name: "WHeaderBar",
20
16
  props: {
21
- title: { default: void 0 },
22
- search: { default: void 0 },
23
- searchEnabled: { type: Boolean }
17
+ title: {}
24
18
  },
25
19
  emits: ["update:search"],
26
20
  setup(__props) {
27
- const props = __props;
28
- const { isMobile } = useIsMobile();
21
+ provide(wBaseZIndex, BASE_ZINDEX_HEADER_BAR);
29
22
  const { headerPadding, updateHeaderHeight } = useHeader();
23
+ const { search } = useHeaderSearch();
24
+ const { visible, updateVisible } = useHeaderSearchVisible();
30
25
  const elementRef = useTemplateRef("element");
31
- const inputRef = useTemplateRef("input");
32
26
  const isTransparent = ref(false);
33
- const isSearchVisible = ref(false);
34
- const openSearch = () => {
35
- isSearchVisible.value = true;
36
- nextTick().then(() => inputRef.value?.focus());
37
- };
38
- const closeSearch = () => {
39
- isSearchVisible.value = false;
40
- };
41
- watch(toRef(props, "searchEnabled"), (value) => {
42
- if (value) return;
43
- isSearchVisible.value = false;
44
- });
45
27
  let timeout;
46
28
  onMounted(() => {
47
29
  timeout = setTimeout(() => {
@@ -56,7 +38,11 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
56
38
  timeout = void 0;
57
39
  });
58
40
  return (_ctx, _cache) => {
59
- return openBlock(), createElementBlock("div", _hoisted_1, [
41
+ return openBlock(), createElementBlock("div", {
42
+ ref: "element",
43
+ class: "-h--header-height fixed inset-x-0 top-0 grid grid-cols-1 print:hidden",
44
+ style: normalizeStyle({ zIndex: unref(BASE_ZINDEX_HEADER_BAR) })
45
+ }, [
60
46
  (openBlock(), createElementBlock("div", {
61
47
  key: unref(headerPadding),
62
48
  class: normalizeClass(["bg-default dark:bg-default-dark supports-backdrop:backdrop-blur fixed inset-x-0 top-0 h-[calc(var(--header-height)+var(--header-height-padding))] print:hidden", {
@@ -65,70 +51,35 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
65
51
  style: normalizeStyle({ "--header-height-padding": unref(headerPadding) + "px" })
66
52
  }, null, 6)),
67
53
  withDirectives(createElementVNode("div", {
68
- class: normalizeClass(["-pl--inner-margin xl-not:-pl--header-height relative flex max-w-full flex-1 items-center", {
69
- "-pr--inner-margin": !_ctx.searchEnabled
54
+ class: normalizeClass(["-pl--inner-margin xl-not:-pl--header-height relative flex items-center", {
55
+ "-pr--inner-margin": !unref(search)
70
56
  }])
71
57
  }, [
72
- createElementVNode("div", _hoisted_2, [
58
+ createElementVNode("div", _hoisted_1, [
73
59
  renderSlot(_ctx.$slots, "title", {}, () => [
74
60
  createTextVNode(toDisplayString(_ctx.title), 1)
75
61
  ])
76
62
  ]),
77
- _ctx.searchEnabled ? (openBlock(), createElementBlock("button", {
63
+ unref(search) ? (openBlock(), createElementBlock("button", {
78
64
  key: 0,
79
65
  class: "w-ripple-trigger sm:-pr--inner-margin h-full select-none",
80
- onClick: openSearch
66
+ onClick: _cache[0] || (_cache[0] = ($event) => unref(updateVisible)(true))
81
67
  }, [
82
- createElementVNode("div", _hoisted_3, [
68
+ createElementVNode("div", _hoisted_2, [
83
69
  createVNode(unref(IconSearch), { class: "square-[1.25em] text-accent" })
84
70
  ])
85
71
  ])) : createCommentVNode("", true)
86
72
  ], 2), [
87
- [vShow, !isSearchVisible.value && !_ctx.search]
73
+ [vShow, !unref(visible)]
88
74
  ]),
89
- _ctx.searchEnabled ? withDirectives((openBlock(), createElementBlock("div", _hoisted_4, [
90
- _ctx.$slots.search && unref(isMobile) ? (openBlock(), createBlock(_sfc_main$1, {
91
- key: 0,
92
- ref: "input",
93
- "model-value": _ctx.search,
94
- placeholder: "Search..",
95
- "allow-clear": "",
96
- persist: "",
97
- teleport: "",
98
- "no-margin": "",
99
- class: "w-full",
100
- icon: markRaw(unref(IconSearch)),
101
- "onClick:clear": _cache[0] || (_cache[0] = ($event) => !unref(isMobile) && unref(inputRef)?.close()),
102
- onClose: closeSearch,
103
- "onUpdate:modelValue": _cache[1] || (_cache[1] = ($event) => _ctx.$emit("update:search", $event))
104
- }, createSlots({ _: 2 }, [
105
- unref(isMobile) ? {
106
- name: "content",
107
- fn: withCtx(() => [
108
- renderSlot(_ctx.$slots, "search")
109
- ]),
110
- key: "0"
111
- } : void 0
112
- ]), 1032, ["model-value", "icon"])) : (openBlock(), createElementBlock(Fragment, { key: 1 }, [
113
- createVNode(_sfc_main$2, {
114
- ref: "input",
115
- "model-value": _ctx.search,
116
- placeholder: "Search..",
117
- autofocus: "",
118
- "allow-clear": "",
119
- "no-margin": "",
120
- class: "w-full",
121
- icon: markRaw(unref(IconSearch)),
122
- "onClick:clear": closeSearch,
123
- onClose: _cache[2] || (_cache[2] = ($event) => _ctx.$route.meta.headerSearchComponent && closeSearch()),
124
- "onUpdate:modelValue": _cache[3] || (_cache[3] = ($event) => _ctx.$emit("update:search", $event))
125
- }, null, 8, ["model-value", "icon"]),
126
- renderSlot(_ctx.$slots, "search")
127
- ], 64))
75
+ unref(search) ? withDirectives((openBlock(), createElementBlock("div", _hoisted_3, [
76
+ (openBlock(true), createElementBlock(Fragment, null, renderList(unref(search), (slot, index) => {
77
+ return openBlock(), createBlock(resolveDynamicComponent(slot), { key: index });
78
+ }), 128))
128
79
  ], 512)), [
129
- [vShow, isSearchVisible.value || _ctx.search]
80
+ [vShow, unref(visible)]
130
81
  ]) : createCommentVNode("", true)
131
- ], 512);
82
+ ], 4);
132
83
  };
133
84
  }
134
85
  });
@@ -0,0 +1,27 @@
1
+ import { VNode } from 'vue';
2
+ declare function __VLS_template(): {
3
+ attrs: Partial<{}>;
4
+ slots: Readonly<{
5
+ default: (props: {
6
+ visible?: boolean;
7
+ hide?: () => void;
8
+ }) => VNode[];
9
+ }> & {
10
+ default: (props: {
11
+ visible?: boolean;
12
+ hide?: () => void;
13
+ }) => VNode[];
14
+ };
15
+ refs: {};
16
+ rootEl: any;
17
+ };
18
+ type __VLS_TemplateResult = ReturnType<typeof __VLS_template>;
19
+ declare const __VLS_component: import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
20
+ declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, __VLS_TemplateResult["slots"]>;
21
+ export default _default;
22
+ type __VLS_WithTemplateSlots<T, S> = T & {
23
+ new (): {
24
+ $slots: S;
25
+ };
26
+ };
27
+ //# sourceMappingURL=WHeaderBarSearch.vue.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"WHeaderBarSearch.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/HeaderBar/WHeaderBarSearch.vue"],"names":[],"mappings":"AA6BA,OAAO,EAAC,KAAK,KAAK,EAA6C,MAAM,KAAK,CAAA;AA6B1E,iBAAS,cAAc;WAYT,OAAO,IAA6B;;iBAjBvC,CAAC,KAAK,EAAE;YAAC,OAAO,CAAC,EAAE,OAAO,CAAC;YAAC,IAAI,CAAC,EAAE,MAAM,IAAI,CAAA;SAAC,KAAK,KAAK,EAAE;;iBAA1D,CAAC,KAAK,EAAE;YAAC,OAAO,CAAC,EAAE,OAAO,CAAC;YAAC,IAAI,CAAC,EAAE,MAAM,IAAI,CAAA;SAAC,KAAK,KAAK,EAAE;;;;EAsBpE;AAOD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe,+QAKnB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAEpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
@@ -0,0 +1,24 @@
1
+ import { defineComponent, useSlots, computed, watch, onBeforeUnmount } from 'vue';
2
+ import { useHeaderSearch } from './use/useHeaderSearch.js';
3
+ import { useHeaderSearchVisible } from './use/useHeaderSearchVisible.js';
4
+
5
+ const _sfc_main = /* @__PURE__ */ defineComponent({
6
+ __name: "WHeaderBarSearch",
7
+ setup(__props) {
8
+ const slots = useSlots();
9
+ const { visible, updateVisible } = useHeaderSearchVisible();
10
+ const hide = () => {
11
+ updateVisible(false);
12
+ };
13
+ const slotsDefault = computed(() => slots.default?.({ visible: visible.value, hide }));
14
+ const { updateHeaderSearch } = useHeaderSearch();
15
+ watch(slotsDefault, updateHeaderSearch, { immediate: true });
16
+ onBeforeUnmount(() => {
17
+ updateHeaderSearch(void 0);
18
+ });
19
+ return () => {
20
+ };
21
+ }
22
+ });
23
+
24
+ export { _sfc_main as default };
@@ -0,0 +1,5 @@
1
+ import _sfc_main from './WHeaderBarSearch.vue.js';
2
+
3
+
4
+
5
+ export { _sfc_main as default };