yuyeon 0.1.0-rc.9 → 0.1.0

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 (242) hide show
  1. package/dist/style.css +1 -1
  2. package/dist/yuyeon.js +4606 -4024
  3. package/dist/yuyeon.umd.cjs +17 -13
  4. package/lib/components/badge/YBadge.scss +0 -1
  5. package/lib/components/card/YCard.mjs +16 -9
  6. package/lib/components/card/YCard.mjs.map +1 -1
  7. package/lib/components/dialog/YDialog.mjs +4 -1
  8. package/lib/components/dialog/YDialog.mjs.map +1 -1
  9. package/lib/components/dropdown/YDropdown.mjs +10 -4
  10. package/lib/components/dropdown/YDropdown.mjs.map +1 -1
  11. package/lib/components/field-input/YFieldInput.mjs.map +1 -1
  12. package/lib/components/field-input/YFieldInput.scss +1 -1
  13. package/lib/components/hover/YHover.mjs +11 -4
  14. package/lib/components/hover/YHover.mjs.map +1 -1
  15. package/lib/components/hover/index.mjs +2 -0
  16. package/lib/components/hover/index.mjs.map +1 -0
  17. package/lib/components/index.mjs +3 -0
  18. package/lib/components/index.mjs.map +1 -1
  19. package/lib/components/input/YInput.scss +1 -1
  20. package/lib/components/ip-field/YIpField.scss +74 -0
  21. package/lib/components/ip-field/YIpv4Field.mjs +297 -0
  22. package/lib/components/ip-field/YIpv4Field.mjs.map +1 -0
  23. package/lib/components/ip-field/index.mjs +2 -0
  24. package/lib/components/ip-field/index.mjs.map +1 -0
  25. package/lib/components/layer/YLayer.mjs +32 -12
  26. package/lib/components/layer/YLayer.mjs.map +1 -1
  27. package/lib/components/layer/base.mjs +1 -1
  28. package/lib/components/layer/base.mjs.map +1 -1
  29. package/lib/components/layer/content.mjs +22 -0
  30. package/lib/components/layer/content.mjs.map +1 -0
  31. package/lib/components/layer/scroll-strategies.mjs +1 -1
  32. package/lib/components/layer/scroll-strategies.mjs.map +1 -1
  33. package/lib/components/list/YListItem.mjs +1 -0
  34. package/lib/components/list/YListItem.mjs.map +1 -1
  35. package/lib/components/menu/YMenu.mjs +6 -11
  36. package/lib/components/menu/YMenu.mjs.map +1 -1
  37. package/lib/components/panel/YDividePanel.scss +1 -1
  38. package/lib/components/select/YSelect.mjs +8 -5
  39. package/lib/components/select/YSelect.mjs.map +1 -1
  40. package/lib/components/snackbar/YSnackbar.mjs +42 -37
  41. package/lib/components/snackbar/YSnackbar.mjs.map +1 -1
  42. package/lib/components/tab/YTab.scss +3 -3
  43. package/lib/components/tab/types.mjs.map +1 -1
  44. package/lib/components/table/YDataTableBody.mjs +1 -1
  45. package/lib/components/table/YDataTableBody.mjs.map +1 -1
  46. package/lib/components/table/YDataTableRow.mjs +30 -3
  47. package/lib/components/table/YDataTableRow.mjs.map +1 -1
  48. package/lib/components/table/composibles/header.mjs +1 -1
  49. package/lib/components/table/composibles/header.mjs.map +1 -1
  50. package/lib/components/table/composibles/items.mjs +3 -1
  51. package/lib/components/table/composibles/items.mjs.map +1 -1
  52. package/lib/components/table/composibles/selection.mjs.map +1 -1
  53. package/lib/components/table/composibles/sorting.mjs.map +1 -1
  54. package/lib/components/table/types/common.mjs.map +1 -1
  55. package/lib/components/table/types/header.mjs.map +1 -1
  56. package/lib/components/text-interpolation/YTi.mjs +46 -0
  57. package/lib/components/text-interpolation/YTi.mjs.map +1 -0
  58. package/lib/components/text-interpolation/index.mjs +2 -0
  59. package/lib/components/text-interpolation/index.mjs.map +1 -0
  60. package/lib/components/textarea/YTextarea.mjs +3 -1
  61. package/lib/components/textarea/YTextarea.mjs.map +1 -1
  62. package/lib/components/tooltip/YTooltip.mjs +1 -0
  63. package/lib/components/tooltip/YTooltip.mjs.map +1 -1
  64. package/lib/components/tree-view/YTreeViewNode.mjs +47 -21
  65. package/lib/components/tree-view/YTreeViewNode.mjs.map +1 -1
  66. package/lib/composables/coordinate/index.mjs.map +1 -1
  67. package/lib/composables/coordinate/levitation.mjs.map +1 -1
  68. package/lib/composables/icon.mjs.map +1 -1
  69. package/lib/composables/index.mjs +1 -0
  70. package/lib/composables/index.mjs.map +1 -1
  71. package/lib/composables/theme/index.mjs +6 -3
  72. package/lib/composables/theme/index.mjs.map +1 -1
  73. package/lib/index.mjs +1 -1
  74. package/lib/index.mjs.map +1 -1
  75. package/lib/util/parser.mjs +31 -0
  76. package/lib/util/parser.mjs.map +1 -0
  77. package/lib/util/string.mjs +30 -0
  78. package/lib/util/string.mjs.map +1 -1
  79. package/package.json +12 -11
  80. package/types/abstract/items.d.ts +5 -4
  81. package/types/components/alert/YAlert.d.ts +3 -2
  82. package/types/components/app/YApp.d.ts +3 -2
  83. package/types/components/badge/YBadge.d.ts +9 -8
  84. package/types/components/bench/YBench.d.ts +4 -0
  85. package/types/components/bench/index.d.ts +1 -0
  86. package/types/components/button/YButton.d.ts +27 -29
  87. package/types/components/card/YCard.d.ts +6 -3
  88. package/types/components/card/YCardBody.d.ts +1 -1
  89. package/types/components/card/YCardFooter.d.ts +1 -1
  90. package/types/components/card/YCardHeader.d.ts +1 -1
  91. package/types/components/checkbox/YCheckbox.d.ts +4 -3
  92. package/types/components/checkbox/YInputCheckbox.d.ts +7 -6
  93. package/types/components/checkbox/index.d.ts +1 -1
  94. package/types/components/chip/YChip.d.ts +3 -2
  95. package/types/components/date-picker/YDateCalendar.d.ts +16 -15
  96. package/types/components/date-picker/YDatePicker.d.ts +41 -40
  97. package/types/components/date-picker/YDatePickerControl.d.ts +29 -28
  98. package/types/components/date-picker/YMonthPicker.d.ts +6 -5
  99. package/types/components/date-picker/YYearPicker.d.ts +3 -2
  100. package/types/components/default-provider/YDefaultProvider.d.ts +0 -0
  101. package/types/components/default-provider/index.d.ts +0 -0
  102. package/types/components/dialog/YDialog.d.ts +416 -335
  103. package/types/components/divider/YDivider.d.ts +4 -3
  104. package/types/components/dropdown/YDropdown.d.ts +507 -61
  105. package/types/components/field-input/YFieldInput.d.ts +27 -26
  106. package/types/components/form/YForm.d.ts +9 -8
  107. package/types/components/hover/YHover.d.ts +79 -0
  108. package/types/components/hover/index.d.ts +1 -0
  109. package/types/components/icon/YIcon.d.ts +5 -4
  110. package/types/components/icons/YIconCheckbox.d.ts +5 -4
  111. package/types/components/icons/YIconClear.d.ts +1 -1
  112. package/types/components/icons/YIconDropdown.d.ts +1 -1
  113. package/types/components/icons/YIconExpand.d.ts +1 -1
  114. package/types/components/icons/YIconPageControl.d.ts +6 -5
  115. package/types/components/icons/YIconSort.d.ts +5 -4
  116. package/types/components/icons/index.d.ts +26 -26
  117. package/types/components/index.d.ts +3 -0
  118. package/types/components/input/YInput.d.ts +21 -20
  119. package/types/components/ip-field/YIpv4Field.d.ts +133 -0
  120. package/types/components/ip-field/index.d.ts +1 -0
  121. package/types/components/layer/YLayer.d.ts +154 -106
  122. package/types/components/layer/active-stack.d.ts +3 -2
  123. package/types/components/layer/base.d.ts +8 -7
  124. package/types/components/layer/content.d.ts +21 -0
  125. package/types/components/layer/scroll-strategies.d.ts +41 -0
  126. package/types/components/list/YList.d.ts +8 -7
  127. package/types/components/list/YListItem.d.ts +19 -13
  128. package/types/components/loading/YSpinnerRing.d.ts +2 -1
  129. package/types/components/menu/YMenu.d.ts +175 -125
  130. package/types/components/navigation/YNavigation.d.ts +1 -0
  131. package/types/components/navigation/index.d.ts +1 -0
  132. package/types/components/pagination/YPagination.d.ts +20 -19
  133. package/types/components/panel/YDividePanel.d.ts +4 -3
  134. package/types/components/plate/YPlate.d.ts +3 -2
  135. package/types/components/progress-bar/YProgressBar.d.ts +5 -4
  136. package/types/components/select/YSelect.d.ts +1304 -944
  137. package/types/components/snackbar/YSnackbar.d.ts +494 -30
  138. package/types/components/switch/YSwitch.d.ts +4 -3
  139. package/types/components/tab/YTab.d.ts +30 -29
  140. package/types/components/tab/YTabs.d.ts +12 -11
  141. package/types/components/tab/index.d.ts +1 -1
  142. package/types/components/tab/shared.d.ts +1 -0
  143. package/types/components/tab/types.d.ts +1 -1
  144. package/types/components/table/YDataTable.d.ts +225 -62
  145. package/types/components/table/YDataTableBody.d.ts +10 -9
  146. package/types/components/table/YDataTableCell.d.ts +6 -5
  147. package/types/components/table/YDataTableControl.d.ts +5 -4
  148. package/types/components/table/YDataTableHead.d.ts +10 -10
  149. package/types/components/table/YDataTableLayer.d.ts +4 -3
  150. package/types/components/table/YDataTableRow.d.ts +3 -2
  151. package/types/components/table/YDataTableServer.d.ts +225 -62
  152. package/types/components/table/YTable.d.ts +7 -6
  153. package/types/components/table/composibles/header.d.ts +103 -12
  154. package/types/components/table/composibles/items.d.ts +5 -4
  155. package/types/components/table/composibles/options.d.ts +2 -1
  156. package/types/components/table/composibles/pagination.d.ts +6 -5
  157. package/types/components/table/composibles/selection.d.ts +7 -5
  158. package/types/components/table/composibles/sorting.d.ts +26 -7
  159. package/types/components/table/types/common.d.ts +1 -0
  160. package/types/components/table/types/header.d.ts +3 -2
  161. package/types/components/table/types/index.d.ts +5 -4
  162. package/types/components/table/types/item.d.ts +1 -0
  163. package/types/components/table/types/row.d.ts +1 -0
  164. package/types/components/text-ellipsis/YTextEllipsis.d.ts +3 -2
  165. package/types/components/text-highlighter/YTextHighlighter.d.ts +3 -2
  166. package/types/components/text-highlighter/index.d.ts +1 -0
  167. package/types/components/text-interpolation/YTi.d.ts +20 -0
  168. package/types/components/text-interpolation/index.d.ts +1 -0
  169. package/types/components/textarea/YTextarea.d.ts +39 -39
  170. package/types/components/toggle-button/YToggleButton.d.ts +1 -0
  171. package/types/components/tooltip/YTooltip.d.ts +217 -150
  172. package/types/components/transitions/expand-transition.d.ts +4 -3
  173. package/types/components/transitions/index.d.ts +10 -10
  174. package/types/components/tree-view/YTreeView.d.ts +20 -13
  175. package/types/components/tree-view/YTreeViewNode.d.ts +42 -20
  176. package/types/components/tree-view/types.d.ts +2 -1
  177. package/types/components/tree-view/util.d.ts +1 -0
  178. package/types/composables/choice-link.d.ts +2 -1
  179. package/types/composables/choice.d.ts +3 -2
  180. package/types/composables/communication.d.ts +2 -1
  181. package/types/composables/component.d.ts +1 -0
  182. package/types/composables/coordinate/arrangement.d.ts +2 -1
  183. package/types/composables/coordinate/index.d.ts +23 -22
  184. package/types/composables/coordinate/levitation.d.ts +2 -1
  185. package/types/composables/coordinate/types.d.ts +2 -1
  186. package/types/composables/coordinate/utils/point.d.ts +1 -0
  187. package/types/composables/date/factory.d.ts +1 -0
  188. package/types/composables/date/index.d.ts +1 -0
  189. package/types/composables/date/setting.d.ts +2 -1
  190. package/types/composables/date/types.d.ts +2 -1
  191. package/types/composables/dimension.d.ts +4 -3
  192. package/types/composables/focus.d.ts +4 -3
  193. package/types/composables/form.d.ts +7 -6
  194. package/types/composables/i18n/index.d.ts +1 -0
  195. package/types/composables/i18n/locale.d.ts +2 -1
  196. package/types/composables/i18n/rtl.d.ts +2 -1
  197. package/types/composables/icon.d.ts +9 -10
  198. package/types/composables/index.d.ts +1 -0
  199. package/types/composables/layer-group.d.ts +3 -2
  200. package/types/composables/layout.d.ts +10 -0
  201. package/types/composables/list-items.d.ts +36 -35
  202. package/types/composables/progress.d.ts +1 -1
  203. package/types/composables/ref.d.ts +2 -1
  204. package/types/composables/resize-observer.d.ts +2 -2
  205. package/types/composables/scope.d.ts +2 -1
  206. package/types/composables/theme/factory.d.ts +1 -0
  207. package/types/composables/theme/index.d.ts +5 -4
  208. package/types/composables/theme/setting.d.ts +1 -0
  209. package/types/composables/timing.d.ts +2 -1
  210. package/types/composables/transition.d.ts +2 -1
  211. package/types/composables/validation.d.ts +19 -18
  212. package/types/composables/vue-router.d.ts +3 -3
  213. package/types/directives/complement-click/index.d.ts +1 -0
  214. package/types/directives/plate-wave/index.d.ts +2 -1
  215. package/types/directives/theme-class.d.ts +1 -0
  216. package/types/globals.d.ts +1 -1
  217. package/types/i18n/built-in.d.ts +2 -1
  218. package/types/i18n/types.d.ts +2 -1
  219. package/types/index.d.ts +2 -1
  220. package/types/locales/index.d.ts +2 -0
  221. package/types/locales/ko.d.ts +6 -0
  222. package/types/mixins/di.d.ts +1 -1
  223. package/types/mixins/rebind-attrs.d.ts +2 -2
  224. package/types/shims.d.ts +5 -45
  225. package/types/types/index.d.ts +2 -1
  226. package/types/util/anchor.d.ts +1 -1
  227. package/types/util/color/contrast/contrast.d.ts +74 -0
  228. package/types/util/color/conversion.d.ts +1 -0
  229. package/types/util/color/hct/cam16.d.ts +2 -17
  230. package/types/util/color/hct/hct-solver.d.ts +131 -0
  231. package/types/util/color/hct/hct.d.ts +2 -17
  232. package/types/util/color/hct/viewing-conditions.d.ts +58 -0
  233. package/types/util/color/index.d.ts +1 -1
  234. package/types/util/color/palettes/core-palette.d.ts +44 -0
  235. package/types/util/color/palettes/tonal-palette.d.ts +40 -0
  236. package/types/util/date/adapters/yuyeon-date-adapter.d.ts +1 -0
  237. package/types/util/date/built-in.d.ts +2 -1
  238. package/types/util/date/index.d.ts +1 -1
  239. package/types/util/parser.d.ts +4 -0
  240. package/types/util/reactivity.d.ts +3 -2
  241. package/types/util/string.d.ts +4 -0
  242. package/types/util/vue-component.d.ts +4 -3
@@ -0,0 +1,297 @@
1
+ import { mergeProps as _mergeProps, createVNode as _createVNode } from "vue";
2
+ import { computed, defineComponent, mergeProps, nextTick, reactive, ref, toRef, watch } from 'vue';
3
+ import { useModelDuplex } from "../../composables/communication.mjs";
4
+ import { useRender } from "../../composables/component.mjs";
5
+ import { chooseProps } from "../../util/vue-component.mjs";
6
+ import { YInput, pressYInputPropsOptions } from "../input/index.mjs";
7
+ import "./YIpField.scss";
8
+ const INHERIT_NAME = 'y-ip-field';
9
+ const NAME = 'y-ipv4-field';
10
+ const IP_PART_REGEX = /^(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/;
11
+ export const YIpv4Field = defineComponent({
12
+ name: NAME,
13
+ props: {
14
+ fixedUntil: Number,
15
+ text: Boolean,
16
+ subnet: Boolean,
17
+ autoFillSubnet: [Boolean, Number, String],
18
+ ...pressYInputPropsOptions()
19
+ },
20
+ emits: {
21
+ 'update:modelValue': _v => true,
22
+ tab: _id => true,
23
+ focus: () => true,
24
+ blur: () => true
25
+ },
26
+ setup(props, _ref) {
27
+ let {
28
+ slots,
29
+ emit
30
+ } = _ref;
31
+ const field$ = ref();
32
+ const yInput$ = ref();
33
+ const input$ = ref([]);
34
+ const model = useModelDuplex(props);
35
+ const parts = reactive({
36
+ 0: '',
37
+ 1: '',
38
+ 2: '',
39
+ 3: '',
40
+ 4: ''
41
+ });
42
+ //
43
+ const lazyParts = reactive({
44
+ 0: '',
45
+ 1: '',
46
+ 2: '',
47
+ 3: '',
48
+ 4: ''
49
+ });
50
+ const isFocused = ref(false);
51
+ const fieldFocused = ref([]);
52
+
53
+ /// Events
54
+ function testSubnetRange(value) {
55
+ return !/[^0-9]/.test(value) && Number(value) < 33 && Number(value) > -1;
56
+ }
57
+ function onInput(id, event) {
58
+ const target = event.target;
59
+ const neoValue = target?.value || '';
60
+ const oldValue = lazyParts[id];
61
+ const pass = id < 4 ? IP_PART_REGEX.test(neoValue) : testSubnetRange(neoValue);
62
+ const neo = neoValue !== '' ? Number(neoValue).toString() : '';
63
+ parts[id] = neo;
64
+ if (!pass && neoValue !== '') {
65
+ nextChange(id, oldValue);
66
+ } else {
67
+ if (neoValue.length > 2) {
68
+ focusNextPart(id);
69
+ }
70
+ lazyParts[id] = neo;
71
+ emitInput();
72
+ }
73
+ }
74
+ function onFocus(id, _event) {
75
+ isFocused.value = true;
76
+ fieldFocused.value.push(id);
77
+ }
78
+ function onBlur(id, _event) {
79
+ isFocused.value = false;
80
+ nextTick(() => {
81
+ setTimeout(() => {
82
+ fieldFocused.value.forEach((value, index) => {
83
+ if (value === id) {
84
+ fieldFocused.value.splice(index, 1);
85
+ }
86
+ });
87
+ });
88
+ });
89
+ }
90
+ function onChange(_id, _event) {
91
+ //
92
+ // const changed = [id, event];
93
+ }
94
+ function onKeydown(id, event) {
95
+ const $target = event.target;
96
+ if (event.key === 'Backspace' && event.target && $target.value === '') {
97
+ focusPrevPart(id);
98
+ }
99
+ if (event.key === 'ArrowRight' || event.key === 'ArrowDown' && !event.shiftKey) {
100
+ if ($target.selectionStart !== null && $target.value.length <= $target.selectionStart) {
101
+ if (id === 3) {
102
+ event.preventDefault();
103
+ emit('tab');
104
+ return;
105
+ } else {
106
+ event.preventDefault();
107
+ focusNextPart(id);
108
+ return;
109
+ }
110
+ }
111
+ }
112
+ if (event.key === 'ArrowLeft' || event.key === 'ArrowUp' && !event.shiftKey) {
113
+ if ($target.selectionStart !== null && $target.selectionStart === 0) {
114
+ if (id === 0) {
115
+ event.preventDefault();
116
+ emit('tab', -1);
117
+ return;
118
+ } else {
119
+ event.preventDefault();
120
+ focusPrevPart(id);
121
+ return;
122
+ }
123
+ }
124
+ }
125
+ if ((event.key === 'Tab' && !event.shiftKey && $target.value !== '' || event.key === 'Enter' || event.key === '.') && props.onTab && id === 3) {
126
+ event.preventDefault();
127
+ emit('tab', 3);
128
+ }
129
+ }
130
+ function onKeyup(id, event) {
131
+ if (event.key === '.') {
132
+ focusNextPart(id);
133
+ }
134
+ }
135
+ function putParts(neo) {
136
+ if (typeof neo === 'string') {
137
+ let tempParts = [];
138
+ if (neo.lastIndexOf('/') > -1) {
139
+ const sub = neo.substring(neo.lastIndexOf('/') + 1, neo.length);
140
+ if (props.subnet && testSubnetRange(sub)) {
141
+ parts[4] = sub;
142
+ }
143
+ tempParts = neo.substring(0, neo.lastIndexOf('/')).split('.');
144
+ } else {
145
+ tempParts = neo.split('.');
146
+ }
147
+ if (tempParts.length > 2) {
148
+ for (let index = 0; index < 4; index += 1) {
149
+ const part = tempParts[index];
150
+ if (part !== undefined && IP_PART_REGEX.test(part)) {
151
+ parts[index] = part;
152
+ } else {
153
+ parts[index] = '';
154
+ }
155
+ }
156
+ emitInput();
157
+ }
158
+ }
159
+ }
160
+ function onPaste(event) {
161
+ const content = (event.clipboardData || window.clipboardData).getData('text');
162
+ if (isNaN(Number(content))) {
163
+ event.preventDefault();
164
+ putParts(content);
165
+ }
166
+ }
167
+ function whenBlur() {
168
+ if (props.autoFillSubnet && parts[0] && parts[1] && parts[2] && parts[3] && !parts[4]) {
169
+ if (typeof props.autoFillSubnet === 'boolean') {
170
+ parts[4] = '32';
171
+ } else {
172
+ parts[4] = props.autoFillSubnet.toString();
173
+ }
174
+ emitInput();
175
+ }
176
+ }
177
+
178
+ /// Actions
179
+ function nextChange(id, value) {
180
+ nextTick(() => {
181
+ parts[id] = value;
182
+ emitInput();
183
+ });
184
+ }
185
+ function focusNextPart(currentId) {
186
+ const nextId = currentId + 1;
187
+ if (nextId < 4) {
188
+ const $input = input$.value[nextId];
189
+ $input.focus();
190
+ $input.selectionStart = 0;
191
+ }
192
+ }
193
+ function focusPrevPart(currentId) {
194
+ const prevId = currentId - 1;
195
+ if (prevId > -1) {
196
+ const $input = input$.value[prevId];
197
+ $input.focus();
198
+ $input.selectionStart = $input.value.length + 1;
199
+ }
200
+ }
201
+ function emitInput() {
202
+ model.value = joinParts();
203
+ }
204
+ function joinParts() {
205
+ if (parts[0] === '' && parts[1] === '' && parts[2] === '' && parts[3] === '') {
206
+ return '';
207
+ }
208
+ return `${parts[0]}.${parts[1]}.${parts[2]}.${parts[3]}${props.subnet ? '/' + parts[4] : ''}`;
209
+ }
210
+ const focused = computed(() => {
211
+ return fieldFocused.value.length > 0;
212
+ });
213
+ watch(model, neo => {
214
+ if (neo === '') {
215
+ for (let index = 0; index < 5; index += 1) {
216
+ parts[index] = '';
217
+ lazyParts[index] = '';
218
+ }
219
+ return;
220
+ } else {
221
+ putParts(neo);
222
+ }
223
+ }, {
224
+ immediate: true
225
+ });
226
+ watch(focused, neo => {
227
+ if (!neo) {
228
+ whenBlur();
229
+ }
230
+ });
231
+ watch(isFocused, neo => {
232
+ if (neo) {
233
+ emit('focus');
234
+ } else {
235
+ emit('blur');
236
+ }
237
+ });
238
+ useRender(() => {
239
+ input$.value = [];
240
+ return _createVNode(YInput, _mergeProps({
241
+ "ref": yInput$,
242
+ "class": [NAME, INHERIT_NAME, {
243
+ [`${INHERIT_NAME}--text`]: props.text
244
+ }]
245
+ }, chooseProps(props, YInput.props)), {
246
+ leading: function () {
247
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
248
+ args[_key] = arguments[_key];
249
+ }
250
+ return slots.leading?.(...args);
251
+ },
252
+ default: defaultProps => {
253
+ return _createVNode("div", _mergeProps({
254
+ "class": [`${INHERIT_NAME}__field`]
255
+ }, mergeProps({
256
+ 'data-id': defaultProps.attrId
257
+ }), {
258
+ "ref": field$
259
+ }), [[0, 1, 2, 3, 4].map(id => {
260
+ const inputValue = toRef(parts, id);
261
+ return (!props.subnet && id < 4 || props.subnet) && [_createVNode("div", {
262
+ "class": [`${INHERIT_NAME}__part`]
263
+ }, [_createVNode("input", {
264
+ "ref": el => input$.value.push(el),
265
+ "id": `${defaultProps.attrId}__part--${id}`,
266
+ "value": inputValue.value,
267
+ "class": [`${INHERIT_NAME}__part-input`],
268
+ "readonly": props.readonly || props.loading,
269
+ "disabled": props.disabled,
270
+ "autocomplete": "false",
271
+ "maxlength": id === 4 ? 2 : 3,
272
+ "onInput": $event => onInput(id, $event),
273
+ "onFocus": $event => onFocus(id, $event),
274
+ "onBlur": $event => onBlur(id, $event),
275
+ "onChange": $event => onChange(id, $event),
276
+ "onKeydown": $event => onKeydown(id, $event),
277
+ "onKeyup": $event => onKeyup(id, $event),
278
+ "onPaste": onPaste
279
+ }, null)]), id !== 4 && (!props.subnet && id < 3 || props.subnet) && _createVNode("div", {
280
+ "class": [`${INHERIT_NAME}__part`]
281
+ }, [id < 3 ? '.' : '/'])];
282
+ })]);
283
+ },
284
+ trailing: function () {
285
+ for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
286
+ args[_key2] = arguments[_key2];
287
+ }
288
+ return slots.trailing?.(...args);
289
+ },
290
+ label: slots.label && (() => slots.label?.()),
291
+ 'helper-text': slots['helper-text'] && (() => slots['helper-text']?.())
292
+ });
293
+ });
294
+ return {};
295
+ }
296
+ });
297
+ //# sourceMappingURL=YIpv4Field.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"YIpv4Field.mjs","names":["computed","defineComponent","mergeProps","nextTick","reactive","ref","toRef","watch","useModelDuplex","useRender","chooseProps","YInput","pressYInputPropsOptions","INHERIT_NAME","NAME","IP_PART_REGEX","YIpv4Field","name","props","fixedUntil","Number","text","Boolean","subnet","autoFillSubnet","String","emits","_v","tab","_id","focus","blur","setup","_ref","slots","emit","field$","yInput$","input$","model","parts","lazyParts","isFocused","fieldFocused","testSubnetRange","value","test","onInput","id","event","target","neoValue","oldValue","pass","neo","toString","nextChange","length","focusNextPart","emitInput","onFocus","_event","push","onBlur","setTimeout","forEach","index","splice","onChange","onKeydown","$target","key","focusPrevPart","shiftKey","selectionStart","preventDefault","onTab","onKeyup","putParts","tempParts","lastIndexOf","sub","substring","split","part","undefined","onPaste","content","clipboardData","window","getData","isNaN","whenBlur","currentId","nextId","$input","prevId","joinParts","focused","immediate","_createVNode","_mergeProps","leading","_len","arguments","args","Array","_key","default","defaultProps","attrId","map","inputValue","el","readonly","loading","disabled","$event","trailing","_len2","_key2","label"],"sources":["../../../src/components/ip-field/YIpv4Field.tsx"],"sourcesContent":["import {\n PropType,\n computed,\n defineComponent,\n mergeProps,\n nextTick,\n reactive,\n ref,\n toRef,\n watch,\n} from 'vue';\n\nimport { useModelDuplex } from '../../composables/communication';\nimport { useRender } from '../../composables/component';\nimport { chooseProps } from '../../util/vue-component';\nimport { YInput, pressYInputPropsOptions } from '../input';\n\nimport './YIpField.scss';\n\nconst INHERIT_NAME = 'y-ip-field';\nconst NAME = 'y-ipv4-field';\nconst IP_PART_REGEX = /^(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/;\n\ntype PartId = 0 | 1 | 2 | 3 | 4;\n\nexport const YIpv4Field = defineComponent({\n name: NAME,\n props: {\n fixedUntil: Number as PropType<0 | 1 | 2 | 3>,\n text: Boolean as PropType<boolean>,\n subnet: Boolean as PropType<boolean>,\n autoFillSubnet: [Boolean, Number, String] as PropType<\n boolean | number | string\n >,\n ...pressYInputPropsOptions(),\n },\n emits: {\n 'update:modelValue': (_v: string) => true,\n tab: (_id?: number) => true,\n focus: () => true,\n blur: () => true,\n },\n setup(props, { slots, emit }) {\n const field$ = ref();\n const yInput$ = ref();\n const input$ = ref<any[]>([]);\n\n const model = useModelDuplex(props);\n\n const parts = reactive<Record<PartId, any>>({\n 0: '',\n 1: '',\n 2: '',\n 3: '',\n 4: '',\n });\n //\n const lazyParts = reactive({\n 0: '',\n 1: '',\n 2: '',\n 3: '',\n 4: '',\n });\n\n const isFocused = ref(false);\n const fieldFocused = ref<number[]>([]);\n\n /// Events\n function testSubnetRange(value: string) {\n return !/[^0-9]/.test(value) && Number(value) < 33 && Number(value) > -1;\n }\n\n function onInput(id: PartId, event: Event) {\n const target = event.target as HTMLInputElement | null;\n const neoValue = target?.value || '';\n const oldValue = lazyParts[id];\n const pass =\n id < 4 ? IP_PART_REGEX.test(neoValue) : testSubnetRange(neoValue);\n const neo = neoValue !== '' ? Number(neoValue).toString() : '';\n parts[id] = neo;\n if (!pass && neoValue !== '') {\n nextChange(id, oldValue);\n } else {\n if (neoValue.length > 2) {\n focusNextPart(id);\n }\n lazyParts[id] = neo;\n emitInput();\n }\n }\n\n function onFocus(id: PartId, _event: FocusEvent) {\n isFocused.value = true;\n fieldFocused.value.push(id);\n }\n\n function onBlur(id: PartId, _event: FocusEvent) {\n isFocused.value = false;\n nextTick(() => {\n setTimeout(() => {\n fieldFocused.value.forEach((value, index) => {\n if (value === id) {\n fieldFocused.value.splice(index, 1);\n }\n });\n });\n });\n }\n\n function onChange(_id: PartId, _event: Event) {\n //\n // const changed = [id, event];\n }\n\n function onKeydown(id: PartId, event: KeyboardEvent) {\n const $target = event.target as HTMLInputElement;\n if (event.key === 'Backspace' && event.target && $target.value === '') {\n focusPrevPart(id);\n }\n if (\n event.key === 'ArrowRight' ||\n (event.key === 'ArrowDown' && !event.shiftKey)\n ) {\n if (\n $target.selectionStart !== null &&\n $target.value.length <= $target.selectionStart\n ) {\n if (id === 3) {\n event.preventDefault();\n emit('tab');\n return;\n } else {\n event.preventDefault();\n focusNextPart(id);\n return;\n }\n }\n }\n if (\n event.key === 'ArrowLeft' ||\n (event.key === 'ArrowUp' && !event.shiftKey)\n ) {\n if ($target.selectionStart !== null && $target.selectionStart === 0) {\n if (id === 0) {\n event.preventDefault();\n emit('tab', -1);\n return;\n } else {\n event.preventDefault();\n focusPrevPart(id);\n return;\n }\n }\n }\n if (\n ((event.key === 'Tab' && !event.shiftKey && $target.value !== '') ||\n event.key === 'Enter' ||\n event.key === '.') &&\n props.onTab &&\n id === 3\n ) {\n event.preventDefault();\n emit('tab', 3);\n }\n }\n\n function onKeyup(id: PartId, event: KeyboardEvent) {\n if (event.key === '.') {\n focusNextPart(id);\n }\n }\n\n function putParts(neo: string | undefined) {\n if (typeof neo === 'string') {\n let tempParts: string[] = [];\n if (neo.lastIndexOf('/') > -1) {\n const sub = neo.substring(neo.lastIndexOf('/') + 1, neo.length);\n if (props.subnet && testSubnetRange(sub)) {\n parts[4] = sub;\n }\n tempParts = neo.substring(0, neo.lastIndexOf('/')).split('.');\n } else {\n tempParts = neo.split('.');\n }\n if (tempParts.length > 2) {\n for (let index = 0; index < 4; index += 1) {\n const part = tempParts[index];\n if (part !== undefined && IP_PART_REGEX.test(part)) {\n parts[index as PartId] = part;\n } else {\n parts[index as PartId] = '';\n }\n }\n emitInput();\n }\n }\n }\n\n function onPaste(event: ClipboardEvent) {\n const content = (\n event.clipboardData || (window as any).clipboardData\n ).getData('text');\n if (isNaN(Number(content))) {\n event.preventDefault();\n putParts(content);\n }\n }\n\n function whenBlur() {\n if (\n props.autoFillSubnet &&\n parts[0] &&\n parts[1] &&\n parts[2] &&\n parts[3] &&\n !parts[4]\n ) {\n if (typeof props.autoFillSubnet === 'boolean') {\n parts[4] = '32';\n } else {\n parts[4] = props.autoFillSubnet.toString();\n }\n emitInput();\n }\n }\n\n /// Actions\n function nextChange(id: PartId, value: any) {\n nextTick(() => {\n parts[id] = value;\n emitInput();\n });\n }\n\n function focusNextPart(currentId: PartId) {\n const nextId = currentId + 1;\n if (nextId < 4) {\n const $input = input$.value[nextId] as HTMLInputElement;\n $input.focus();\n $input.selectionStart = 0;\n }\n }\n\n function focusPrevPart(currentId: PartId) {\n const prevId = currentId - 1;\n if (prevId > -1) {\n const $input = input$.value[prevId] as HTMLInputElement;\n $input.focus();\n $input.selectionStart = $input.value.length + 1;\n }\n }\n\n function emitInput() {\n model.value = joinParts();\n }\n\n function joinParts(): string {\n if (\n parts[0] === '' &&\n parts[1] === '' &&\n parts[2] === '' &&\n parts[3] === ''\n ) {\n return '';\n }\n return `${parts[0]}.${parts[1]}.${parts[2]}.${parts[3]}${\n props.subnet ? '/' + parts[4] : ''\n }`;\n }\n\n const focused = computed(() => {\n return fieldFocused.value.length > 0;\n });\n\n watch(\n model,\n (neo: string | undefined) => {\n if (neo === '') {\n for (let index = 0; index < 5; index += 1) {\n parts[index as PartId] = '';\n lazyParts[index as PartId] = '';\n }\n return;\n } else {\n putParts(neo);\n }\n },\n { immediate: true },\n );\n\n watch(focused, (neo: boolean) => {\n if (!neo) {\n whenBlur();\n }\n });\n\n watch(isFocused, (neo: boolean) => {\n if (neo) {\n emit('focus');\n } else {\n emit('blur');\n }\n });\n\n useRender(() => {\n input$.value = [];\n return (\n <YInput\n ref={yInput$}\n class={[\n NAME,\n INHERIT_NAME,\n { [`${INHERIT_NAME}--text`]: props.text },\n ]}\n {...chooseProps(props, YInput.props)}\n >\n {{\n leading: (...args: any[]) => slots.leading?.(...args),\n default: (defaultProps: any) => {\n return (\n <div\n class={[`${INHERIT_NAME}__field`]}\n {...mergeProps({ 'data-id': defaultProps.attrId })}\n ref={field$}\n >\n {([0, 1, 2, 3, 4] as PartId[]).map((id) => {\n const inputValue = toRef(parts, id);\n return (\n ((!props.subnet && id < 4) || props.subnet) && [\n <div class={[`${INHERIT_NAME}__part`]}>\n <input\n ref={(el) => input$.value.push(el)}\n id={`${defaultProps.attrId}__part--${id}`}\n value={inputValue.value}\n class={[`${INHERIT_NAME}__part-input`]}\n readonly={props.readonly || props.loading}\n disabled={props.disabled}\n autocomplete=\"false\"\n maxlength={id === 4 ? 2 : 3}\n onInput={($event) => onInput(id, $event)}\n onFocus={($event) => onFocus(id, $event)}\n onBlur={($event) => onBlur(id, $event)}\n onChange={($event) => onChange(id, $event)}\n onKeydown={($event) => onKeydown(id, $event)}\n onKeyup={($event) => onKeyup(id, $event)}\n onPaste={onPaste}\n />\n </div>,\n id !== 4 &&\n ((!props.subnet && id < 3) || props.subnet) && (\n <div class={[`${INHERIT_NAME}__part`]}>\n {id < 3 ? '.' : '/'}\n </div>\n ),\n ]\n );\n })}\n </div>\n );\n },\n trailing: (...args: any[]) => slots.trailing?.(...args),\n label: slots.label && (() => slots.label?.()),\n 'helper-text':\n slots['helper-text'] && (() => slots['helper-text']?.()),\n }}\n </YInput>\n );\n });\n\n return {};\n },\n});\n\nexport type YIpv4Field = InstanceType<typeof YIpv4Field>;\n"],"mappings":";AAAA,SAEEA,QAAQ,EACRC,eAAe,EACfC,UAAU,EACVC,QAAQ,EACRC,QAAQ,EACRC,GAAG,EACHC,KAAK,EACLC,KAAK,QACA,KAAK;AAAC,SAEJC,cAAc;AAAA,SACdC,SAAS;AAAA,SACTC,WAAW;AAAA,SACXC,MAAM,EAAEC,uBAAuB;AAExC;AAEA,MAAMC,YAAY,GAAG,YAAY;AACjC,MAAMC,IAAI,GAAG,cAAc;AAC3B,MAAMC,aAAa,GAAG,0CAA0C;AAIhE,OAAO,MAAMC,UAAU,GAAGf,eAAe,CAAC;EACxCgB,IAAI,EAAEH,IAAI;EACVI,KAAK,EAAE;IACLC,UAAU,EAAEC,MAAiC;IAC7CC,IAAI,EAAEC,OAA4B;IAClCC,MAAM,EAAED,OAA4B;IACpCE,cAAc,EAAE,CAACF,OAAO,EAAEF,MAAM,EAAEK,MAAM,CAEvC;IACD,GAAGb,uBAAuB,CAAC;EAC7B,CAAC;EACDc,KAAK,EAAE;IACL,mBAAmB,EAAGC,EAAU,IAAK,IAAI;IACzCC,GAAG,EAAGC,GAAY,IAAK,IAAI;IAC3BC,KAAK,EAAEA,CAAA,KAAM,IAAI;IACjBC,IAAI,EAAEA,CAAA,KAAM;EACd,CAAC;EACDC,KAAKA,CAACd,KAAK,EAAAe,IAAA,EAAmB;IAAA,IAAjB;MAAEC,KAAK;MAAEC;IAAK,CAAC,GAAAF,IAAA;IAC1B,MAAMG,MAAM,GAAG/B,GAAG,CAAC,CAAC;IACpB,MAAMgC,OAAO,GAAGhC,GAAG,CAAC,CAAC;IACrB,MAAMiC,MAAM,GAAGjC,GAAG,CAAQ,EAAE,CAAC;IAE7B,MAAMkC,KAAK,GAAG/B,cAAc,CAACU,KAAK,CAAC;IAEnC,MAAMsB,KAAK,GAAGpC,QAAQ,CAAsB;MAC1C,CAAC,EAAE,EAAE;MACL,CAAC,EAAE,EAAE;MACL,CAAC,EAAE,EAAE;MACL,CAAC,EAAE,EAAE;MACL,CAAC,EAAE;IACL,CAAC,CAAC;IACF;IACA,MAAMqC,SAAS,GAAGrC,QAAQ,CAAC;MACzB,CAAC,EAAE,EAAE;MACL,CAAC,EAAE,EAAE;MACL,CAAC,EAAE,EAAE;MACL,CAAC,EAAE,EAAE;MACL,CAAC,EAAE;IACL,CAAC,CAAC;IAEF,MAAMsC,SAAS,GAAGrC,GAAG,CAAC,KAAK,CAAC;IAC5B,MAAMsC,YAAY,GAAGtC,GAAG,CAAW,EAAE,CAAC;;IAEtC;IACA,SAASuC,eAAeA,CAACC,KAAa,EAAE;MACtC,OAAO,CAAC,QAAQ,CAACC,IAAI,CAACD,KAAK,CAAC,IAAIzB,MAAM,CAACyB,KAAK,CAAC,GAAG,EAAE,IAAIzB,MAAM,CAACyB,KAAK,CAAC,GAAG,CAAC,CAAC;IAC1E;IAEA,SAASE,OAAOA,CAACC,EAAU,EAAEC,KAAY,EAAE;MACzC,MAAMC,MAAM,GAAGD,KAAK,CAACC,MAAiC;MACtD,MAAMC,QAAQ,GAAGD,MAAM,EAAEL,KAAK,IAAI,EAAE;MACpC,MAAMO,QAAQ,GAAGX,SAAS,CAACO,EAAE,CAAC;MAC9B,MAAMK,IAAI,GACRL,EAAE,GAAG,CAAC,GAAGjC,aAAa,CAAC+B,IAAI,CAACK,QAAQ,CAAC,GAAGP,eAAe,CAACO,QAAQ,CAAC;MACnE,MAAMG,GAAG,GAAGH,QAAQ,KAAK,EAAE,GAAG/B,MAAM,CAAC+B,QAAQ,CAAC,CAACI,QAAQ,CAAC,CAAC,GAAG,EAAE;MAC9Df,KAAK,CAACQ,EAAE,CAAC,GAAGM,GAAG;MACf,IAAI,CAACD,IAAI,IAAIF,QAAQ,KAAK,EAAE,EAAE;QAC5BK,UAAU,CAACR,EAAE,EAAEI,QAAQ,CAAC;MAC1B,CAAC,MAAM;QACL,IAAID,QAAQ,CAACM,MAAM,GAAG,CAAC,EAAE;UACvBC,aAAa,CAACV,EAAE,CAAC;QACnB;QACAP,SAAS,CAACO,EAAE,CAAC,GAAGM,GAAG;QACnBK,SAAS,CAAC,CAAC;MACb;IACF;IAEA,SAASC,OAAOA,CAACZ,EAAU,EAAEa,MAAkB,EAAE;MAC/CnB,SAAS,CAACG,KAAK,GAAG,IAAI;MACtBF,YAAY,CAACE,KAAK,CAACiB,IAAI,CAACd,EAAE,CAAC;IAC7B;IAEA,SAASe,MAAMA,CAACf,EAAU,EAAEa,MAAkB,EAAE;MAC9CnB,SAAS,CAACG,KAAK,GAAG,KAAK;MACvB1C,QAAQ,CAAC,MAAM;QACb6D,UAAU,CAAC,MAAM;UACfrB,YAAY,CAACE,KAAK,CAACoB,OAAO,CAAC,CAACpB,KAAK,EAAEqB,KAAK,KAAK;YAC3C,IAAIrB,KAAK,KAAKG,EAAE,EAAE;cAChBL,YAAY,CAACE,KAAK,CAACsB,MAAM,CAACD,KAAK,EAAE,CAAC,CAAC;YACrC;UACF,CAAC,CAAC;QACJ,CAAC,CAAC;MACJ,CAAC,CAAC;IACJ;IAEA,SAASE,QAAQA,CAACvC,GAAW,EAAEgC,MAAa,EAAE;MAC5C;MACA;IAAA;IAGF,SAASQ,SAASA,CAACrB,EAAU,EAAEC,KAAoB,EAAE;MACnD,MAAMqB,OAAO,GAAGrB,KAAK,CAACC,MAA0B;MAChD,IAAID,KAAK,CAACsB,GAAG,KAAK,WAAW,IAAItB,KAAK,CAACC,MAAM,IAAIoB,OAAO,CAACzB,KAAK,KAAK,EAAE,EAAE;QACrE2B,aAAa,CAACxB,EAAE,CAAC;MACnB;MACA,IACEC,KAAK,CAACsB,GAAG,KAAK,YAAY,IACzBtB,KAAK,CAACsB,GAAG,KAAK,WAAW,IAAI,CAACtB,KAAK,CAACwB,QAAS,EAC9C;QACA,IACEH,OAAO,CAACI,cAAc,KAAK,IAAI,IAC/BJ,OAAO,CAACzB,KAAK,CAACY,MAAM,IAAIa,OAAO,CAACI,cAAc,EAC9C;UACA,IAAI1B,EAAE,KAAK,CAAC,EAAE;YACZC,KAAK,CAAC0B,cAAc,CAAC,CAAC;YACtBxC,IAAI,CAAC,KAAK,CAAC;YACX;UACF,CAAC,MAAM;YACLc,KAAK,CAAC0B,cAAc,CAAC,CAAC;YACtBjB,aAAa,CAACV,EAAE,CAAC;YACjB;UACF;QACF;MACF;MACA,IACEC,KAAK,CAACsB,GAAG,KAAK,WAAW,IACxBtB,KAAK,CAACsB,GAAG,KAAK,SAAS,IAAI,CAACtB,KAAK,CAACwB,QAAS,EAC5C;QACA,IAAIH,OAAO,CAACI,cAAc,KAAK,IAAI,IAAIJ,OAAO,CAACI,cAAc,KAAK,CAAC,EAAE;UACnE,IAAI1B,EAAE,KAAK,CAAC,EAAE;YACZC,KAAK,CAAC0B,cAAc,CAAC,CAAC;YACtBxC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YACf;UACF,CAAC,MAAM;YACLc,KAAK,CAAC0B,cAAc,CAAC,CAAC;YACtBH,aAAa,CAACxB,EAAE,CAAC;YACjB;UACF;QACF;MACF;MACA,IACE,CAAEC,KAAK,CAACsB,GAAG,KAAK,KAAK,IAAI,CAACtB,KAAK,CAACwB,QAAQ,IAAIH,OAAO,CAACzB,KAAK,KAAK,EAAE,IAC9DI,KAAK,CAACsB,GAAG,KAAK,OAAO,IACrBtB,KAAK,CAACsB,GAAG,KAAK,GAAG,KACnBrD,KAAK,CAAC0D,KAAK,IACX5B,EAAE,KAAK,CAAC,EACR;QACAC,KAAK,CAAC0B,cAAc,CAAC,CAAC;QACtBxC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;MAChB;IACF;IAEA,SAAS0C,OAAOA,CAAC7B,EAAU,EAAEC,KAAoB,EAAE;MACjD,IAAIA,KAAK,CAACsB,GAAG,KAAK,GAAG,EAAE;QACrBb,aAAa,CAACV,EAAE,CAAC;MACnB;IACF;IAEA,SAAS8B,QAAQA,CAACxB,GAAuB,EAAE;MACzC,IAAI,OAAOA,GAAG,KAAK,QAAQ,EAAE;QAC3B,IAAIyB,SAAmB,GAAG,EAAE;QAC5B,IAAIzB,GAAG,CAAC0B,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE;UAC7B,MAAMC,GAAG,GAAG3B,GAAG,CAAC4B,SAAS,CAAC5B,GAAG,CAAC0B,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE1B,GAAG,CAACG,MAAM,CAAC;UAC/D,IAAIvC,KAAK,CAACK,MAAM,IAAIqB,eAAe,CAACqC,GAAG,CAAC,EAAE;YACxCzC,KAAK,CAAC,CAAC,CAAC,GAAGyC,GAAG;UAChB;UACAF,SAAS,GAAGzB,GAAG,CAAC4B,SAAS,CAAC,CAAC,EAAE5B,GAAG,CAAC0B,WAAW,CAAC,GAAG,CAAC,CAAC,CAACG,KAAK,CAAC,GAAG,CAAC;QAC/D,CAAC,MAAM;UACLJ,SAAS,GAAGzB,GAAG,CAAC6B,KAAK,CAAC,GAAG,CAAC;QAC5B;QACA,IAAIJ,SAAS,CAACtB,MAAM,GAAG,CAAC,EAAE;UACxB,KAAK,IAAIS,KAAK,GAAG,CAAC,EAAEA,KAAK,GAAG,CAAC,EAAEA,KAAK,IAAI,CAAC,EAAE;YACzC,MAAMkB,IAAI,GAAGL,SAAS,CAACb,KAAK,CAAC;YAC7B,IAAIkB,IAAI,KAAKC,SAAS,IAAItE,aAAa,CAAC+B,IAAI,CAACsC,IAAI,CAAC,EAAE;cAClD5C,KAAK,CAAC0B,KAAK,CAAW,GAAGkB,IAAI;YAC/B,CAAC,MAAM;cACL5C,KAAK,CAAC0B,KAAK,CAAW,GAAG,EAAE;YAC7B;UACF;UACAP,SAAS,CAAC,CAAC;QACb;MACF;IACF;IAEA,SAAS2B,OAAOA,CAACrC,KAAqB,EAAE;MACtC,MAAMsC,OAAO,GAAG,CACdtC,KAAK,CAACuC,aAAa,IAAKC,MAAM,CAASD,aAAa,EACpDE,OAAO,CAAC,MAAM,CAAC;MACjB,IAAIC,KAAK,CAACvE,MAAM,CAACmE,OAAO,CAAC,CAAC,EAAE;QAC1BtC,KAAK,CAAC0B,cAAc,CAAC,CAAC;QACtBG,QAAQ,CAACS,OAAO,CAAC;MACnB;IACF;IAEA,SAASK,QAAQA,CAAA,EAAG;MAClB,IACE1E,KAAK,CAACM,cAAc,IACpBgB,KAAK,CAAC,CAAC,CAAC,IACRA,KAAK,CAAC,CAAC,CAAC,IACRA,KAAK,CAAC,CAAC,CAAC,IACRA,KAAK,CAAC,CAAC,CAAC,IACR,CAACA,KAAK,CAAC,CAAC,CAAC,EACT;QACA,IAAI,OAAOtB,KAAK,CAACM,cAAc,KAAK,SAAS,EAAE;UAC7CgB,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI;QACjB,CAAC,MAAM;UACLA,KAAK,CAAC,CAAC,CAAC,GAAGtB,KAAK,CAACM,cAAc,CAAC+B,QAAQ,CAAC,CAAC;QAC5C;QACAI,SAAS,CAAC,CAAC;MACb;IACF;;IAEA;IACA,SAASH,UAAUA,CAACR,EAAU,EAAEH,KAAU,EAAE;MAC1C1C,QAAQ,CAAC,MAAM;QACbqC,KAAK,CAACQ,EAAE,CAAC,GAAGH,KAAK;QACjBc,SAAS,CAAC,CAAC;MACb,CAAC,CAAC;IACJ;IAEA,SAASD,aAAaA,CAACmC,SAAiB,EAAE;MACxC,MAAMC,MAAM,GAAGD,SAAS,GAAG,CAAC;MAC5B,IAAIC,MAAM,GAAG,CAAC,EAAE;QACd,MAAMC,MAAM,GAAGzD,MAAM,CAACO,KAAK,CAACiD,MAAM,CAAqB;QACvDC,MAAM,CAACjE,KAAK,CAAC,CAAC;QACdiE,MAAM,CAACrB,cAAc,GAAG,CAAC;MAC3B;IACF;IAEA,SAASF,aAAaA,CAACqB,SAAiB,EAAE;MACxC,MAAMG,MAAM,GAAGH,SAAS,GAAG,CAAC;MAC5B,IAAIG,MAAM,GAAG,CAAC,CAAC,EAAE;QACf,MAAMD,MAAM,GAAGzD,MAAM,CAACO,KAAK,CAACmD,MAAM,CAAqB;QACvDD,MAAM,CAACjE,KAAK,CAAC,CAAC;QACdiE,MAAM,CAACrB,cAAc,GAAGqB,MAAM,CAAClD,KAAK,CAACY,MAAM,GAAG,CAAC;MACjD;IACF;IAEA,SAASE,SAASA,CAAA,EAAG;MACnBpB,KAAK,CAACM,KAAK,GAAGoD,SAAS,CAAC,CAAC;IAC3B;IAEA,SAASA,SAASA,CAAA,EAAW;MAC3B,IACEzD,KAAK,CAAC,CAAC,CAAC,KAAK,EAAE,IACfA,KAAK,CAAC,CAAC,CAAC,KAAK,EAAE,IACfA,KAAK,CAAC,CAAC,CAAC,KAAK,EAAE,IACfA,KAAK,CAAC,CAAC,CAAC,KAAK,EAAE,EACf;QACA,OAAO,EAAE;MACX;MACA,OAAQ,GAAEA,KAAK,CAAC,CAAC,CAAE,IAAGA,KAAK,CAAC,CAAC,CAAE,IAAGA,KAAK,CAAC,CAAC,CAAE,IAAGA,KAAK,CAAC,CAAC,CAAE,GACrDtB,KAAK,CAACK,MAAM,GAAG,GAAG,GAAGiB,KAAK,CAAC,CAAC,CAAC,GAAG,EACjC,EAAC;IACJ;IAEA,MAAM0D,OAAO,GAAGlG,QAAQ,CAAC,MAAM;MAC7B,OAAO2C,YAAY,CAACE,KAAK,CAACY,MAAM,GAAG,CAAC;IACtC,CAAC,CAAC;IAEFlD,KAAK,CACHgC,KAAK,EACJe,GAAuB,IAAK;MAC3B,IAAIA,GAAG,KAAK,EAAE,EAAE;QACd,KAAK,IAAIY,KAAK,GAAG,CAAC,EAAEA,KAAK,GAAG,CAAC,EAAEA,KAAK,IAAI,CAAC,EAAE;UACzC1B,KAAK,CAAC0B,KAAK,CAAW,GAAG,EAAE;UAC3BzB,SAAS,CAACyB,KAAK,CAAW,GAAG,EAAE;QACjC;QACA;MACF,CAAC,MAAM;QACLY,QAAQ,CAACxB,GAAG,CAAC;MACf;IACF,CAAC,EACD;MAAE6C,SAAS,EAAE;IAAK,CACpB,CAAC;IAED5F,KAAK,CAAC2F,OAAO,EAAG5C,GAAY,IAAK;MAC/B,IAAI,CAACA,GAAG,EAAE;QACRsC,QAAQ,CAAC,CAAC;MACZ;IACF,CAAC,CAAC;IAEFrF,KAAK,CAACmC,SAAS,EAAGY,GAAY,IAAK;MACjC,IAAIA,GAAG,EAAE;QACPnB,IAAI,CAAC,OAAO,CAAC;MACf,CAAC,MAAM;QACLA,IAAI,CAAC,MAAM,CAAC;MACd;IACF,CAAC,CAAC;IAEF1B,SAAS,CAAC,MAAM;MACd6B,MAAM,CAACO,KAAK,GAAG,EAAE;MACjB,OAAAuD,YAAA,CAAAzF,MAAA,EAAA0F,WAAA;QAAA,OAEShE,OAAO;QAAA,SACL,CACLvB,IAAI,EACJD,YAAY,EACZ;UAAE,CAAE,GAAEA,YAAa,QAAO,GAAGK,KAAK,CAACG;QAAK,CAAC;MAC1C,GACGX,WAAW,CAACQ,KAAK,EAAEP,MAAM,CAACO,KAAK,CAAC;QAGlCoF,OAAO,EAAE,SAAAA,CAAA;UAAA,SAAAC,IAAA,GAAAC,SAAA,CAAA/C,MAAA,EAAIgD,IAAI,OAAAC,KAAA,CAAAH,IAAA,GAAAI,IAAA,MAAAA,IAAA,GAAAJ,IAAA,EAAAI,IAAA;YAAJF,IAAI,CAAAE,IAAA,IAAAH,SAAA,CAAAG,IAAA;UAAA;UAAA,OAAYzE,KAAK,CAACoE,OAAO,GAAG,GAAGG,IAAI,CAAC;QAAA;QACrDG,OAAO,EAAGC,YAAiB,IAAK;UAC9B,OAAAT,YAAA,QAAAC,WAAA;YAAA,SAEW,CAAE,GAAExF,YAAa,SAAQ;UAAC,GAC7BX,UAAU,CAAC;YAAE,SAAS,EAAE2G,YAAY,CAACC;UAAO,CAAC,CAAC;YAAA,OAC7C1E;UAAM,KAET,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAc2E,GAAG,CAAE/D,EAAE,IAAK;YACzC,MAAMgE,UAAU,GAAG1G,KAAK,CAACkC,KAAK,EAAEQ,EAAE,CAAC;YACnC,OACE,CAAE,CAAC9B,KAAK,CAACK,MAAM,IAAIyB,EAAE,GAAG,CAAC,IAAK9B,KAAK,CAACK,MAAM,KAAK,CAAA6E,YAAA;cAAA,SACjC,CAAE,GAAEvF,YAAa,QAAO;YAAC,IAAAuF,YAAA;cAAA,OAE3Ba,EAAE,IAAK3E,MAAM,CAACO,KAAK,CAACiB,IAAI,CAACmD,EAAE,CAAC;cAAA,MAC7B,GAAEJ,YAAY,CAACC,MAAO,WAAU9D,EAAG,EAAC;cAAA,SAClCgE,UAAU,CAACnE,KAAK;cAAA,SAChB,CAAE,GAAEhC,YAAa,cAAa,CAAC;cAAA,YAC5BK,KAAK,CAACgG,QAAQ,IAAIhG,KAAK,CAACiG,OAAO;cAAA,YAC/BjG,KAAK,CAACkG,QAAQ;cAAA;cAAA,aAEbpE,EAAE,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC;cAAA,WACjBqE,MAAM,IAAKtE,OAAO,CAACC,EAAE,EAAEqE,MAAM,CAAC;cAAA,WAC9BA,MAAM,IAAKzD,OAAO,CAACZ,EAAE,EAAEqE,MAAM,CAAC;cAAA,UAC/BA,MAAM,IAAKtD,MAAM,CAACf,EAAE,EAAEqE,MAAM,CAAC;cAAA,YAC3BA,MAAM,IAAKjD,QAAQ,CAACpB,EAAE,EAAEqE,MAAM,CAAC;cAAA,aAC9BA,MAAM,IAAKhD,SAAS,CAACrB,EAAE,EAAEqE,MAAM,CAAC;cAAA,WAClCA,MAAM,IAAKxC,OAAO,CAAC7B,EAAE,EAAEqE,MAAM,CAAC;cAAA,WAC/B/B;YAAO,YAGpBtC,EAAE,KAAK,CAAC,KACJ,CAAC9B,KAAK,CAACK,MAAM,IAAIyB,EAAE,GAAG,CAAC,IAAK9B,KAAK,CAACK,MAAM,CAAC,IAAA6E,YAAA;cAAA,SAC7B,CAAE,GAAEvF,YAAa,QAAO;YAAC,IAClCmC,EAAE,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,EAEtB,CACJ;UAEL,CAAC,CAAC;QAGR,CAAC;QACDsE,QAAQ,EAAE,SAAAA,CAAA;UAAA,SAAAC,KAAA,GAAAf,SAAA,CAAA/C,MAAA,EAAIgD,IAAI,OAAAC,KAAA,CAAAa,KAAA,GAAAC,KAAA,MAAAA,KAAA,GAAAD,KAAA,EAAAC,KAAA;YAAJf,IAAI,CAAAe,KAAA,IAAAhB,SAAA,CAAAgB,KAAA;UAAA;UAAA,OAAYtF,KAAK,CAACoF,QAAQ,GAAG,GAAGb,IAAI,CAAC;QAAA;QACvDgB,KAAK,EAAEvF,KAAK,CAACuF,KAAK,KAAK,MAAMvF,KAAK,CAACuF,KAAK,GAAG,CAAC,CAAC;QAC7C,aAAa,EACXvF,KAAK,CAAC,aAAa,CAAC,KAAK,MAAMA,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC;MAAC;IAIlE,CAAC,CAAC;IAEF,OAAO,CAAC,CAAC;EACX;AACF,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export * from "./YIpv4Field.mjs";
2
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","names":[],"sources":["../../../src/components/ip-field/index.ts"],"sourcesContent":["export * from './YIpv4Field';\r\n"],"mappings":""}
@@ -1,5 +1,6 @@
1
- import { mergeProps as _mergeProps, withDirectives as _withDirectives, resolveDirective as _resolveDirective, vShow as _vShow, createVNode as _createVNode, Fragment as _Fragment } from "vue";
1
+ import { withDirectives as _withDirectives, mergeProps as _mergeProps, resolveDirective as _resolveDirective, vShow as _vShow, createVNode as _createVNode, Fragment as _Fragment } from "vue";
2
2
  import { Teleport, Transition, computed, defineComponent, getCurrentInstance, mergeProps, reactive, ref, shallowRef, toRef } from 'vue';
3
+ import { useModelDuplex } from "../../composables/communication.mjs";
3
4
  import { useRender } from "../../composables/component.mjs";
4
5
  import { pressCoordinateProps, useCoordinate } from "../../composables/coordinate/index.mjs";
5
6
  import { pressDimensionPropsOptions, useDimension } from "../../composables/dimension.mjs";
@@ -9,8 +10,10 @@ import { useLazy } from "../../composables/timing.mjs";
9
10
  import { PolyTransition, polyTransitionPropOptions, usePolyTransition } from "../../composables/transition.mjs";
10
11
  import { ComplementClick } from "../../directives/complement-click/index.mjs";
11
12
  import { bindClasses, propsFactory } from "../../util/vue-component.mjs";
12
- import "./YLayer.scss";
13
13
  import { pressBasePropsOptions, useBase } from "./base.mjs";
14
+ import { pressContentPropsOptions, useContent } from "./content.mjs";
15
+ import { pressScrollStrategyProps, useScrollStrategies } from "./scroll-strategies.mjs";
16
+ import "./YLayer.scss";
14
17
  export const pressYLayerProps = propsFactory({
15
18
  modelValue: {
16
19
  type: Boolean
@@ -57,10 +60,13 @@ export const pressYLayerProps = propsFactory({
57
60
  type: [Number, String],
58
61
  default: 2000
59
62
  },
63
+ contained: Boolean,
60
64
  ...pressThemePropsOptions(),
61
65
  ...polyTransitionPropOptions,
62
66
  ...pressBasePropsOptions(),
67
+ ...pressContentPropsOptions(),
63
68
  ...pressCoordinateProps(),
69
+ ...pressScrollStrategyProps(),
64
70
  ...pressDimensionPropsOptions()
65
71
  }, 'YLayer');
66
72
  export const YLayer = defineComponent({
@@ -92,6 +98,7 @@ export const YLayer = defineComponent({
92
98
  const vm = getCurrentInstance();
93
99
  const scrim$ = ref();
94
100
  const content$ = ref();
101
+ const root$ = ref();
95
102
  const {
96
103
  base,
97
104
  base$,
@@ -113,14 +120,18 @@ export const YLayer = defineComponent({
113
120
  const {
114
121
  dimensionStyles
115
122
  } = useDimension(props);
123
+ const model = useModelDuplex(props);
116
124
  const active = computed({
117
125
  get: () => {
118
- return !!props.modelValue;
126
+ return !!model.value;
119
127
  },
120
128
  set: v => {
121
- emit('update:modelValue', v);
129
+ if (!(v && props.disabled)) model.value = v;
122
130
  }
123
131
  });
132
+ const {
133
+ contentEvents
134
+ } = useContent(props, active);
124
135
  const finish = shallowRef(false);
125
136
  const hovered = ref(false);
126
137
  const disabled = toRef(props, 'disabled');
@@ -137,6 +148,13 @@ export const YLayer = defineComponent({
137
148
  base,
138
149
  active
139
150
  });
151
+ useScrollStrategies(props, {
152
+ root: root$,
153
+ contentEl: content$,
154
+ active,
155
+ baseEl: base,
156
+ updateCoordinate
157
+ });
140
158
  function onClickComplementLayer(mouseEvent) {
141
159
  emit('click:complement', mouseEvent);
142
160
  if (!props.modal) {
@@ -229,15 +247,16 @@ export const YLayer = defineComponent({
229
247
  "to": layerGroup.value
230
248
  }, {
231
249
  default: () => [rendered.value && _createVNode("div", _mergeProps({
232
- "class": {
250
+ "class": [{
233
251
  'y-layer': true,
234
252
  'y-layer--finish': finish.value,
235
- ...computedClass.value,
236
- [themeClasses.value ?? '']: true
237
- },
253
+ 'y-layer--contained': props.contained,
254
+ ...computedClass.value
255
+ }, themeClasses.value],
238
256
  "onMouseenter": onMouseenter,
239
257
  "onMouseleave": onMouseleave,
240
- "style": computedStyle.value
258
+ "style": computedStyle.value,
259
+ "ref": root$
241
260
  }, attrs), [_createVNode(Transition, {
242
261
  "name": "fade",
243
262
  "appear": true
@@ -255,7 +274,7 @@ export const YLayer = defineComponent({
255
274
  "onAfterLeave": onAfterLeave,
256
275
  "appear": true
257
276
  }, polyTransitionBindProps.value), {
258
- default: () => [_withDirectives(_createVNode("div", {
277
+ default: () => [_withDirectives(_createVNode("div", _mergeProps({
259
278
  "class": {
260
279
  'y-layer__content': true,
261
280
  ...computedContentClasses.value
@@ -264,9 +283,10 @@ export const YLayer = defineComponent({
264
283
  ...dimensionStyles.value,
265
284
  ...coordinateStyles.value,
266
285
  ...props.contentStyles
267
- }],
286
+ }]
287
+ }, contentEvents.value, {
268
288
  "ref": content$
269
- }, [slots.default?.({
289
+ }), [slots.default?.({
270
290
  active: active.value
271
291
  })]), [[_vShow, active.value], [_resolveDirective("complement-click"), {
272
292
  ...complementClickOption
@@ -1 +1 @@
1
- {"version":3,"file":"YLayer.mjs","names":["Teleport","Transition","computed","defineComponent","getCurrentInstance","mergeProps","reactive","ref","shallowRef","toRef","useRender","pressCoordinateProps","useCoordinate","pressDimensionPropsOptions","useDimension","useLayerGroup","pressThemePropsOptions","useLocalTheme","useLazy","PolyTransition","polyTransitionPropOptions","usePolyTransition","ComplementClick","bindClasses","propsFactory","pressBasePropsOptions","useBase","pressYLayerProps","modelValue","type","Boolean","scrim","scrimOpacity","Number","eager","classes","Array","String","Object","contentClasses","closeClickScrim","contentStyles","default","disabled","openOnHover","openDelay","closeDelay","zIndex","YLayer","name","inheritAttrs","components","directives","props","modal","emits","value","mouseEvent","afterLeave","slots","setup","_ref","emit","expose","attrs","vm","scrim$","content$","base","base$","baseEl","baseSlot","baseFromSlotEl","themeClasses","layerGroup","layerGroupState","getActiveLayers","polyTransitionBindProps","dimensionStyles","active","get","set","v","finish","hovered","lazyValue","onAfterUpdate","rendered","coordinateStyles","updateCoordinate","contentEl","onClickComplementLayer","target","closeConditional","complementClickOption","handler","determine","include","onAfterEnter","onAfterLeave","onClickScrim","onMouseenter","event","onMouseleave","computedStyle","toString","computedClass","boundClasses","computedContentClasses","isMe","vnode","slotBase","class","_createVNode","_Fragment","_mergeProps","_withDirectives","_vShow","_resolveDirective"],"sources":["../../../src/components/layer/YLayer.tsx"],"sourcesContent":["import type {\r\n CSSProperties,\r\n ComponentInternalInstance,\r\n PropType,\r\n SlotsType,\r\n} from 'vue';\r\nimport {\r\n Teleport,\r\n Transition,\r\n computed,\r\n defineComponent,\r\n getCurrentInstance,\r\n mergeProps,\r\n reactive,\r\n ref,\r\n shallowRef,\r\n toRef,\r\n watchEffect,\r\n} from 'vue';\r\n\r\nimport { useRender } from '../../composables/component';\r\nimport {\r\n pressCoordinateProps,\r\n useCoordinate,\r\n} from '../../composables/coordinate';\r\nimport {\r\n pressDimensionPropsOptions,\r\n useDimension,\r\n} from '../../composables/dimension';\r\nimport { useLayerGroup } from '../../composables/layer-group';\r\nimport { pressThemePropsOptions, useLocalTheme } from '../../composables/theme';\r\nimport { useLazy } from '../../composables/timing';\r\nimport {\r\n PolyTransition,\r\n polyTransitionPropOptions,\r\n usePolyTransition,\r\n} from '../../composables/transition';\r\nimport {\r\n ComplementClick,\r\n ComplementClickBindingOptions,\r\n} from '../../directives/complement-click';\r\nimport { bindClasses, propsFactory } from '../../util/vue-component';\r\n\r\nimport './YLayer.scss';\r\nimport { pressBasePropsOptions, useBase } from './base';\r\n\r\nexport const pressYLayerProps = propsFactory(\r\n {\r\n modelValue: {\r\n type: Boolean as PropType<boolean>,\r\n },\r\n scrim: {\r\n type: Boolean as PropType<boolean>,\r\n },\r\n scrimOpacity: {\r\n type: Number as PropType<number>,\r\n },\r\n eager: {\r\n type: Boolean as PropType<boolean>,\r\n },\r\n classes: {\r\n type: [Array, String, Object] as PropType<\r\n string[] | string | Record<string, any>\r\n >,\r\n },\r\n contentClasses: {\r\n type: [Array, String, Object] as PropType<\r\n string[] | string | Record<string, any>\r\n >,\r\n },\r\n closeClickScrim: {\r\n type: Boolean as PropType<boolean>,\r\n },\r\n contentStyles: {\r\n type: Object as PropType<CSSProperties>,\r\n default: () => {},\r\n },\r\n disabled: {\r\n type: Boolean as PropType<boolean>,\r\n default: false,\r\n },\r\n openOnHover: {\r\n type: Boolean as PropType<boolean>,\r\n default: false,\r\n },\r\n openDelay: {\r\n type: Number as PropType<number>,\r\n default: 200,\r\n },\r\n closeDelay: {\r\n type: Number as PropType<number>,\r\n default: 200,\r\n },\r\n zIndex: {\r\n type: [Number, String] as PropType<number | string>,\r\n default: 2000,\r\n },\r\n ...pressThemePropsOptions(),\r\n ...polyTransitionPropOptions,\r\n ...pressBasePropsOptions(),\r\n ...pressCoordinateProps(),\r\n ...pressDimensionPropsOptions(),\r\n },\r\n 'YLayer',\r\n);\r\n\r\nexport const YLayer = defineComponent({\r\n name: 'YLayer',\r\n inheritAttrs: false,\r\n components: {\r\n PolyTransition,\r\n },\r\n directives: {\r\n ComplementClick,\r\n },\r\n props: {\r\n modal: Boolean as PropType<boolean>,\r\n ...pressYLayerProps(),\r\n },\r\n emits: {\r\n 'update:modelValue': (value: boolean) => true,\r\n 'click:complement': (mouseEvent: MouseEvent) => true,\r\n afterLeave: () => true,\r\n },\r\n slots: Object as SlotsType<{\r\n base: any;\r\n default: any;\r\n }>,\r\n setup(props, { emit, expose, attrs, slots }) {\r\n const vm = getCurrentInstance();\r\n\r\n const scrim$ = ref<HTMLElement>();\r\n const content$ = ref<HTMLElement>();\r\n\r\n const { base, base$, baseEl, baseSlot, baseFromSlotEl } = useBase(props);\r\n\r\n const { themeClasses } = useLocalTheme(props);\r\n const { layerGroup, layerGroupState, getActiveLayers } = useLayerGroup();\r\n const { polyTransitionBindProps } = usePolyTransition(props);\r\n const { dimensionStyles } = useDimension(props);\r\n const active = computed<boolean>({\r\n get: (): boolean => {\r\n return !!props.modelValue;\r\n },\r\n set: (v: boolean) => {\r\n emit('update:modelValue', v);\r\n },\r\n });\r\n const finish = shallowRef(false);\r\n const hovered = ref(false);\r\n\r\n const disabled = toRef(props, 'disabled');\r\n const { lazyValue, onAfterUpdate } = useLazy(toRef(props, 'eager'), active);\r\n const rendered = computed<boolean>(\r\n () => !disabled.value && (lazyValue.value || active.value),\r\n );\r\n\r\n const { coordinateStyles, updateCoordinate } = useCoordinate(props, {\r\n contentEl: content$,\r\n base,\r\n active,\r\n });\r\n\r\n function onClickComplementLayer(mouseEvent: MouseEvent) {\r\n emit('click:complement', mouseEvent);\r\n if (!props.modal) {\r\n if (\r\n scrim$.value !== null &&\r\n scrim$.value === mouseEvent.target &&\r\n props.closeClickScrim\r\n ) {\r\n active.value = false;\r\n }\r\n } else {\r\n // TODO: shrug ani\r\n }\r\n }\r\n\r\n function closeConditional(): boolean {\r\n return (\r\n (!props.openOnHover || (props.openOnHover && !hovered.value)) &&\r\n active.value && finish.value\r\n ); // TODO: && groupTopLevel.value;\r\n }\r\n\r\n const complementClickOption = reactive<ComplementClickBindingOptions>({\r\n handler: onClickComplementLayer,\r\n determine: closeConditional,\r\n include: () => [baseEl.value],\r\n });\r\n\r\n function onAfterEnter() {\r\n finish.value = true;\r\n }\r\n\r\n function onAfterLeave() {\r\n onAfterUpdate();\r\n finish.value = false;\r\n emit('afterLeave');\r\n }\r\n\r\n function onClickScrim() {\r\n if (props.closeClickScrim) {\r\n active.value = false;\r\n }\r\n }\r\n\r\n function onMouseenter(event: Event) {\r\n hovered.value = true;\r\n }\r\n\r\n function onMouseleave(event: Event) {\r\n hovered.value = false;\r\n }\r\n\r\n const computedStyle = computed(() => {\r\n return {\r\n zIndex: (props.zIndex ?? '2000').toString(),\r\n };\r\n });\r\n\r\n const computedClass = computed<Record<string, boolean>>(() => {\r\n const { classes } = props;\r\n const boundClasses = bindClasses(classes);\r\n return {\r\n ...boundClasses,\r\n 'y-layer--active': !!active.value,\r\n };\r\n });\r\n\r\n const computedContentClasses = computed<Record<string, boolean>>(() => {\r\n const boundClasses = bindClasses(props.contentClasses);\r\n return {\r\n ...boundClasses,\r\n };\r\n });\r\n\r\n expose({\r\n scrim$,\r\n base$,\r\n content$: computed(() => content$.value),\r\n baseEl,\r\n active,\r\n onAfterUpdate,\r\n updateCoordinate,\r\n hovered,\r\n finish,\r\n modal: computed(() => props.modal),\r\n getActiveLayers,\r\n isMe: (vnode: ComponentInternalInstance) => {\r\n return vnode === vm;\r\n },\r\n });\r\n\r\n useRender(() => {\r\n const slotBase = slots.base?.({\r\n active: active.value,\r\n props: mergeProps({\r\n ref: base$,\r\n class: {\r\n 'y-layer-base': true,\r\n 'y-layer-base--active': active.value,\r\n },\r\n }),\r\n });\r\n baseSlot.value = slotBase;\r\n return (\r\n <>\r\n {slotBase}\r\n <Teleport disabled={!layerGroup.value} to={layerGroup.value as any}>\r\n {rendered.value && (\r\n <div\r\n class={{\r\n 'y-layer': true,\r\n 'y-layer--finish': finish.value,\r\n ...computedClass.value,\r\n [themeClasses.value ?? '']: true,\r\n }}\r\n onMouseenter={onMouseenter}\r\n onMouseleave={onMouseleave}\r\n style={computedStyle.value}\r\n {...attrs}\r\n >\r\n <Transition name=\"fade\" appear>\r\n {active.value && props.scrim && (\r\n <div\r\n class=\"y-layer__scrim\"\r\n style={{ '--y-layer-scrim-opacity': props.scrimOpacity }}\r\n onClick={onClickScrim}\r\n ref=\"scrim$\"\r\n ></div>\r\n )}\r\n </Transition>\r\n <PolyTransition\r\n onAfterEnter={onAfterEnter}\r\n onAfterLeave={onAfterLeave}\r\n appear\r\n {...polyTransitionBindProps.value}\r\n >\r\n <div\r\n v-show={active.value}\r\n v-complement-click={{ ...complementClickOption }}\r\n class={{\r\n 'y-layer__content': true,\r\n ...computedContentClasses.value,\r\n }}\r\n style={[\r\n {\r\n ...dimensionStyles.value,\r\n ...coordinateStyles.value,\r\n ...props.contentStyles,\r\n },\r\n ]}\r\n ref={content$}\r\n >\r\n {slots.default?.({ active: active.value })}\r\n </div>\r\n </PolyTransition>\r\n </div>\r\n )}\r\n </Teleport>\r\n </>\r\n );\r\n });\r\n\r\n return {\r\n complementClickOption,\r\n layerGroup,\r\n active,\r\n finish,\r\n rendered,\r\n lazyValue,\r\n onAfterUpdate: onAfterUpdate as () => void,\r\n scrim$,\r\n content$,\r\n base$,\r\n baseEl,\r\n baseFromSlotEl,\r\n polyTransitionBindProps,\r\n coordinateStyles,\r\n layerGroupState,\r\n getActiveLayers,\r\n };\r\n },\r\n});\r\n\r\nexport type YLayer = InstanceType<typeof YLayer>;\r\n"],"mappings":"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"}
1
+ {"version":3,"file":"YLayer.mjs","names":["Teleport","Transition","computed","defineComponent","getCurrentInstance","mergeProps","reactive","ref","shallowRef","toRef","useModelDuplex","useRender","pressCoordinateProps","useCoordinate","pressDimensionPropsOptions","useDimension","useLayerGroup","pressThemePropsOptions","useLocalTheme","useLazy","PolyTransition","polyTransitionPropOptions","usePolyTransition","ComplementClick","bindClasses","propsFactory","pressBasePropsOptions","useBase","pressContentPropsOptions","useContent","pressScrollStrategyProps","useScrollStrategies","pressYLayerProps","modelValue","type","Boolean","scrim","scrimOpacity","Number","eager","classes","Array","String","Object","contentClasses","closeClickScrim","contentStyles","default","disabled","openOnHover","openDelay","closeDelay","zIndex","contained","YLayer","name","inheritAttrs","components","directives","props","modal","emits","value","mouseEvent","afterLeave","slots","setup","_ref","emit","expose","attrs","vm","scrim$","content$","root$","base","base$","baseEl","baseSlot","baseFromSlotEl","themeClasses","layerGroup","layerGroupState","getActiveLayers","polyTransitionBindProps","dimensionStyles","model","active","get","set","v","contentEvents","finish","hovered","lazyValue","onAfterUpdate","rendered","coordinateStyles","updateCoordinate","contentEl","root","onClickComplementLayer","target","closeConditional","complementClickOption","handler","determine","include","onAfterEnter","onAfterLeave","onClickScrim","onMouseenter","event","onMouseleave","computedStyle","toString","computedClass","boundClasses","computedContentClasses","isMe","vnode","slotBase","class","_createVNode","_Fragment","_mergeProps","_withDirectives","_vShow","_resolveDirective"],"sources":["../../../src/components/layer/YLayer.tsx"],"sourcesContent":["import type {\n CSSProperties,\n ComponentInternalInstance,\n PropType,\n SlotsType,\n} from 'vue';\nimport {\n Teleport,\n Transition,\n computed,\n defineComponent,\n getCurrentInstance,\n mergeProps,\n reactive,\n ref,\n shallowRef,\n toRef,\n watchEffect,\n} from 'vue';\n\nimport { useModelDuplex } from '../../composables/communication';\nimport { useRender } from '../../composables/component';\nimport {\n pressCoordinateProps,\n useCoordinate,\n} from '../../composables/coordinate';\nimport {\n pressDimensionPropsOptions,\n useDimension,\n} from '../../composables/dimension';\nimport { useLayerGroup } from '../../composables/layer-group';\nimport { pressThemePropsOptions, useLocalTheme } from '../../composables/theme';\nimport { useLazy } from '../../composables/timing';\nimport {\n PolyTransition,\n polyTransitionPropOptions,\n usePolyTransition,\n} from '../../composables/transition';\nimport {\n ComplementClick,\n ComplementClickBindingOptions,\n} from '../../directives/complement-click';\nimport { bindClasses, propsFactory } from '../../util/vue-component';\nimport { pressBasePropsOptions, useBase } from './base';\nimport { pressContentPropsOptions, useContent } from './content';\nimport {\n pressScrollStrategyProps,\n useScrollStrategies,\n} from './scroll-strategies';\n\nimport './YLayer.scss';\n\nexport const pressYLayerProps = propsFactory(\n {\n modelValue: {\n type: Boolean as PropType<boolean>,\n },\n scrim: {\n type: Boolean as PropType<boolean>,\n },\n scrimOpacity: {\n type: Number as PropType<number>,\n },\n eager: {\n type: Boolean as PropType<boolean>,\n },\n classes: {\n type: [Array, String, Object] as PropType<\n string[] | string | Record<string, any>\n >,\n },\n contentClasses: {\n type: [Array, String, Object] as PropType<\n string[] | string | Record<string, any>\n >,\n },\n closeClickScrim: {\n type: Boolean as PropType<boolean>,\n },\n contentStyles: {\n type: Object as PropType<CSSProperties>,\n default: () => {},\n },\n disabled: {\n type: Boolean as PropType<boolean>,\n default: false,\n },\n openOnHover: {\n type: Boolean as PropType<boolean>,\n default: false,\n },\n openDelay: {\n type: Number as PropType<number>,\n default: 200,\n },\n closeDelay: {\n type: Number as PropType<number>,\n default: 200,\n },\n zIndex: {\n type: [Number, String] as PropType<number | string>,\n default: 2000,\n },\n contained: Boolean,\n ...pressThemePropsOptions(),\n ...polyTransitionPropOptions,\n ...pressBasePropsOptions(),\n ...pressContentPropsOptions(),\n ...pressCoordinateProps(),\n ...pressScrollStrategyProps(),\n ...pressDimensionPropsOptions(),\n },\n 'YLayer',\n);\n\nexport const YLayer = defineComponent({\n name: 'YLayer',\n inheritAttrs: false,\n components: {\n PolyTransition,\n },\n directives: {\n ComplementClick,\n },\n props: {\n modal: Boolean as PropType<boolean>,\n ...pressYLayerProps(),\n },\n emits: {\n 'update:modelValue': (value: boolean) => true,\n 'click:complement': (mouseEvent: MouseEvent) => true,\n afterLeave: () => true,\n },\n slots: Object as SlotsType<{\n base: any;\n default: any;\n }>,\n setup(props, { emit, expose, attrs, slots }) {\n const vm = getCurrentInstance();\n\n const scrim$ = ref<HTMLElement>();\n const content$ = ref<HTMLElement>();\n const root$ = ref<HTMLElement>();\n\n const { base, base$, baseEl, baseSlot, baseFromSlotEl } = useBase(props);\n\n const { themeClasses } = useLocalTheme(props);\n const { layerGroup, layerGroupState, getActiveLayers } = useLayerGroup();\n const { polyTransitionBindProps } = usePolyTransition(props);\n const { dimensionStyles } = useDimension(props);\n const model = useModelDuplex(props);\n\n const active = computed({\n get: (): boolean => {\n return !!model.value;\n },\n set: (v: boolean) => {\n if (!(v && props.disabled)) model.value = v;\n },\n });\n const { contentEvents } = useContent(props, active);\n const finish = shallowRef(false);\n const hovered = ref(false);\n\n const disabled = toRef(props, 'disabled');\n const { lazyValue, onAfterUpdate } = useLazy(toRef(props, 'eager'), active);\n const rendered = computed<boolean>(\n () => !disabled.value && (lazyValue.value || active.value),\n );\n\n const { coordinateStyles, updateCoordinate } = useCoordinate(props, {\n contentEl: content$,\n base,\n active,\n });\n useScrollStrategies(props, {\n root: root$,\n contentEl: content$,\n active,\n baseEl: base,\n updateCoordinate,\n });\n\n function onClickComplementLayer(mouseEvent: MouseEvent) {\n emit('click:complement', mouseEvent);\n if (!props.modal) {\n if (\n scrim$.value !== null &&\n scrim$.value === mouseEvent.target &&\n props.closeClickScrim\n ) {\n active.value = false;\n }\n } else {\n // TODO: shrug ani\n }\n }\n\n function closeConditional(): boolean {\n return (\n (!props.openOnHover || (props.openOnHover && !hovered.value)) &&\n active.value &&\n finish.value\n ); // TODO: && groupTopLevel.value;\n }\n\n const complementClickOption = reactive<ComplementClickBindingOptions>({\n handler: onClickComplementLayer,\n determine: closeConditional,\n include: () => [baseEl.value],\n });\n\n function onAfterEnter() {\n finish.value = true;\n }\n\n function onAfterLeave() {\n onAfterUpdate();\n finish.value = false;\n emit('afterLeave');\n }\n\n function onClickScrim() {\n if (props.closeClickScrim) {\n active.value = false;\n }\n }\n\n function onMouseenter(event: Event) {\n hovered.value = true;\n }\n\n function onMouseleave(event: Event) {\n hovered.value = false;\n }\n\n const computedStyle = computed(() => {\n return {\n zIndex: (props.zIndex ?? '2000').toString(),\n };\n });\n\n const computedClass = computed<Record<string, boolean>>(() => {\n const { classes } = props;\n const boundClasses = bindClasses(classes);\n return {\n ...boundClasses,\n 'y-layer--active': !!active.value,\n };\n });\n\n const computedContentClasses = computed<Record<string, boolean>>(() => {\n const boundClasses = bindClasses(props.contentClasses);\n return {\n ...boundClasses,\n };\n });\n\n expose({\n scrim$,\n base$,\n content$: computed(() => content$.value),\n baseEl,\n active,\n onAfterUpdate,\n updateCoordinate,\n hovered,\n finish,\n modal: computed(() => props.modal),\n getActiveLayers,\n isMe: (vnode: ComponentInternalInstance) => {\n return vnode === vm;\n },\n });\n\n useRender(() => {\n const slotBase = slots.base?.({\n active: active.value,\n props: mergeProps({\n ref: base$,\n class: {\n 'y-layer-base': true,\n 'y-layer-base--active': active.value,\n },\n }),\n });\n baseSlot.value = slotBase;\n return (\n <>\n {slotBase}\n <Teleport disabled={!layerGroup.value} to={layerGroup.value as any}>\n {rendered.value && (\n <div\n class={[\n {\n 'y-layer': true,\n 'y-layer--finish': finish.value,\n 'y-layer--contained': props.contained,\n ...computedClass.value,\n },\n themeClasses.value,\n ]}\n onMouseenter={onMouseenter}\n onMouseleave={onMouseleave}\n style={computedStyle.value}\n ref={ root$ }\n {...attrs}\n >\n <Transition name=\"fade\" appear>\n {active.value && props.scrim && (\n <div\n class=\"y-layer__scrim\"\n style={{ '--y-layer-scrim-opacity': props.scrimOpacity }}\n onClick={onClickScrim}\n ref=\"scrim$\"\n ></div>\n )}\n </Transition>\n <PolyTransition\n onAfterEnter={onAfterEnter}\n onAfterLeave={onAfterLeave}\n appear\n {...polyTransitionBindProps.value}\n >\n <div\n v-show={active.value}\n v-complement-click={{ ...complementClickOption }}\n class={{\n 'y-layer__content': true,\n ...computedContentClasses.value,\n }}\n style={[\n {\n ...dimensionStyles.value,\n ...coordinateStyles.value,\n ...props.contentStyles,\n },\n ]}\n {...contentEvents.value}\n ref={content$}\n >\n {slots.default?.({ active: active.value })}\n </div>\n </PolyTransition>\n </div>\n )}\n </Teleport>\n </>\n );\n });\n\n return {\n complementClickOption,\n layerGroup,\n active,\n finish,\n rendered,\n lazyValue,\n onAfterUpdate: onAfterUpdate as () => void,\n scrim$,\n content$,\n base$,\n baseEl,\n baseFromSlotEl,\n polyTransitionBindProps,\n coordinateStyles,\n layerGroupState,\n getActiveLayers,\n };\n },\n});\n\nexport type YLayer = InstanceType<typeof YLayer>;\n"],"mappings":"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"}
@@ -16,7 +16,7 @@ export function useBase(props) {
16
16
  return undefined;
17
17
  });
18
18
  const base = computed(() => {
19
- if (baseEl.value) {
19
+ if (baseEl.value && !props.base) {
20
20
  return baseEl.value;
21
21
  }
22
22
  return getBase(props.base, vm);
@@ -1 +1 @@
1
- {"version":3,"file":"base.mjs","names":["computed","getCurrentInstance","ref","watchEffect","propsFactory","pressBasePropsOptions","base","String","Object","Array","useBase","props","vm","base$","baseSlot","baseEl","baseFromSlotEl","el","value","nodeType","Node","ELEMENT_NODE","undefined","getBase","isArray","toEl","$el","selector","ret","proxy","parentNode","hasAttribute","document","querySelector"],"sources":["../../../src/components/layer/base.ts"],"sourcesContent":["import {\n ComponentInternalInstance,\n ComponentPublicInstance,\n PropType,\n computed,\n getCurrentInstance,\n ref,\n watchEffect,\n} from 'vue';\n\nimport { propsFactory } from '../../util/vue-component';\n\nexport type BaseType =\n | string\n | Element\n | ComponentPublicInstance\n | [x: number, y: number]\n | undefined;\n\nexport const pressBasePropsOptions = propsFactory(\n {\n base: [String, Object, Array] as PropType<BaseType>,\n },\n 'YLayer.base',\n);\n\ninterface BaseProps {\n base: BaseType;\n}\n\nexport function useBase(props: BaseProps) {\n const vm = getCurrentInstance()!;\n\n const base$ = ref();\n const baseSlot = ref();\n const baseEl = ref<HTMLElement>();\n\n const baseFromSlotEl = computed(() => {\n const el = baseSlot.value?.[0]?.el;\n if (el && el.nodeType === Node.ELEMENT_NODE) {\n return el;\n }\n return undefined;\n });\n\n const base = computed(() => {\n if (baseEl.value) {\n return baseEl.value;\n }\n return getBase(props.base, vm);\n });\n\n watchEffect(() => {\n if (!base$.value) {\n if (!baseFromSlotEl.value && props.base && !Array.isArray(props.base)) {\n baseEl.value = base.value;\n return;\n }\n baseEl.value = baseFromSlotEl.value;\n return;\n }\n let toEl = base$.value;\n if (toEl.baseEl) {\n toEl = toEl.baseEl;\n }\n if (base$.value?.$el) {\n if (base$.value.$el.nodeType === Node.ELEMENT_NODE) {\n toEl = base$.value.$el;\n }\n }\n if (toEl?.nodeType !== Node.ELEMENT_NODE) {\n toEl = baseFromSlotEl.value;\n }\n baseEl.value = toEl;\n });\n\n return {\n base$,\n baseEl,\n baseSlot,\n base,\n baseFromSlotEl,\n };\n}\n\nfunction getBase(selector: BaseType, vm: ComponentInternalInstance) {\n if (!selector) return;\n\n let ret;\n\n if (selector === 'parent') {\n let el = vm?.proxy?.$el?.parentNode;\n while (el?.hasAttribute('data-base-parent')) {\n el = el.parentNode;\n }\n ret = el;\n }\n // Selector\n else if (typeof selector === 'string') {\n ret = document.querySelector(selector);\n }\n // Component\n else if ('$el' in selector) {\n ret = selector.$el;\n }\n // HTMLElement | Element | [x, y]\n else {\n ret = selector;\n }\n\n return ret;\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"base.mjs","names":["computed","getCurrentInstance","ref","watchEffect","propsFactory","pressBasePropsOptions","base","String","Object","Array","useBase","props","vm","base$","baseSlot","baseEl","baseFromSlotEl","el","value","nodeType","Node","ELEMENT_NODE","undefined","getBase","isArray","toEl","$el","selector","ret","proxy","parentNode","hasAttribute","document","querySelector"],"sources":["../../../src/components/layer/base.ts"],"sourcesContent":["import {\n ComponentInternalInstance,\n ComponentPublicInstance,\n PropType,\n computed,\n getCurrentInstance,\n ref,\n watchEffect,\n} from 'vue';\n\nimport { propsFactory } from '../../util/vue-component';\n\nexport type BaseType =\n | string\n | Element\n | ComponentPublicInstance\n | [x: number, y: number]\n | undefined;\n\nexport const pressBasePropsOptions = propsFactory(\n {\n base: [String, Object, Array] as PropType<BaseType>,\n },\n 'YLayer.base',\n);\n\ninterface BaseProps {\n base: BaseType;\n}\n\nexport function useBase(props: BaseProps) {\n const vm = getCurrentInstance()!;\n\n const base$ = ref();\n const baseSlot = ref();\n const baseEl = ref<HTMLElement>();\n\n const baseFromSlotEl = computed(() => {\n const el = baseSlot.value?.[0]?.el;\n if (el && el.nodeType === Node.ELEMENT_NODE) {\n return el;\n }\n return undefined;\n });\n\n const base = computed(() => {\n if (baseEl.value && !props.base) {\n return baseEl.value;\n }\n return getBase(props.base, vm);\n });\n\n watchEffect(() => {\n if (!base$.value) {\n if (!baseFromSlotEl.value && props.base && !Array.isArray(props.base)) {\n baseEl.value = base.value;\n return;\n }\n baseEl.value = baseFromSlotEl.value;\n return;\n }\n let toEl = base$.value;\n if (toEl.baseEl) {\n toEl = toEl.baseEl;\n }\n if (base$.value?.$el) {\n if (base$.value.$el.nodeType === Node.ELEMENT_NODE) {\n toEl = base$.value.$el;\n }\n }\n if (toEl?.nodeType !== Node.ELEMENT_NODE) {\n toEl = baseFromSlotEl.value;\n }\n baseEl.value = toEl;\n });\n\n return {\n base$,\n baseEl,\n baseSlot,\n base,\n baseFromSlotEl,\n };\n}\n\nfunction getBase(selector: BaseType, vm: ComponentInternalInstance) {\n if (!selector) return;\n\n let ret;\n\n if (selector === 'parent') {\n let el = vm?.proxy?.$el?.parentNode;\n while (el?.hasAttribute('data-base-parent')) {\n el = el.parentNode;\n }\n ret = el;\n }\n // Selector\n else if (typeof selector === 'string') {\n ret = document.querySelector(selector);\n }\n // Component\n else if ('$el' in selector) {\n ret = selector.$el;\n }\n // HTMLElement | Element | [x, y]\n else {\n ret = selector;\n }\n\n return ret;\n}\n"],"mappings":"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"}
@@ -0,0 +1,22 @@
1
+ import { computed } from 'vue';
2
+ import { propsFactory } from "../../util/vue-component.mjs";
3
+ export const pressContentPropsOptions = propsFactory({
4
+ closeClickContent: {
5
+ type: Boolean
6
+ }
7
+ }, 'YLayer.content');
8
+ export function useContent(props, active) {
9
+ const contentEvents = computed(() => {
10
+ const events = {};
11
+ if (props.closeClickContent) {
12
+ events.onClick = e => {
13
+ active.value = false;
14
+ };
15
+ }
16
+ return events;
17
+ });
18
+ return {
19
+ contentEvents
20
+ };
21
+ }
22
+ //# sourceMappingURL=content.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"content.mjs","names":["computed","propsFactory","pressContentPropsOptions","closeClickContent","type","Boolean","useContent","props","active","contentEvents","events","onClick","e","value"],"sources":["../../../src/components/layer/content.ts"],"sourcesContent":["import { computed, type PropType, type Ref } from 'vue';\r\n\r\nimport { propsFactory } from '../../util/vue-component';\r\n\r\nexport const pressContentPropsOptions = propsFactory(\r\n {\r\n closeClickContent: {\r\n type: Boolean as PropType<boolean>,\r\n },\r\n },\r\n 'YLayer.content',\r\n);\r\n\r\ninterface ContentProps {\r\n closeClickContent: boolean | undefined;\r\n}\r\n\r\nexport function useContent(props: ContentProps, active: Ref<boolean>) {\r\n const contentEvents = computed(() => {\r\n const events: Record<string, EventListener> = {}\r\n\r\n if (props.closeClickContent) {\r\n events.onClick = (e: Event) => {\r\n active.value = false;\r\n }\r\n }\r\n\r\n return events;\r\n })\r\n\r\n return {\r\n contentEvents\r\n }\r\n}\r\n"],"mappings":"AAAA,SAASA,QAAQ,QAAiC,KAAK;AAAC,SAE/CC,YAAY;AAErB,OAAO,MAAMC,wBAAwB,GAAGD,YAAY,CAClD;EACEE,iBAAiB,EAAE;IACjBC,IAAI,EAAEC;EACR;AACF,CAAC,EACD,gBACF,CAAC;AAMD,OAAO,SAASC,UAAUA,CAACC,KAAmB,EAAEC,MAAoB,EAAE;EACpE,MAAMC,aAAa,GAAGT,QAAQ,CAAC,MAAM;IACnC,MAAMU,MAAqC,GAAG,CAAC,CAAC;IAEhD,IAAIH,KAAK,CAACJ,iBAAiB,EAAE;MAC3BO,MAAM,CAACC,OAAO,GAAIC,CAAQ,IAAK;QAC7BJ,MAAM,CAACK,KAAK,GAAG,KAAK;MACtB,CAAC;IACH;IAEA,OAAOH,MAAM;EACf,CAAC,CAAC;EAEF,OAAO;IACLD;EACF,CAAC;AACH"}