bitboss-ui 0.2.30 → 0.2.31

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 (118) hide show
  1. package/dist/components/BbTable/BbTable.vue.d.ts +1 -1
  2. package/dist/components/BbTable/types.d.ts +1 -1
  3. package/dist/index101.js +24 -24
  4. package/dist/index101.js.map +1 -1
  5. package/dist/index103.js +2 -2
  6. package/dist/index11.js +2 -2
  7. package/dist/index111.js +3 -3
  8. package/dist/index113.js +1 -1
  9. package/dist/index116.js +1 -1
  10. package/dist/index117.js +1 -1
  11. package/dist/index118.js +1 -1
  12. package/dist/index119.js +1 -1
  13. package/dist/index121.js +1 -1
  14. package/dist/index131.js +2 -2
  15. package/dist/index15.js +8 -8
  16. package/dist/index17.js +9 -9
  17. package/dist/index19.js +3 -3
  18. package/dist/index196.js +2 -5
  19. package/dist/index196.js.map +1 -1
  20. package/dist/index197.js +5 -16
  21. package/dist/index197.js.map +1 -1
  22. package/dist/index198.js +10 -10
  23. package/dist/index198.js.map +1 -1
  24. package/dist/index199.js +15 -18
  25. package/dist/index199.js.map +1 -1
  26. package/dist/index200.js +18 -19
  27. package/dist/index200.js.map +1 -1
  28. package/dist/index201.js +15 -24
  29. package/dist/index201.js.map +1 -1
  30. package/dist/index202.js +29 -8
  31. package/dist/index202.js.map +1 -1
  32. package/dist/index203.js +8 -2
  33. package/dist/index203.js.map +1 -1
  34. package/dist/index204.js +2 -3
  35. package/dist/index204.js.map +1 -1
  36. package/dist/index205.js +376 -33
  37. package/dist/index205.js.map +1 -1
  38. package/dist/index206.js +134 -6
  39. package/dist/index206.js.map +1 -1
  40. package/dist/index207.js +2 -2
  41. package/dist/index207.js.map +1 -1
  42. package/dist/index208.js +174 -4
  43. package/dist/index208.js.map +1 -1
  44. package/dist/index209.js +23 -378
  45. package/dist/index209.js.map +1 -1
  46. package/dist/index210.js +373 -2
  47. package/dist/index210.js.map +1 -1
  48. package/dist/index211.js +2 -373
  49. package/dist/index211.js.map +1 -1
  50. package/dist/index212.js +4 -2
  51. package/dist/index212.js.map +1 -1
  52. package/dist/index213.js +1 -1
  53. package/dist/index214.js +1 -1
  54. package/dist/index215.js +10 -2
  55. package/dist/index215.js.map +1 -1
  56. package/dist/index216.js +3 -2
  57. package/dist/index216.js.map +1 -1
  58. package/dist/index217.js +34 -133
  59. package/dist/index217.js.map +1 -1
  60. package/dist/index218.js +6 -174
  61. package/dist/index218.js.map +1 -1
  62. package/dist/index219.js +2 -23
  63. package/dist/index219.js.map +1 -1
  64. package/dist/index220.js +2 -10
  65. package/dist/index220.js.map +1 -1
  66. package/dist/index221.js +1 -1
  67. package/dist/index223.js +4 -4
  68. package/dist/index224.js +1 -1
  69. package/dist/index226.js +1 -1
  70. package/dist/index227.js +291 -431
  71. package/dist/index227.js.map +1 -1
  72. package/dist/index228.js +5 -88
  73. package/dist/index228.js.map +1 -1
  74. package/dist/index229.js +2 -200
  75. package/dist/index229.js.map +1 -1
  76. package/dist/index23.js +1 -1
  77. package/dist/index230.js +2 -295
  78. package/dist/index230.js.map +1 -1
  79. package/dist/index231.js +2 -6
  80. package/dist/index231.js.map +1 -1
  81. package/dist/index232.js +2 -2
  82. package/dist/index235.js +2 -2
  83. package/dist/index236.js +117 -2
  84. package/dist/index236.js.map +1 -1
  85. package/dist/index237.js +106 -2
  86. package/dist/index237.js.map +1 -1
  87. package/dist/index239.js +218 -111
  88. package/dist/index239.js.map +1 -1
  89. package/dist/index240.js +246 -94
  90. package/dist/index240.js.map +1 -1
  91. package/dist/index241.js +435 -2
  92. package/dist/index241.js.map +1 -1
  93. package/dist/index242.js +83 -218
  94. package/dist/index242.js.map +1 -1
  95. package/dist/index243.js +200 -258
  96. package/dist/index243.js.map +1 -1
  97. package/dist/index244.js +2 -162
  98. package/dist/index244.js.map +1 -1
  99. package/dist/index245.js +2 -2
  100. package/dist/index245.js.map +1 -1
  101. package/dist/index247.js +162 -2
  102. package/dist/index247.js.map +1 -1
  103. package/dist/index248.js +2 -2
  104. package/dist/index25.js +2 -2
  105. package/dist/index255.js +2 -2
  106. package/dist/index29.js +3 -3
  107. package/dist/index31.js +6 -6
  108. package/dist/index33.js +2 -2
  109. package/dist/index35.js +2 -2
  110. package/dist/index47.js +1 -1
  111. package/dist/index49.js +1 -1
  112. package/dist/index65.js +3 -3
  113. package/dist/index72.js +1 -1
  114. package/dist/index75.js +1 -1
  115. package/dist/index79.js +3 -3
  116. package/dist/index81.js +1 -1
  117. package/dist/style.css +1 -1
  118. package/package.json +1 -1
package/dist/index244.js CHANGED
@@ -1,165 +1,5 @@
1
- import { defineComponent as K, ref as s, computed as y, openBlock as p, createElementBlock as m, normalizeClass as g, renderSlot as v, createElementVNode as k, Fragment as E, renderList as C, toDisplayString as B, createBlock as S, withDirectives as z, mergeProps as H, vModelDynamic as J } from "vue";
2
- import { clamp as P } from "./index212.js";
3
- import { drop as q } from "./index256.js";
4
- import { isNil as R } from "./index120.js";
5
- import { isNotNil as w } from "./index124.js";
6
- import { wait as L } from "./index122.js";
7
- import U from "./index115.js";
8
- import "./index158.js";
9
- const j = { class: "bb-base-tag__input-container" }, G = ["autocomplete", "autofocus", "disabled", "id", "placeholder", "readonly"], te = /* @__PURE__ */ K({
10
- __name: "BaseTag",
11
- props: {
12
- autocomplete: {},
13
- autofocus: {},
14
- comma: { type: Boolean },
15
- disabled: { type: Boolean },
16
- divider: { default: "Enter" },
17
- hasErrors: { type: Boolean },
18
- id: {},
19
- modelValue: {},
20
- multiple: { type: Boolean, default: !0 },
21
- name: {},
22
- placeholder: {},
23
- readonly: {}
24
- },
25
- emits: ["blur", "change", "click", "duplicate", "focus", "inactive", "input", "keydown", "keyup", "update:modelValue"],
26
- setup(N, { emit: I }) {
27
- const a = N, u = I;
28
- if (a.multiple && !Array.isArray(a.modelValue))
29
- throw new Error('Multiple is set to "true" but modelValue is not an array.');
30
- const i = s(null), $ = s(null), c = s(null), t = s(""), D = y(() => a.placeholder), o = y(
31
- () => [].concat(a.modelValue).filter(w)
32
- ), h = y(() => {
33
- let e = {};
34
- return o.value.forEach((n, r) => {
35
- e[JSON.stringify(n)] = r;
36
- }), {
37
- get: (n) => e[JSON.stringify(n)]
38
- };
39
- }), f = s(!1), l = s(null), A = (e) => {
40
- if (u("keyup", e), a.readonly || a.disabled) {
41
- e.preventDefault();
42
- return;
43
- }
44
- if (e.key === a.divider) {
45
- if (t.value[t.value.length - 1] === e.key && (t.value = t.value.slice(0, t.value.length - 1)), !t.value)
46
- return;
47
- l.value = null;
48
- const n = h.value.get(t.value);
49
- R(n) ? F(t.value) : u("duplicate", t.value), t.value = "";
50
- } else if (e.key === "ArrowLeft")
51
- l.value === null ? l.value = o.value.length - 1 : l.value === 0 ? l.value = null : l.value--;
52
- else if (e.key === "ArrowRight")
53
- l.value === null ? l.value = 1 : l.value === o.value.length - 1 ? l.value = null : l.value++;
54
- else if (e.key === "Backspace") {
55
- if (t.value)
56
- return;
57
- w(l.value) ? (b(l.value), l.value = P(
58
- l.value,
59
- 0,
60
- o.value.length - 2
61
- ), o.value.length === 1 && (l.value = null)) : l.value = o.value.length - 1;
62
- } else
63
- (e.key === "Tab" || e.key === "Escape") && (l.value = null);
64
- }, F = (e) => {
65
- a.multiple ? u("update:modelValue", a.modelValue.concat(e)) : u("update:modelValue", e);
66
- }, b = (e) => {
67
- if (typeof e == "number")
68
- a.multiple ? u("update:modelValue", q(a.modelValue, 1, e)) : u("update:modelValue", null);
69
- else {
70
- const n = h.value.get(t.value);
71
- b(n);
72
- }
73
- }, M = (e) => {
74
- u("focus", e), f.value = !0, document.addEventListener("click", _), document.addEventListener("focusin", V), c.value instanceof HTMLInputElement && c.value.select();
75
- }, O = (e) => {
76
- u("click", e), !(a.disabled || a.readonly) && c.value instanceof HTMLElement && c.value.focus();
77
- }, _ = (e) => {
78
- if (e.target instanceof Node && i.value && !i.value.contains(e.target)) {
79
- u("inactive"), document.removeEventListener("click", _), f.value = !1, a.multiple && L(500).then(() => {
80
- t.value = "";
81
- });
82
- return;
83
- }
84
- }, V = (e) => {
85
- if (e.target instanceof Node && i.value && !i.value.contains(e.target)) {
86
- u("inactive"), document.removeEventListener("focusin", V), f.value = !1, a.multiple && L(500).then(() => {
87
- t.value = "";
88
- });
89
- return;
90
- }
91
- }, T = {
92
- onBlur: (e) => u("blur", e),
93
- onChange: (e) => u("change", e),
94
- onKeydown: (e) => {
95
- e.key === "Enter" && a.divider === "Enter" && e.preventDefault(), u("keydown", e);
96
- },
97
- onInput: (e) => u("input", e)
98
- };
99
- return (e, n) => (p(), m("span", {
100
- class: g({
101
- "bb-base-tag": !0,
102
- "bb-base-tag--active": f.value,
103
- "bb-base-tag--disabled": e.disabled,
104
- "bb-base-tag--errors": e.hasErrors,
105
- "bb-base-tag--readonly": e.readonly
106
- }),
107
- onClick: O,
108
- ref_key: "outerContainer",
109
- ref: i
110
- }, [
111
- v(e.$slots, "prepend-outer"),
112
- k("span", {
113
- class: "bb-base-tag__inner-container",
114
- ref_key: "innerContainer",
115
- ref: $
116
- }, [
117
- v(e.$slots, "prepend"),
118
- k("span", j, [
119
- e.comma ? (p(!0), m(E, { key: 0 }, C(o.value, (r, d) => (p(), m("span", {
120
- class: g({
121
- "bb-base-tag__selected": !0,
122
- "bb-base-tag__selected--comma": !0,
123
- "bb-base-tag__selected--focused": d === l.value
124
- }),
125
- key: r
126
- }, B(r) + B(d < o.value.length - 1 ? "," : ""), 3))), 128)) : (p(!0), m(E, { key: 1 }, C(o.value, (r, d) => (p(), S(U, {
127
- class: g({
128
- "bb-base-tag__selected": !0,
129
- "bb-base-tag__selected--chip": !0,
130
- "bb-base-tag__selected--focused": d === l.value
131
- }),
132
- clearable: !0,
133
- key: r,
134
- text: r,
135
- "onClick:clear": (Q) => b(d)
136
- }, null, 8, ["class", "text", "onClick:clear"]))), 128)),
137
- z(k("input", H({
138
- autocomplete: e.autocomplete,
139
- autofocus: e.autofocus,
140
- class: "bb-base-tag__text-input",
141
- disabled: e.disabled,
142
- id: e.id,
143
- placeholder: D.value,
144
- readonly: e.readonly,
145
- type: "text",
146
- onKeyup: A,
147
- onFocus: M
148
- }, T, {
149
- "onUpdate:modelValue": n[0] || (n[0] = (r) => t.value = r),
150
- ref_key: "input",
151
- ref: c
152
- }), null, 16, G), [
153
- [J, t.value]
154
- ])
155
- ]),
156
- v(e.$slots, "append")
157
- ], 512),
158
- v(e.$slots, "append-outer")
159
- ], 2));
160
- }
161
- });
1
+ const t = (d, o) => +d + +o;
162
2
  export {
163
- te as default
3
+ t as add
164
4
  };
165
5
  //# sourceMappingURL=index244.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index244.js","sources":["../src/components/BaseTag/BaseTag.vue?vue&type=script&setup=true&lang.ts"],"sourcesContent":["import { defineComponent as _defineComponent } from 'vue'\nimport { renderSlot as _renderSlot, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, toDisplayString as _toDisplayString, normalizeClass as _normalizeClass, createCommentVNode as _createCommentVNode, createBlock as _createBlock, vModelDynamic as _vModelDynamic, mergeProps as _mergeProps, createElementVNode as _createElementVNode, withDirectives as _withDirectives } from \"vue\"\n\nconst _hoisted_1 = { class: \"bb-base-tag__input-container\" }\nconst _hoisted_2 = [\"autocomplete\", \"autofocus\", \"disabled\", \"id\", \"placeholder\", \"readonly\"]\n\nimport { clamp } from \"@/utilities/functions/clamp\";\nimport { computed, ref } from \"vue\";\nimport { drop } from \"@/utilities/functions/drop\";\nimport { isNil } from \"@/utilities/functions/isNil\";\nimport { isNotNil } from \"@/utilities/functions/isNotNil\";\nimport { wait } from \"@/utilities/functions/wait\";\nimport BbChip from \"../BbChip/BbChip.vue\";\nimport type { InputHTMLAttributes, HTMLAttributes } from \"vue\";\n\nexport type BaseTagProps = {\n /**\n * Guides to the browser as to the type of information expected in the field.\n */\n autocomplete?: InputHTMLAttributes[\"autocomplete\"];\n\n /**\n * Sets autofocus on page load.\n */\n autofocus?: InputHTMLAttributes[\"autofocus\"];\n\n /**\n * Sets the display model for selected values to a list\n * of comma separated string. In this mode the user\n * cannot deselect an option by pressing the close button.\n */\n comma?: boolean;\n\n /**\n * Disables the component\n */\n disabled?: boolean;\n\n /**\n * The divider key used to separate values from one another. By default it is \"Enter\"\n */\n divider?: KeyboardEvent[\"key\"];\n\n /**\n * Define if the component should be in an error state.\n * It usually attaches a CSS class for styling purposes.\n */\n hasErrors?: boolean;\n\n /**\n * The identifier of the component.\n */\n id?: HTMLAttributes[\"id\"];\n\n /**\n * Used by v-model. Can be any serializable type.\n */\n modelValue: any;\n\n /**\n * Allows the selection of multiple items.\n */\n multiple?: boolean;\n\n /**\n * Defines the name of the input.\n */\n name?: InputHTMLAttributes[\"name\"];\n\n /**\n * String displayed when there's no data.\n */\n placeholder?: InputHTMLAttributes[\"placeholder\"];\n\n /**\n * Sets the input in a readonly state.\n */\n readonly?: InputHTMLAttributes[\"readonly\"];\n};\n\nexport type BaseTagEvents = {\n (e: \"blur\", event: FocusEvent): void;\n\n (e: \"change\", event: Event): void;\n\n (e: \"click\", event: MouseEvent): void;\n\n (e: \"duplicate\", string: string): void;\n\n (e: \"focus\", event: FocusEvent): void;\n\n (e: \"inactive\"): void;\n\n (e: \"input\", event: Event): void;\n\n (e: \"keydown\", event: KeyboardEvent): void;\n\n (e: \"keyup\", event: KeyboardEvent): void;\n\n (e: \"update:modelValue\", value: any): void;\n};\n\nexport type BaseTagSlots = {\n append?: (props: {}) => any;\n\n \"append-outer\"?: (props: {}) => any;\n\n prepend?: (props: {}) => any;\n\n \"prepend-outer\"?: (props: {}) => any;\n};\n\n\nexport default /*#__PURE__*/_defineComponent({\n __name: 'BaseTag',\n props: {\n autocomplete: {},\n autofocus: {},\n comma: { type: Boolean },\n disabled: { type: Boolean },\n divider: { default: \"Enter\" },\n hasErrors: { type: Boolean },\n id: {},\n modelValue: {},\n multiple: { type: Boolean, default: true },\n name: {},\n placeholder: {},\n readonly: {}\n },\n emits: [\"blur\", \"change\", \"click\", \"duplicate\", \"focus\", \"inactive\", \"input\", \"keydown\", \"keyup\", \"update:modelValue\"],\n setup(__props: any, { emit: __emit }) {\n\nconst props = __props;\n\nconst emit = __emit;\n\n\n\nif (props.multiple && !Array.isArray(props.modelValue)) {\n throw new Error('Multiple is set to \"true\" but modelValue is not an array.');\n}\n\nconst outerContainer = ref<HTMLElement | null>(null);\nconst innerContainer = ref<HTMLElement | null>(null);\nconst input = ref<HTMLElement | null>(null);\nconst query = ref<string>(\"\");\nconst computedPlaceholder = computed(() => {\n return props.placeholder;\n});\n\nconst modelValueNormalized = computed(() =>\n [].concat(props.modelValue).filter(isNotNil)\n);\n\n/**\n * Indexes modelValue to a map so when can easily know which values are selected\n */\nconst modelValueIndexed = computed(() => {\n let map: { [key: string]: number } = {};\n modelValueNormalized.value.forEach((value: any, index: number) => {\n map[JSON.stringify(value)] = index;\n });\n return {\n get: (value: any) => map[JSON.stringify(value)],\n };\n});\n\n/**\n * Applies a class when the user is inside this whole component.\n * We cannot use focus within as it doesn't work for elements that are teleported.\n * Also we cannot use the <input/> if we phisically move focus to the options so\n * we track it manually.\n */\nconst active = ref(false);\n\nconst focusedIndex = ref<null | number>(null);\n\nconst onInputKeyup = (event: KeyboardEvent) => {\n emit(\"keyup\", event);\n if (props.readonly || props.disabled) {\n event.preventDefault();\n return;\n }\n if (event.key === props.divider) {\n if (query.value[query.value.length - 1] === event.key) {\n query.value = query.value.slice(0, query.value.length - 1);\n }\n if (!query.value) return;\n focusedIndex.value = null;\n const currentIndex = modelValueIndexed.value.get(query.value);\n if (isNil(currentIndex)) selectValue(query.value);\n else emit(\"duplicate\", query.value);\n query.value = \"\";\n } else if (event.key === \"ArrowLeft\") {\n if (focusedIndex.value === null)\n focusedIndex.value = modelValueNormalized.value.length - 1;\n else if (focusedIndex.value === 0) focusedIndex.value = null;\n else focusedIndex.value--;\n } else if (event.key === \"ArrowRight\") {\n if (focusedIndex.value === null) focusedIndex.value = 1;\n else if (focusedIndex.value === modelValueNormalized.value.length - 1)\n focusedIndex.value = null;\n else focusedIndex.value++;\n } else if (event.key === \"Backspace\") {\n if (query.value) return;\n if (isNotNil(focusedIndex.value)) {\n removeValue(focusedIndex.value);\n focusedIndex.value = clamp(\n focusedIndex.value,\n 0,\n modelValueNormalized.value.length - 2\n );\n if (modelValueNormalized.value.length === 1) focusedIndex.value = null;\n } else focusedIndex.value = modelValueNormalized.value.length - 1;\n } else if (event.key === \"Tab\" || event.key === \"Escape\") {\n focusedIndex.value = null;\n }\n};\n\nconst selectValue = (text: string) => {\n if (props.multiple) emit(\"update:modelValue\", props.modelValue.concat(text));\n else emit(\"update:modelValue\", text);\n};\n\nconst removeValue = (indexOrString: number | string) => {\n if (typeof indexOrString === \"number\") {\n if (props.multiple)\n emit(\"update:modelValue\", drop(props.modelValue, 1, indexOrString));\n else emit(\"update:modelValue\", null);\n } else {\n const currentIndex = modelValueIndexed.value.get(query.value);\n removeValue(currentIndex);\n }\n};\n\nconst onInputFocus = (event: FocusEvent) => {\n emit(\"focus\", event);\n active.value = true;\n document.addEventListener(\"click\", onClickOutside);\n document.addEventListener(\"focusin\", onFocusOutside);\n if (input.value instanceof HTMLInputElement) input.value.select();\n};\n\n/**\n * When clicking on the outside container seamlessly move focus to the input and open the panel\n */\nconst onOuterContainerClick = (event: MouseEvent) => {\n emit(\"click\", event);\n if (props.disabled || props.readonly) return;\n if (input.value instanceof HTMLElement) {\n input.value.focus();\n }\n};\n\n/**\n * On click outside of the container close the panel, remove active state.\n * In multiple selection clear query after a timeout\n */\nconst onClickOutside = (event: Event) => {\n if (event.target instanceof Node) {\n if (outerContainer.value) {\n if (!outerContainer.value.contains(event.target)) {\n emit(\"inactive\");\n document.removeEventListener(\"click\", onClickOutside);\n active.value = false;\n if (props.multiple)\n wait(500).then(() => {\n query.value = \"\";\n });\n return;\n }\n }\n }\n};\n\nconst onFocusOutside = (event: FocusEvent) => {\n if (event.target instanceof Node) {\n if (outerContainer.value) {\n if (!outerContainer.value.contains(event.target)) {\n emit(\"inactive\");\n document.removeEventListener(\"focusin\", onFocusOutside);\n active.value = false;\n if (props.multiple)\n wait(500).then(() => {\n query.value = \"\";\n });\n return;\n }\n }\n }\n};\n\nconst eventListeners = {\n onBlur: (event: FocusEvent) => emit(\"blur\", event),\n onChange: (event: Event) => emit(\"change\", event),\n onKeydown: (event: KeyboardEvent) => {\n if (event.key === \"Enter\" && props.divider === \"Enter\") {\n event.preventDefault();\n }\n emit(\"keydown\", event);\n },\n onInput: (event: Event) => emit(\"input\", event),\n};\n\nreturn (_ctx: any,_cache: any) => {\n return (_openBlock(), _createElementBlock(\"span\", {\n class: _normalizeClass({\n 'bb-base-tag': true,\n 'bb-base-tag--active': active.value,\n 'bb-base-tag--disabled': _ctx.disabled,\n 'bb-base-tag--errors': _ctx.hasErrors,\n 'bb-base-tag--readonly': _ctx.readonly,\n }),\n onClick: onOuterContainerClick,\n ref_key: \"outerContainer\",\n ref: outerContainer\n }, [\n _renderSlot(_ctx.$slots, \"prepend-outer\"),\n _createElementVNode(\"span\", {\n class: \"bb-base-tag__inner-container\",\n ref_key: \"innerContainer\",\n ref: innerContainer\n }, [\n _renderSlot(_ctx.$slots, \"prepend\"),\n _createElementVNode(\"span\", _hoisted_1, [\n (_ctx.comma)\n ? (_openBlock(true), _createElementBlock(_Fragment, { key: 0 }, _renderList(modelValueNormalized.value, (option, index) => {\n return (_openBlock(), _createElementBlock(\"span\", {\n class: _normalizeClass({\n 'bb-base-tag__selected': true,\n 'bb-base-tag__selected--comma': true,\n 'bb-base-tag__selected--focused': index === focusedIndex.value,\n }),\n key: option\n }, _toDisplayString(option) + _toDisplayString(index < modelValueNormalized.value.length - 1 ? \",\" : \"\"), 3))\n }), 128))\n : (_openBlock(true), _createElementBlock(_Fragment, { key: 1 }, _renderList(modelValueNormalized.value, (option, index) => {\n return (_openBlock(), _createBlock(BbChip, {\n class: _normalizeClass({\n 'bb-base-tag__selected': true,\n 'bb-base-tag__selected--chip': true,\n 'bb-base-tag__selected--focused': index === focusedIndex.value,\n }),\n clearable: true,\n key: option,\n text: option,\n \"onClick:clear\": ($event: any) => (removeValue(index))\n }, null, 8, [\"class\", \"text\", \"onClick:clear\"]))\n }), 128)),\n _withDirectives(_createElementVNode(\"input\", _mergeProps({\n autocomplete: _ctx.autocomplete,\n autofocus: _ctx.autofocus,\n class: 'bb-base-tag__text-input',\n disabled: _ctx.disabled,\n id: _ctx.id,\n placeholder: computedPlaceholder.value,\n readonly: _ctx.readonly,\n type: 'text',\n onKeyup: onInputKeyup,\n onFocus: onInputFocus\n }, eventListeners, {\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = ($event: any) => ((query).value = $event)),\n ref_key: \"input\",\n ref: input\n }), null, 16, _hoisted_2), [\n [_vModelDynamic, query.value]\n ])\n ]),\n _renderSlot(_ctx.$slots, \"append\")\n ], 512),\n _renderSlot(_ctx.$slots, \"append-outer\")\n ], 2))\n}\n}\n\n})"],"names":["_hoisted_1","_hoisted_2","_sfc_main","_defineComponent","__props","__emit","props","emit","outerContainer","ref","innerContainer","input","query","computedPlaceholder","computed","modelValueNormalized","isNotNil","modelValueIndexed","map","value","index","active","focusedIndex","onInputKeyup","event","currentIndex","isNil","selectValue","removeValue","clamp","text","indexOrString","drop","onInputFocus","onClickOutside","onFocusOutside","onOuterContainerClick","wait","eventListeners","_ctx","_cache","_openBlock","_createElementBlock","_normalizeClass","_renderSlot","_createElementVNode","_Fragment","_renderList","option","_toDisplayString","_createBlock","BbChip","$event","_withDirectives","_mergeProps","_vModelDynamic"],"mappings":"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"}
1
+ {"version":3,"file":"index244.js","sources":["../src/utilities/functions/add.ts"],"sourcesContent":["export const add = (a:number | string, b: number | string) => +a + +b;"],"names":["add","a","b"],"mappings":"AAAO,MAAMA,IAAM,CAACC,GAAmBC,MAAuB,CAACD,IAAI,CAACC;"}
package/dist/index245.js CHANGED
@@ -1,5 +1,5 @@
1
- const e = "";
1
+ const o = (l, n, f = (r) => r, u) => l.map((r) => Array.isArray(r[n]) ? [f(r, u), ...o(r[n], n, f, f(r, u))] : [f(r, u)]).flat();
2
2
  export {
3
- e as default
3
+ o as flattenTree
4
4
  };
5
5
  //# sourceMappingURL=index245.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index245.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
1
+ {"version":3,"file":"index245.js","sources":["../src/utilities/functions/flattenTree.ts"],"sourcesContent":["export const flattenTree = <T extends Record<string, any>, U>(\n items: T[],\n keyName: keyof T,\n mapper: (item: T, parent?: U) => U = (x:any) => x,\n parent?: ReturnType<typeof mapper>\n): ReturnType<typeof mapper>[] => {\n return items\n .map((item) => {\n if (Array.isArray(item[keyName])) {\n return [mapper(item, parent), ...flattenTree(item[keyName], keyName, mapper, mapper(item, parent))];\n }\n return [mapper(item, parent)];\n })\n .flat();\n};\n"],"names":["flattenTree","items","keyName","mapper","x","parent","item"],"mappings":"AAAa,MAAAA,IAAc,CACzBC,GACAC,GACAC,IAAqC,CAACC,MAAUA,GAChDC,MAEOJ,EACJ,IAAI,CAACK,MACA,MAAM,QAAQA,EAAKJ,CAAO,CAAC,IACtB,CAACC,EAAOG,GAAMD,CAAM,GAAG,GAAGL,EAAYM,EAAKJ,CAAO,GAAGA,GAASC,GAAQA,EAAOG,GAAMD,CAAM,CAAC,CAAC,IAE7F,CAACF,EAAOG,GAAMD,CAAM,CAAC,CAC7B,EACA,KAAK;"}
package/dist/index247.js CHANGED
@@ -1,5 +1,165 @@
1
- const o = (l, n, f = (r) => r, u) => l.map((r) => Array.isArray(r[n]) ? [f(r, u), ...o(r[n], n, f, f(r, u))] : [f(r, u)]).flat();
1
+ import { defineComponent as K, ref as s, computed as y, openBlock as p, createElementBlock as m, normalizeClass as g, renderSlot as v, createElementVNode as k, Fragment as E, renderList as C, toDisplayString as B, createBlock as S, withDirectives as z, mergeProps as H, vModelDynamic as J } from "vue";
2
+ import { clamp as P } from "./index196.js";
3
+ import { drop as q } from "./index256.js";
4
+ import { isNil as R } from "./index120.js";
5
+ import { isNotNil as w } from "./index124.js";
6
+ import { wait as L } from "./index122.js";
7
+ import U from "./index115.js";
8
+ import "./index158.js";
9
+ const j = { class: "bb-base-tag__input-container" }, G = ["autocomplete", "autofocus", "disabled", "id", "placeholder", "readonly"], te = /* @__PURE__ */ K({
10
+ __name: "BaseTag",
11
+ props: {
12
+ autocomplete: {},
13
+ autofocus: {},
14
+ comma: { type: Boolean },
15
+ disabled: { type: Boolean },
16
+ divider: { default: "Enter" },
17
+ hasErrors: { type: Boolean },
18
+ id: {},
19
+ modelValue: {},
20
+ multiple: { type: Boolean, default: !0 },
21
+ name: {},
22
+ placeholder: {},
23
+ readonly: {}
24
+ },
25
+ emits: ["blur", "change", "click", "duplicate", "focus", "inactive", "input", "keydown", "keyup", "update:modelValue"],
26
+ setup(N, { emit: I }) {
27
+ const a = N, u = I;
28
+ if (a.multiple && !Array.isArray(a.modelValue))
29
+ throw new Error('Multiple is set to "true" but modelValue is not an array.');
30
+ const i = s(null), $ = s(null), c = s(null), t = s(""), D = y(() => a.placeholder), o = y(
31
+ () => [].concat(a.modelValue).filter(w)
32
+ ), h = y(() => {
33
+ let e = {};
34
+ return o.value.forEach((n, r) => {
35
+ e[JSON.stringify(n)] = r;
36
+ }), {
37
+ get: (n) => e[JSON.stringify(n)]
38
+ };
39
+ }), f = s(!1), l = s(null), A = (e) => {
40
+ if (u("keyup", e), a.readonly || a.disabled) {
41
+ e.preventDefault();
42
+ return;
43
+ }
44
+ if (e.key === a.divider) {
45
+ if (t.value[t.value.length - 1] === e.key && (t.value = t.value.slice(0, t.value.length - 1)), !t.value)
46
+ return;
47
+ l.value = null;
48
+ const n = h.value.get(t.value);
49
+ R(n) ? F(t.value) : u("duplicate", t.value), t.value = "";
50
+ } else if (e.key === "ArrowLeft")
51
+ l.value === null ? l.value = o.value.length - 1 : l.value === 0 ? l.value = null : l.value--;
52
+ else if (e.key === "ArrowRight")
53
+ l.value === null ? l.value = 1 : l.value === o.value.length - 1 ? l.value = null : l.value++;
54
+ else if (e.key === "Backspace") {
55
+ if (t.value)
56
+ return;
57
+ w(l.value) ? (b(l.value), l.value = P(
58
+ l.value,
59
+ 0,
60
+ o.value.length - 2
61
+ ), o.value.length === 1 && (l.value = null)) : l.value = o.value.length - 1;
62
+ } else
63
+ (e.key === "Tab" || e.key === "Escape") && (l.value = null);
64
+ }, F = (e) => {
65
+ a.multiple ? u("update:modelValue", a.modelValue.concat(e)) : u("update:modelValue", e);
66
+ }, b = (e) => {
67
+ if (typeof e == "number")
68
+ a.multiple ? u("update:modelValue", q(a.modelValue, 1, e)) : u("update:modelValue", null);
69
+ else {
70
+ const n = h.value.get(t.value);
71
+ b(n);
72
+ }
73
+ }, M = (e) => {
74
+ u("focus", e), f.value = !0, document.addEventListener("click", _), document.addEventListener("focusin", V), c.value instanceof HTMLInputElement && c.value.select();
75
+ }, O = (e) => {
76
+ u("click", e), !(a.disabled || a.readonly) && c.value instanceof HTMLElement && c.value.focus();
77
+ }, _ = (e) => {
78
+ if (e.target instanceof Node && i.value && !i.value.contains(e.target)) {
79
+ u("inactive"), document.removeEventListener("click", _), f.value = !1, a.multiple && L(500).then(() => {
80
+ t.value = "";
81
+ });
82
+ return;
83
+ }
84
+ }, V = (e) => {
85
+ if (e.target instanceof Node && i.value && !i.value.contains(e.target)) {
86
+ u("inactive"), document.removeEventListener("focusin", V), f.value = !1, a.multiple && L(500).then(() => {
87
+ t.value = "";
88
+ });
89
+ return;
90
+ }
91
+ }, T = {
92
+ onBlur: (e) => u("blur", e),
93
+ onChange: (e) => u("change", e),
94
+ onKeydown: (e) => {
95
+ e.key === "Enter" && a.divider === "Enter" && e.preventDefault(), u("keydown", e);
96
+ },
97
+ onInput: (e) => u("input", e)
98
+ };
99
+ return (e, n) => (p(), m("span", {
100
+ class: g({
101
+ "bb-base-tag": !0,
102
+ "bb-base-tag--active": f.value,
103
+ "bb-base-tag--disabled": e.disabled,
104
+ "bb-base-tag--errors": e.hasErrors,
105
+ "bb-base-tag--readonly": e.readonly
106
+ }),
107
+ onClick: O,
108
+ ref_key: "outerContainer",
109
+ ref: i
110
+ }, [
111
+ v(e.$slots, "prepend-outer"),
112
+ k("span", {
113
+ class: "bb-base-tag__inner-container",
114
+ ref_key: "innerContainer",
115
+ ref: $
116
+ }, [
117
+ v(e.$slots, "prepend"),
118
+ k("span", j, [
119
+ e.comma ? (p(!0), m(E, { key: 0 }, C(o.value, (r, d) => (p(), m("span", {
120
+ class: g({
121
+ "bb-base-tag__selected": !0,
122
+ "bb-base-tag__selected--comma": !0,
123
+ "bb-base-tag__selected--focused": d === l.value
124
+ }),
125
+ key: r
126
+ }, B(r) + B(d < o.value.length - 1 ? "," : ""), 3))), 128)) : (p(!0), m(E, { key: 1 }, C(o.value, (r, d) => (p(), S(U, {
127
+ class: g({
128
+ "bb-base-tag__selected": !0,
129
+ "bb-base-tag__selected--chip": !0,
130
+ "bb-base-tag__selected--focused": d === l.value
131
+ }),
132
+ clearable: !0,
133
+ key: r,
134
+ text: r,
135
+ "onClick:clear": (Q) => b(d)
136
+ }, null, 8, ["class", "text", "onClick:clear"]))), 128)),
137
+ z(k("input", H({
138
+ autocomplete: e.autocomplete,
139
+ autofocus: e.autofocus,
140
+ class: "bb-base-tag__text-input",
141
+ disabled: e.disabled,
142
+ id: e.id,
143
+ placeholder: D.value,
144
+ readonly: e.readonly,
145
+ type: "text",
146
+ onKeyup: A,
147
+ onFocus: M
148
+ }, T, {
149
+ "onUpdate:modelValue": n[0] || (n[0] = (r) => t.value = r),
150
+ ref_key: "input",
151
+ ref: c
152
+ }), null, 16, G), [
153
+ [J, t.value]
154
+ ])
155
+ ]),
156
+ v(e.$slots, "append")
157
+ ], 512),
158
+ v(e.$slots, "append-outer")
159
+ ], 2));
160
+ }
161
+ });
2
162
  export {
3
- o as flattenTree
163
+ te as default
4
164
  };
5
165
  //# sourceMappingURL=index247.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index247.js","sources":["../src/utilities/functions/flattenTree.ts"],"sourcesContent":["export const flattenTree = <T extends Record<string, any>, U>(\n items: T[],\n keyName: keyof T,\n mapper: (item: T, parent?: U) => U = (x:any) => x,\n parent?: ReturnType<typeof mapper>\n): ReturnType<typeof mapper>[] => {\n return items\n .map((item) => {\n if (Array.isArray(item[keyName])) {\n return [mapper(item, parent), ...flattenTree(item[keyName], keyName, mapper, mapper(item, parent))];\n }\n return [mapper(item, parent)];\n })\n .flat();\n};\n"],"names":["flattenTree","items","keyName","mapper","x","parent","item"],"mappings":"AAAa,MAAAA,IAAc,CACzBC,GACAC,GACAC,IAAqC,CAACC,MAAUA,GAChDC,MAEOJ,EACJ,IAAI,CAACK,MACA,MAAM,QAAQA,EAAKJ,CAAO,CAAC,IACtB,CAACC,EAAOG,GAAMD,CAAM,GAAG,GAAGL,EAAYM,EAAKJ,CAAO,GAAGA,GAASC,GAAQA,EAAOG,GAAMD,CAAM,CAAC,CAAC,IAE7F,CAACF,EAAOG,GAAMD,CAAM,CAAC,CAC7B,EACA,KAAK;"}
1
+ {"version":3,"file":"index247.js","sources":["../src/components/BaseTag/BaseTag.vue?vue&type=script&setup=true&lang.ts"],"sourcesContent":["import { defineComponent as _defineComponent } from 'vue'\nimport { renderSlot as _renderSlot, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, toDisplayString as _toDisplayString, normalizeClass as _normalizeClass, createCommentVNode as _createCommentVNode, createBlock as _createBlock, vModelDynamic as _vModelDynamic, mergeProps as _mergeProps, createElementVNode as _createElementVNode, withDirectives as _withDirectives } from \"vue\"\n\nconst _hoisted_1 = { class: \"bb-base-tag__input-container\" }\nconst _hoisted_2 = [\"autocomplete\", \"autofocus\", \"disabled\", \"id\", \"placeholder\", \"readonly\"]\n\nimport { clamp } from \"@/utilities/functions/clamp\";\nimport { computed, ref } from \"vue\";\nimport { drop } from \"@/utilities/functions/drop\";\nimport { isNil } from \"@/utilities/functions/isNil\";\nimport { isNotNil } from \"@/utilities/functions/isNotNil\";\nimport { wait } from \"@/utilities/functions/wait\";\nimport BbChip from \"../BbChip/BbChip.vue\";\nimport type { InputHTMLAttributes, HTMLAttributes } from \"vue\";\n\nexport type BaseTagProps = {\n /**\n * Guides to the browser as to the type of information expected in the field.\n */\n autocomplete?: InputHTMLAttributes[\"autocomplete\"];\n\n /**\n * Sets autofocus on page load.\n */\n autofocus?: InputHTMLAttributes[\"autofocus\"];\n\n /**\n * Sets the display model for selected values to a list\n * of comma separated string. In this mode the user\n * cannot deselect an option by pressing the close button.\n */\n comma?: boolean;\n\n /**\n * Disables the component\n */\n disabled?: boolean;\n\n /**\n * The divider key used to separate values from one another. By default it is \"Enter\"\n */\n divider?: KeyboardEvent[\"key\"];\n\n /**\n * Define if the component should be in an error state.\n * It usually attaches a CSS class for styling purposes.\n */\n hasErrors?: boolean;\n\n /**\n * The identifier of the component.\n */\n id?: HTMLAttributes[\"id\"];\n\n /**\n * Used by v-model. Can be any serializable type.\n */\n modelValue: any;\n\n /**\n * Allows the selection of multiple items.\n */\n multiple?: boolean;\n\n /**\n * Defines the name of the input.\n */\n name?: InputHTMLAttributes[\"name\"];\n\n /**\n * String displayed when there's no data.\n */\n placeholder?: InputHTMLAttributes[\"placeholder\"];\n\n /**\n * Sets the input in a readonly state.\n */\n readonly?: InputHTMLAttributes[\"readonly\"];\n};\n\nexport type BaseTagEvents = {\n (e: \"blur\", event: FocusEvent): void;\n\n (e: \"change\", event: Event): void;\n\n (e: \"click\", event: MouseEvent): void;\n\n (e: \"duplicate\", string: string): void;\n\n (e: \"focus\", event: FocusEvent): void;\n\n (e: \"inactive\"): void;\n\n (e: \"input\", event: Event): void;\n\n (e: \"keydown\", event: KeyboardEvent): void;\n\n (e: \"keyup\", event: KeyboardEvent): void;\n\n (e: \"update:modelValue\", value: any): void;\n};\n\nexport type BaseTagSlots = {\n append?: (props: {}) => any;\n\n \"append-outer\"?: (props: {}) => any;\n\n prepend?: (props: {}) => any;\n\n \"prepend-outer\"?: (props: {}) => any;\n};\n\n\nexport default /*#__PURE__*/_defineComponent({\n __name: 'BaseTag',\n props: {\n autocomplete: {},\n autofocus: {},\n comma: { type: Boolean },\n disabled: { type: Boolean },\n divider: { default: \"Enter\" },\n hasErrors: { type: Boolean },\n id: {},\n modelValue: {},\n multiple: { type: Boolean, default: true },\n name: {},\n placeholder: {},\n readonly: {}\n },\n emits: [\"blur\", \"change\", \"click\", \"duplicate\", \"focus\", \"inactive\", \"input\", \"keydown\", \"keyup\", \"update:modelValue\"],\n setup(__props: any, { emit: __emit }) {\n\nconst props = __props;\n\nconst emit = __emit;\n\n\n\nif (props.multiple && !Array.isArray(props.modelValue)) {\n throw new Error('Multiple is set to \"true\" but modelValue is not an array.');\n}\n\nconst outerContainer = ref<HTMLElement | null>(null);\nconst innerContainer = ref<HTMLElement | null>(null);\nconst input = ref<HTMLElement | null>(null);\nconst query = ref<string>(\"\");\nconst computedPlaceholder = computed(() => {\n return props.placeholder;\n});\n\nconst modelValueNormalized = computed(() =>\n [].concat(props.modelValue).filter(isNotNil)\n);\n\n/**\n * Indexes modelValue to a map so when can easily know which values are selected\n */\nconst modelValueIndexed = computed(() => {\n let map: { [key: string]: number } = {};\n modelValueNormalized.value.forEach((value: any, index: number) => {\n map[JSON.stringify(value)] = index;\n });\n return {\n get: (value: any) => map[JSON.stringify(value)],\n };\n});\n\n/**\n * Applies a class when the user is inside this whole component.\n * We cannot use focus within as it doesn't work for elements that are teleported.\n * Also we cannot use the <input/> if we phisically move focus to the options so\n * we track it manually.\n */\nconst active = ref(false);\n\nconst focusedIndex = ref<null | number>(null);\n\nconst onInputKeyup = (event: KeyboardEvent) => {\n emit(\"keyup\", event);\n if (props.readonly || props.disabled) {\n event.preventDefault();\n return;\n }\n if (event.key === props.divider) {\n if (query.value[query.value.length - 1] === event.key) {\n query.value = query.value.slice(0, query.value.length - 1);\n }\n if (!query.value) return;\n focusedIndex.value = null;\n const currentIndex = modelValueIndexed.value.get(query.value);\n if (isNil(currentIndex)) selectValue(query.value);\n else emit(\"duplicate\", query.value);\n query.value = \"\";\n } else if (event.key === \"ArrowLeft\") {\n if (focusedIndex.value === null)\n focusedIndex.value = modelValueNormalized.value.length - 1;\n else if (focusedIndex.value === 0) focusedIndex.value = null;\n else focusedIndex.value--;\n } else if (event.key === \"ArrowRight\") {\n if (focusedIndex.value === null) focusedIndex.value = 1;\n else if (focusedIndex.value === modelValueNormalized.value.length - 1)\n focusedIndex.value = null;\n else focusedIndex.value++;\n } else if (event.key === \"Backspace\") {\n if (query.value) return;\n if (isNotNil(focusedIndex.value)) {\n removeValue(focusedIndex.value);\n focusedIndex.value = clamp(\n focusedIndex.value,\n 0,\n modelValueNormalized.value.length - 2\n );\n if (modelValueNormalized.value.length === 1) focusedIndex.value = null;\n } else focusedIndex.value = modelValueNormalized.value.length - 1;\n } else if (event.key === \"Tab\" || event.key === \"Escape\") {\n focusedIndex.value = null;\n }\n};\n\nconst selectValue = (text: string) => {\n if (props.multiple) emit(\"update:modelValue\", props.modelValue.concat(text));\n else emit(\"update:modelValue\", text);\n};\n\nconst removeValue = (indexOrString: number | string) => {\n if (typeof indexOrString === \"number\") {\n if (props.multiple)\n emit(\"update:modelValue\", drop(props.modelValue, 1, indexOrString));\n else emit(\"update:modelValue\", null);\n } else {\n const currentIndex = modelValueIndexed.value.get(query.value);\n removeValue(currentIndex);\n }\n};\n\nconst onInputFocus = (event: FocusEvent) => {\n emit(\"focus\", event);\n active.value = true;\n document.addEventListener(\"click\", onClickOutside);\n document.addEventListener(\"focusin\", onFocusOutside);\n if (input.value instanceof HTMLInputElement) input.value.select();\n};\n\n/**\n * When clicking on the outside container seamlessly move focus to the input and open the panel\n */\nconst onOuterContainerClick = (event: MouseEvent) => {\n emit(\"click\", event);\n if (props.disabled || props.readonly) return;\n if (input.value instanceof HTMLElement) {\n input.value.focus();\n }\n};\n\n/**\n * On click outside of the container close the panel, remove active state.\n * In multiple selection clear query after a timeout\n */\nconst onClickOutside = (event: Event) => {\n if (event.target instanceof Node) {\n if (outerContainer.value) {\n if (!outerContainer.value.contains(event.target)) {\n emit(\"inactive\");\n document.removeEventListener(\"click\", onClickOutside);\n active.value = false;\n if (props.multiple)\n wait(500).then(() => {\n query.value = \"\";\n });\n return;\n }\n }\n }\n};\n\nconst onFocusOutside = (event: FocusEvent) => {\n if (event.target instanceof Node) {\n if (outerContainer.value) {\n if (!outerContainer.value.contains(event.target)) {\n emit(\"inactive\");\n document.removeEventListener(\"focusin\", onFocusOutside);\n active.value = false;\n if (props.multiple)\n wait(500).then(() => {\n query.value = \"\";\n });\n return;\n }\n }\n }\n};\n\nconst eventListeners = {\n onBlur: (event: FocusEvent) => emit(\"blur\", event),\n onChange: (event: Event) => emit(\"change\", event),\n onKeydown: (event: KeyboardEvent) => {\n if (event.key === \"Enter\" && props.divider === \"Enter\") {\n event.preventDefault();\n }\n emit(\"keydown\", event);\n },\n onInput: (event: Event) => emit(\"input\", event),\n};\n\nreturn (_ctx: any,_cache: any) => {\n return (_openBlock(), _createElementBlock(\"span\", {\n class: _normalizeClass({\n 'bb-base-tag': true,\n 'bb-base-tag--active': active.value,\n 'bb-base-tag--disabled': _ctx.disabled,\n 'bb-base-tag--errors': _ctx.hasErrors,\n 'bb-base-tag--readonly': _ctx.readonly,\n }),\n onClick: onOuterContainerClick,\n ref_key: \"outerContainer\",\n ref: outerContainer\n }, [\n _renderSlot(_ctx.$slots, \"prepend-outer\"),\n _createElementVNode(\"span\", {\n class: \"bb-base-tag__inner-container\",\n ref_key: \"innerContainer\",\n ref: innerContainer\n }, [\n _renderSlot(_ctx.$slots, \"prepend\"),\n _createElementVNode(\"span\", _hoisted_1, [\n (_ctx.comma)\n ? (_openBlock(true), _createElementBlock(_Fragment, { key: 0 }, _renderList(modelValueNormalized.value, (option, index) => {\n return (_openBlock(), _createElementBlock(\"span\", {\n class: _normalizeClass({\n 'bb-base-tag__selected': true,\n 'bb-base-tag__selected--comma': true,\n 'bb-base-tag__selected--focused': index === focusedIndex.value,\n }),\n key: option\n }, _toDisplayString(option) + _toDisplayString(index < modelValueNormalized.value.length - 1 ? \",\" : \"\"), 3))\n }), 128))\n : (_openBlock(true), _createElementBlock(_Fragment, { key: 1 }, _renderList(modelValueNormalized.value, (option, index) => {\n return (_openBlock(), _createBlock(BbChip, {\n class: _normalizeClass({\n 'bb-base-tag__selected': true,\n 'bb-base-tag__selected--chip': true,\n 'bb-base-tag__selected--focused': index === focusedIndex.value,\n }),\n clearable: true,\n key: option,\n text: option,\n \"onClick:clear\": ($event: any) => (removeValue(index))\n }, null, 8, [\"class\", \"text\", \"onClick:clear\"]))\n }), 128)),\n _withDirectives(_createElementVNode(\"input\", _mergeProps({\n autocomplete: _ctx.autocomplete,\n autofocus: _ctx.autofocus,\n class: 'bb-base-tag__text-input',\n disabled: _ctx.disabled,\n id: _ctx.id,\n placeholder: computedPlaceholder.value,\n readonly: _ctx.readonly,\n type: 'text',\n onKeyup: onInputKeyup,\n onFocus: onInputFocus\n }, eventListeners, {\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = ($event: any) => ((query).value = $event)),\n ref_key: \"input\",\n ref: input\n }), null, 16, _hoisted_2), [\n [_vModelDynamic, query.value]\n ])\n ]),\n _renderSlot(_ctx.$slots, \"append\")\n ], 512),\n _renderSlot(_ctx.$slots, \"append-outer\")\n ], 2))\n}\n}\n\n})"],"names":["_hoisted_1","_hoisted_2","_sfc_main","_defineComponent","__props","__emit","props","emit","outerContainer","ref","innerContainer","input","query","computedPlaceholder","computed","modelValueNormalized","isNotNil","modelValueIndexed","map","value","index","active","focusedIndex","onInputKeyup","event","currentIndex","isNil","selectValue","removeValue","clamp","text","indexOrString","drop","onInputFocus","onClickOutside","onFocusOutside","onOuterContainerClick","wait","eventListeners","_ctx","_cache","_openBlock","_createElementBlock","_normalizeClass","_renderSlot","_createElementVNode","_Fragment","_renderList","option","_toDisplayString","_createBlock","BbChip","$event","_withDirectives","_mergeProps","_vModelDynamic"],"mappings":"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"}
package/dist/index248.js CHANGED
@@ -1,5 +1,5 @@
1
- var o = { exports: {} };
1
+ const e = "";
2
2
  export {
3
- o as __module
3
+ e as default
4
4
  };
5
5
  //# sourceMappingURL=index248.js.map
package/dist/index25.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { defineComponent as g, computed as n, ref as _, openBlock as w, createElementBlock as B, normalizeClass as C, createElementVNode as l, normalizeProps as t, guardReactiveProps as u, renderSlot as V } from "vue";
2
- import { isCssColor as i } from "./index207.js";
3
- import { when as E } from "./index208.js";
2
+ import { isCssColor as i } from "./index211.js";
3
+ import { when as E } from "./index212.js";
4
4
  const N = {
5
5
  class: "bb-base-radio-container",
6
6
  "aria-hidden": "true"
package/dist/index255.js CHANGED
@@ -1,5 +1,5 @@
1
- import o from "./index244.js";
2
- import "./index245.js";
1
+ import o from "./index247.js";
2
+ import "./index248.js";
3
3
  export {
4
4
  o as default
5
5
  };
package/dist/index29.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { defineComponent as C, ref as b, computed as f, openBlock as l, createElementBlock as i, mergeProps as g, createElementVNode as r, Fragment as I, renderList as V, normalizeClass as B, toDisplayString as h, renderSlot as x } from "vue";
2
- import { booleanishToBoolean as M } from "./index215.js";
3
- import { identity as F } from "./index216.js";
4
- import { isCssColor as p } from "./index207.js";
2
+ import { booleanishToBoolean as M } from "./index219.js";
3
+ import { identity as F } from "./index207.js";
4
+ import { isCssColor as p } from "./index211.js";
5
5
  import { isNotNil as T } from "./index124.js";
6
6
  const H = { class: "bb-base-rating__inner-container" }, D = { class: "bb-base-rating__label-text" }, N = ["autofocus", "checked", "disabled", "id", "name", "value"], j = ["width", "height"], A = /* @__PURE__ */ r("path", {
7
7
  "stroke-linecap": "round",
package/dist/index31.js CHANGED
@@ -3,17 +3,17 @@ import Pe from "./index115.js";
3
3
  import "./index158.js";
4
4
  import He from "./index119.js";
5
5
  import "./index185.js";
6
- import { autoUpdate as je, computePosition as Qe, flip as Ue, shift as We } from "./index209.js";
6
+ import { autoUpdate as je, computePosition as Qe, flip as Ue, shift as We } from "./index205.js";
7
7
  import { deepEqual as re } from "./index123.js";
8
- import { head as le } from "./index210.js";
8
+ import { head as le } from "./index220.js";
9
9
  import { isNotNil as I } from "./index124.js";
10
- import { last as Re } from "./index203.js";
10
+ import { last as Re } from "./index204.js";
11
11
  import { useItemText as Ke } from "./index125.js";
12
12
  import { useItemValue as Ye } from "./index126.js";
13
13
  import { wait as q } from "./index122.js";
14
- import { waitFor as Ze } from "./index206.js";
15
- import { when as Ge } from "./index208.js";
16
- import { offset as Xe } from "./index211.js";
14
+ import { waitFor as Ze } from "./index218.js";
15
+ import { when as Ge } from "./index212.js";
16
+ import { offset as Xe } from "./index210.js";
17
17
  const el = { class: "bb-base-select__input-container" }, ll = ["autocomplete", "autofocus", "disabled", "id", "placeholder", "readonly"], tl = {
18
18
  key: 0,
19
19
  class: "bb-base-select__loading-container"
package/dist/index33.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { defineComponent as R, ref as l, onMounted as S, watchEffect as z, computed as y, openBlock as D, createElementBlock as F, mergeProps as h, renderSlot as g, createElementVNode as t, normalizeProps as H, guardReactiveProps as T, normalizeStyle as E, unref as X } from "vue";
2
- import { clamp as K } from "./index212.js";
3
- import { isCssColor as w } from "./index207.js";
2
+ import { clamp as K } from "./index196.js";
3
+ import { isCssColor as w } from "./index211.js";
4
4
  import { isNil as O } from "./index120.js";
5
5
  import { transposeValue as L } from "./index121.js";
6
6
  const Y = { class: "bb-base-slider__slider-container" }, j = ["disabled", "id", "name", "readonly", "value"], q = ["aria-readonly", "aria-valuemax", "aria-valuemin", "aria-valuenow", "tabindex"], W = /* @__PURE__ */ R({
package/dist/index35.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { defineComponent as I, ref as b, computed as n, watch as F, openBlock as m, createElementBlock as p, normalizeClass as N, normalizeProps as c, mergeProps as h, createCommentVNode as S, createElementVNode as l, renderSlot as x, guardReactiveProps as f } from "vue";
2
- import { isCssColor as V } from "./index207.js";
3
- import { when as A } from "./index208.js";
2
+ import { isCssColor as V } from "./index211.js";
3
+ import { when as A } from "./index212.js";
4
4
  const J = { class: "bb-base-switch-container" }, M = /* @__PURE__ */ l("span", { class: "bb-base-switch-container__icon-thumb" }, null, -1), O = [
5
5
  M
6
6
  ], H = /* @__PURE__ */ I({
package/dist/index47.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { defineComponent as p, computed as u, ref as d, watch as f, openBlock as a, createElementBlock as l, normalizeProps as b, guardReactiveProps as z, createElementVNode as v, renderSlot as g, createCommentVNode as h } from "vue";
2
- import { isCssColor as _ } from "./index207.js";
2
+ import { isCssColor as _ } from "./index211.js";
3
3
  const k = { class: "bb-avatar__fallback" }, C = ["alt", "src", "srcset", "sizes"], B = /* @__PURE__ */ p({
4
4
  __name: "BbAvatar",
5
5
  props: {
package/dist/index49.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { defineComponent as p, useSlots as d, computed as n, openBlock as m, createElementBlock as u, normalizeClass as g, createElementVNode as s, renderSlot as l, mergeProps as f, createTextVNode as _, toDisplayString as y } from "vue";
2
- import { isCssColor as r } from "./index207.js";
2
+ import { isCssColor as r } from "./index211.js";
3
3
  import { isNil as B } from "./index120.js";
4
4
  const C = { class: "bb-badge__wrapper" }, h = { class: "bb-badge__content-inner" }, S = /* @__PURE__ */ p({
5
5
  __name: "BbBadge",
package/dist/index65.js CHANGED
@@ -5,9 +5,9 @@ import { useId as de } from "./index7.js";
5
5
  import { wait as U } from "./index122.js";
6
6
  import ce from "./index9.js";
7
7
  import "./index10.js";
8
- import V from "./index219.js";
9
- import { autoUpdate as fe, flip as pe, shift as be } from "./index209.js";
10
- import { offset as me } from "./index211.js";
8
+ import V from "./index209.js";
9
+ import { autoUpdate as fe, flip as pe, shift as be } from "./index205.js";
10
+ import { offset as me } from "./index210.js";
11
11
  const ve = ["aria-labelledby", "id"], we = { class: "bb-dropdown__items-container" }, Me = /* @__PURE__ */ Y({
12
12
  __name: "BbDropdown",
13
13
  props: {
package/dist/index72.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { defineComponent as h, ref as t, onMounted as m, onBeforeUnmount as p, openBlock as g, createBlock as b, resolveDynamicComponent as w, withCtx as _, renderSlot as I } from "vue";
2
- import { throttle as c } from "./index204.js";
2
+ import { throttle as c } from "./index216.js";
3
3
  const M = /* @__PURE__ */ h({
4
4
  __name: "BbIntersection",
5
5
  props: {
package/dist/index75.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { defineComponent as q, ref as s, useAttrs as G, computed as m, onMounted as J, watch as Q, onBeforeUnmount as X, openBlock as y, createBlock as Y, Teleport as Z, createElementVNode as o, mergeProps as N, createElementBlock as w, renderSlot as l, createTextVNode as ee, toDisplayString as z, createCommentVNode as B, nextTick as te } from "vue";
2
- import { useFocusTrap as oe } from "./index205.js";
2
+ import { useFocusTrap as oe } from "./index217.js";
3
3
  import { useId as L } from "./index7.js";
4
4
  import { wait as O } from "./index122.js";
5
5
  const se = { class: "bb-offcanvas-close" }, ae = { class: "bb-offcanvas-close__content" }, ne = { class: "bb-offcanvas-close__label" }, le = /* @__PURE__ */ o("span", { class: "bb-offcanvas-close__icon" }, [
package/dist/index79.js CHANGED
@@ -1,12 +1,12 @@
1
1
  import { defineComponent as V, ref as a, computed as _, openBlock as p, createElementBlock as h, mergeProps as B, createElementVNode as d, renderSlot as P, normalizeProps as I, guardReactiveProps as R, unref as g, createBlock as D, Teleport as U, normalizeClass as W, normalizeStyle as j, createCommentVNode as y, withCtx as G, nextTick as J } from "vue";
2
2
  import { useFloating as K, arrow as Q } from "./index223.js";
3
- import { useFocusTrap as X } from "./index205.js";
3
+ import { useFocusTrap as X } from "./index217.js";
4
4
  import { useId as Y } from "./index7.js";
5
5
  import { wait as E } from "./index122.js";
6
6
  import Z from "./index9.js";
7
7
  import "./index10.js";
8
- import { autoUpdate as ee, flip as oe, shift as te } from "./index209.js";
9
- import { offset as ae } from "./index211.js";
8
+ import { autoUpdate as ee, flip as oe, shift as te } from "./index205.js";
9
+ import { offset as ae } from "./index210.js";
10
10
  const re = ["id"], ne = {
11
11
  key: 1,
12
12
  class: "bb-popover__bubble"
package/dist/index81.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { defineComponent as a, computed as l, openBlock as s, createElementBlock as n, normalizeClass as m, createElementVNode as i, normalizeStyle as c } from "vue";
2
- import { clamp as p } from "./index212.js";
2
+ import { clamp as p } from "./index196.js";
3
3
  import { getAsPercentageBetween as d } from "./index121.js";
4
4
  const v = /* @__PURE__ */ a({
5
5
  __name: "BbProgress",