bromcom-ui 2.7.37-rc.3 → 2.7.37-rc.4-1

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 (238) hide show
  1. package/dist/collection/components/atoms/avatar/avatar.js +3 -3
  2. package/dist/collection/components/atoms/typography/typography.js +1 -1
  3. package/dist/collection/components/molecules/drawer/drawer.js +3 -3
  4. package/dist/collection/components/molecules/linked/linked.js +4 -4
  5. package/dist/collection/components/molecules/menu/menu.js +2 -2
  6. package/dist/collection/components/molecules/popover/popover.js +3 -3
  7. package/dist/collection/components/molecules/tooltip/tooltip.js +3 -3
  8. package/dist/collection/components/organism/list/list-tag-control.js +1 -1
  9. package/dist/collection/components/organism/list/list.js +5 -5
  10. package/dist/collection/components/other_deprecated/old-popover/old-popover-box.js +1 -1
  11. package/dist/collection/helper/popover-helper.js +2 -2
  12. package/dist/collection/helper/tooltip-helper.js +2 -2
  13. package/dist/collection/utils/floating-ui.js +1 -1
  14. package/dist/components/_commonjsHelpers.js +25 -0
  15. package/dist/components/avatar.js +124 -0
  16. package/dist/components/badge.js +95 -0
  17. package/dist/components/bcm-accordion.d.ts +11 -0
  18. package/dist/components/bcm-accordion.js +101 -0
  19. package/dist/components/bcm-alert.d.ts +11 -0
  20. package/dist/components/bcm-alert.js +140 -0
  21. package/dist/components/bcm-attendance.d.ts +11 -0
  22. package/dist/components/bcm-attendance.js +72 -0
  23. package/dist/components/bcm-autocomplete.d.ts +11 -0
  24. package/dist/components/bcm-autocomplete.js +293 -0
  25. package/dist/components/bcm-avatar.d.ts +11 -0
  26. package/dist/components/bcm-avatar.js +10 -0
  27. package/dist/components/bcm-badge.d.ts +11 -0
  28. package/dist/components/bcm-badge.js +10 -0
  29. package/dist/components/bcm-box.d.ts +11 -0
  30. package/dist/components/bcm-box.js +48 -0
  31. package/dist/components/bcm-breadcrumb.d.ts +11 -0
  32. package/dist/components/bcm-breadcrumb.js +96 -0
  33. package/dist/components/bcm-button-group.d.ts +11 -0
  34. package/dist/components/bcm-button-group.js +121 -0
  35. package/dist/components/bcm-button.d.ts +11 -0
  36. package/dist/components/bcm-button.js +10 -0
  37. package/dist/components/bcm-card.d.ts +11 -0
  38. package/dist/components/bcm-card.js +91 -0
  39. package/dist/components/bcm-checkbox-group.d.ts +11 -0
  40. package/dist/components/bcm-checkbox-group.js +474 -0
  41. package/dist/components/bcm-checkbox-lite.d.ts +11 -0
  42. package/dist/components/bcm-checkbox-lite.js +10 -0
  43. package/dist/components/bcm-checkbox.d.ts +11 -0
  44. package/dist/components/bcm-checkbox.js +10 -0
  45. package/dist/components/bcm-chip.d.ts +11 -0
  46. package/dist/components/bcm-chip.js +106 -0
  47. package/dist/components/bcm-collapse-group.d.ts +11 -0
  48. package/dist/components/bcm-collapse-group.js +75 -0
  49. package/dist/components/bcm-collapse.d.ts +11 -0
  50. package/dist/components/bcm-collapse.js +77 -0
  51. package/dist/components/bcm-colorpicker.d.ts +11 -0
  52. package/dist/components/bcm-colorpicker.js +491 -0
  53. package/dist/components/bcm-date-picker.d.ts +11 -0
  54. package/dist/components/bcm-date-picker.js +249 -0
  55. package/dist/components/bcm-datetime-picker.d.ts +11 -0
  56. package/dist/components/bcm-datetime-picker.js +10 -0
  57. package/dist/components/bcm-default.d.ts +11 -0
  58. package/dist/components/bcm-default.js +61 -0
  59. package/dist/components/bcm-divider.d.ts +11 -0
  60. package/dist/components/bcm-divider.js +10 -0
  61. package/dist/components/bcm-drawer.d.ts +11 -0
  62. package/dist/components/bcm-drawer.js +141 -0
  63. package/dist/components/bcm-dropdown.d.ts +11 -0
  64. package/dist/components/bcm-dropdown.js +306 -0
  65. package/dist/components/bcm-empty.d.ts +11 -0
  66. package/dist/components/bcm-empty.js +10 -0
  67. package/dist/components/bcm-error-layout.d.ts +11 -0
  68. package/dist/components/bcm-error-layout.js +98 -0
  69. package/dist/components/bcm-expansion-panel.d.ts +11 -0
  70. package/dist/components/bcm-expansion-panel.js +159 -0
  71. package/dist/components/bcm-form-2.d.ts +11 -0
  72. package/dist/components/bcm-form-2.js +226 -0
  73. package/dist/components/bcm-form-group.d.ts +11 -0
  74. package/dist/components/bcm-form-group.js +65 -0
  75. package/dist/components/bcm-form.d.ts +11 -0
  76. package/dist/components/bcm-form.js +510 -0
  77. package/dist/components/bcm-icon.d.ts +11 -0
  78. package/dist/components/bcm-icon.js +10 -0
  79. package/dist/components/bcm-input.d.ts +11 -0
  80. package/dist/components/bcm-input.js +404 -0
  81. package/dist/components/bcm-item.d.ts +11 -0
  82. package/dist/components/bcm-item.js +98 -0
  83. package/dist/components/bcm-items.d.ts +11 -0
  84. package/dist/components/bcm-items.js +74 -0
  85. package/dist/components/bcm-label.d.ts +11 -0
  86. package/dist/components/bcm-label.js +10 -0
  87. package/dist/components/bcm-link.d.ts +11 -0
  88. package/dist/components/bcm-link.js +10 -0
  89. package/dist/components/bcm-linked.d.ts +11 -0
  90. package/dist/components/bcm-linked.js +201 -0
  91. package/dist/components/bcm-list.d.ts +11 -0
  92. package/dist/components/bcm-list.js +1859 -0
  93. package/dist/components/bcm-listbox-group.d.ts +11 -0
  94. package/dist/components/bcm-listbox-group.js +10 -0
  95. package/dist/components/bcm-listbox-item.d.ts +11 -0
  96. package/dist/components/bcm-listbox-item.js +10 -0
  97. package/dist/components/bcm-listbox.d.ts +11 -0
  98. package/dist/components/bcm-listbox.js +10 -0
  99. package/dist/components/bcm-menu.d.ts +11 -0
  100. package/dist/components/bcm-menu.js +10 -0
  101. package/dist/components/bcm-message.d.ts +11 -0
  102. package/dist/components/bcm-message.js +126 -0
  103. package/dist/components/bcm-modal.d.ts +11 -0
  104. package/dist/components/bcm-modal.js +166 -0
  105. package/dist/components/bcm-notification.d.ts +11 -0
  106. package/dist/components/bcm-notification.js +136 -0
  107. package/dist/components/bcm-old-input.d.ts +11 -0
  108. package/dist/components/bcm-old-input.js +10 -0
  109. package/dist/components/bcm-old-search.d.ts +11 -0
  110. package/dist/components/bcm-old-search.js +10 -0
  111. package/dist/components/bcm-old-tag.d.ts +11 -0
  112. package/dist/components/bcm-old-tag.js +10 -0
  113. package/dist/components/bcm-popconfirm-box.d.ts +11 -0
  114. package/dist/components/bcm-popconfirm-box.js +10 -0
  115. package/dist/components/bcm-popconfirm.d.ts +11 -0
  116. package/dist/components/bcm-popconfirm.js +160 -0
  117. package/dist/components/bcm-popover.d.ts +11 -0
  118. package/dist/components/bcm-popover.js +203 -0
  119. package/dist/components/bcm-progress.d.ts +11 -0
  120. package/dist/components/bcm-progress.js +205 -0
  121. package/dist/components/bcm-radio-group.d.ts +11 -0
  122. package/dist/components/bcm-radio-group.js +334 -0
  123. package/dist/components/bcm-radio.d.ts +11 -0
  124. package/dist/components/bcm-radio.js +10 -0
  125. package/dist/components/bcm-range.d.ts +11 -0
  126. package/dist/components/bcm-range.js +220 -0
  127. package/dist/components/bcm-result.d.ts +11 -0
  128. package/dist/components/bcm-result.js +105 -0
  129. package/dist/components/bcm-search.d.ts +11 -0
  130. package/dist/components/bcm-search.js +10 -0
  131. package/dist/components/bcm-select-box.d.ts +11 -0
  132. package/dist/components/bcm-select-box.js +10 -0
  133. package/dist/components/bcm-select-group.d.ts +11 -0
  134. package/dist/components/bcm-select-group.js +48 -0
  135. package/dist/components/bcm-select-option.d.ts +11 -0
  136. package/dist/components/bcm-select-option.js +57 -0
  137. package/dist/components/bcm-select.d.ts +11 -0
  138. package/dist/components/bcm-select.js +1385 -0
  139. package/dist/components/bcm-skeleton.d.ts +11 -0
  140. package/dist/components/bcm-skeleton.js +10 -0
  141. package/dist/components/bcm-step.d.ts +11 -0
  142. package/dist/components/bcm-step.js +10 -0
  143. package/dist/components/bcm-stepper.d.ts +11 -0
  144. package/dist/components/bcm-stepper.js +249 -0
  145. package/dist/components/bcm-switch.d.ts +11 -0
  146. package/dist/components/bcm-switch.js +201 -0
  147. package/dist/components/bcm-tab-group.d.ts +11 -0
  148. package/dist/components/bcm-tab-group.js +190 -0
  149. package/dist/components/bcm-tab-pane.d.ts +11 -0
  150. package/dist/components/bcm-tab-pane.js +89 -0
  151. package/dist/components/bcm-tab.d.ts +11 -0
  152. package/dist/components/bcm-tab.js +125 -0
  153. package/dist/components/bcm-table.d.ts +11 -0
  154. package/dist/components/bcm-table.js +93 -0
  155. package/dist/components/bcm-tabs-content.d.ts +11 -0
  156. package/dist/components/bcm-tabs-content.js +80 -0
  157. package/dist/components/bcm-tabs.d.ts +11 -0
  158. package/dist/components/bcm-tabs.js +430 -0
  159. package/dist/components/bcm-tag.d.ts +11 -0
  160. package/dist/components/bcm-tag.js +132 -0
  161. package/dist/components/bcm-text.d.ts +11 -0
  162. package/dist/components/bcm-text.js +10 -0
  163. package/dist/components/bcm-textarea.d.ts +11 -0
  164. package/dist/components/bcm-textarea.js +212 -0
  165. package/dist/components/bcm-time-picker.d.ts +11 -0
  166. package/dist/components/bcm-time-picker.js +209 -0
  167. package/dist/components/bcm-timeline-item.d.ts +11 -0
  168. package/dist/components/bcm-timeline-item.js +81 -0
  169. package/dist/components/bcm-timeline.d.ts +11 -0
  170. package/dist/components/bcm-timeline.js +91 -0
  171. package/dist/components/bcm-tooltip.d.ts +11 -0
  172. package/dist/components/bcm-tooltip.js +10 -0
  173. package/dist/components/bcm-treeview-group.d.ts +11 -0
  174. package/dist/components/bcm-treeview-group.js +37 -0
  175. package/dist/components/bcm-treeview-item.d.ts +11 -0
  176. package/dist/components/bcm-treeview-item.js +10 -0
  177. package/dist/components/bcm-treeview.d.ts +11 -0
  178. package/dist/components/bcm-treeview.js +10 -0
  179. package/dist/components/bcm-typography.d.ts +11 -0
  180. package/dist/components/bcm-typography.js +10 -0
  181. package/dist/components/bcm.js +446 -0
  182. package/dist/components/button.js +403 -0
  183. package/dist/components/caption-template.js +32 -0
  184. package/dist/components/checkbox-lite.js +97 -0
  185. package/dist/components/checkbox.js +231 -0
  186. package/dist/components/color-helper.js +488 -0
  187. package/dist/components/colors.js +222 -0
  188. package/dist/components/datetime-picker.js +1509 -0
  189. package/dist/components/divider.js +59 -0
  190. package/dist/components/element-dragger.js +277 -0
  191. package/dist/components/empty.js +53 -0
  192. package/dist/components/floating-ui.js +1453 -0
  193. package/dist/components/generate.js +202 -0
  194. package/dist/components/icon.js +53 -0
  195. package/dist/components/index.d.ts +105 -0
  196. package/dist/components/index.js +99 -0
  197. package/dist/components/index2.js +62 -0
  198. package/dist/components/index3.js +191 -0
  199. package/dist/components/input-template.js +97 -0
  200. package/dist/components/is-load-decorator.js +54 -0
  201. package/dist/components/json-parse-decarator.js +38 -0
  202. package/dist/components/label-template.js +21 -0
  203. package/dist/components/label.js +83 -0
  204. package/dist/components/link.js +84 -0
  205. package/dist/components/listbox-group.js +55 -0
  206. package/dist/components/listbox-item.js +217 -0
  207. package/dist/components/listbox.js +1116 -0
  208. package/dist/components/menu.js +274 -0
  209. package/dist/components/number-helper.js +18 -0
  210. package/dist/components/old-bcm-popover-box.d.ts +11 -0
  211. package/dist/components/old-bcm-popover-box.js +10 -0
  212. package/dist/components/old-bcm-popover.d.ts +11 -0
  213. package/dist/components/old-bcm-popover.js +132 -0
  214. package/dist/components/old-input.js +470 -0
  215. package/dist/components/old-popover-box.js +184 -0
  216. package/dist/components/old-search.js +235 -0
  217. package/dist/components/old-tag.js +153 -0
  218. package/dist/components/popconfirm-box.js +160 -0
  219. package/dist/components/popover-placement.js +95 -0
  220. package/dist/components/property-decorators.js +31 -0
  221. package/dist/components/radio.js +119 -0
  222. package/dist/components/search.js +286 -0
  223. package/dist/components/select-box.js +165 -0
  224. package/dist/components/skeleton.js +69 -0
  225. package/dist/components/slot-template.js +13 -0
  226. package/dist/components/step.js +188 -0
  227. package/dist/components/string-helper.js +132 -0
  228. package/dist/components/text.js +72 -0
  229. package/dist/components/tooltip-helper.js +101 -0
  230. package/dist/components/tooltip.js +96 -0
  231. package/dist/components/treeview-item.js +419 -0
  232. package/dist/components/treeview.js +956 -0
  233. package/dist/components/types.js +32 -0
  234. package/dist/components/types2.js +32 -0
  235. package/dist/components/typography.js +45 -0
  236. package/dist/components/utils.js +123 -0
  237. package/dist/components/validators.js +35 -0
  238. package/package.json +4 -3
@@ -0,0 +1,74 @@
1
+ /*!
2
+ * Built with Stencil
3
+ * Copyright (c) Bromcom.
4
+ */
5
+ import { proxyCustomElement, HTMLElement, createEvent, h } from '@stencil/core/internal/client';
6
+ import { G as Generate, s as snq } from './generate.js';
7
+ import { I as IsLoad } from './is-load-decorator.js';
8
+ import { S as StringHelper } from './string-helper.js';
9
+
10
+ var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
11
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
12
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
13
+ r = Reflect.decorate(decorators, target, key, desc);
14
+ else
15
+ for (var i = decorators.length - 1; i >= 0; i--)
16
+ if (d = decorators[i])
17
+ r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
18
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
19
+ };
20
+ const BcmItems$1 = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
21
+ constructor() {
22
+ super();
23
+ this.__registerHost();
24
+ this.bcmItems = createEvent(this, "bcm-items", 7);
25
+ this._id = Generate.UID();
26
+ }
27
+ connectedCallback() {
28
+ if (this.el.children && this.el.children.length > 0) {
29
+ let slots = this.nestedItems(this.el);
30
+ this.bcmItems.emit(slots);
31
+ this.el.remove();
32
+ }
33
+ }
34
+ mapItems(element) {
35
+ var _a;
36
+ const item = element;
37
+ const textContent = (_a = item === null || item === void 0 ? void 0 : item.innerHTML) === null || _a === void 0 ? void 0 : _a.replace(/<bcm-item>.*<\/bcm-item>/g, '').replace(/<bcm-item .*>.*<\/bcm-item>/g, '').replace(/<!--(.|\s)*?-->/g, '').trim();
38
+ const checkAttr = (attr) => StringHelper.elementBooleanCheck(element.getAttribute(attr));
39
+ return Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign(Object.assign({ id: element.getAttribute('id') || Generate.UID(), text: element.getAttribute('text') || textContent }, (element.innerHTML.trim() && { isHtmlContent: element.textContent.length > 0 ? (element.innerHTML.trim()) : null })), (checkAttr('disabled') && { disabled: checkAttr('disabled') })), (checkAttr('selected') && { selected: checkAttr('selected') })), (checkAttr('checked') && { checked: checkAttr('checked') })), (checkAttr('readonly') && { readonly: checkAttr('readonly') })), (checkAttr('active') && { active: checkAttr('active') })), (checkAttr('icon') && { icon: element.getAttribute('icon') })), (checkAttr('link') && { link: element.getAttribute('link') }));
40
+ }
41
+ nestedItems(element) {
42
+ return snq(() => Array.from(element === null || element === void 0 ? void 0 : element.children).map((child) => {
43
+ var _a;
44
+ return (Object.assign(Object.assign({}, (((_a = child === null || child === void 0 ? void 0 : child.tagName) === null || _a === void 0 ? void 0 : _a.toLowerCase()) === 'bcm-item' && this.mapItems(child))), { items: this.nestedItems(child) }));
45
+ }), []);
46
+ }
47
+ render() {
48
+ return h("slot", null);
49
+ }
50
+ get el() { return this; }
51
+ }, [4, "bcm-items", {
52
+ "_id": [1537, "id"]
53
+ }]);
54
+ __decorate([
55
+ IsLoad()
56
+ ], BcmItems$1.prototype, "el", void 0);
57
+ function defineCustomElement$1() {
58
+ if (typeof customElements === "undefined") {
59
+ return;
60
+ }
61
+ const components = ["bcm-items"];
62
+ components.forEach(tagName => { switch (tagName) {
63
+ case "bcm-items":
64
+ if (!customElements.get(tagName)) {
65
+ customElements.define(tagName, BcmItems$1);
66
+ }
67
+ break;
68
+ } });
69
+ }
70
+
71
+ const BcmItems = BcmItems$1;
72
+ const defineCustomElement = defineCustomElement$1;
73
+
74
+ export { BcmItems, defineCustomElement };
@@ -0,0 +1,11 @@
1
+ import type { Components, JSX } from "../types/components";
2
+
3
+ interface BcmLabel extends Components.BcmLabel, HTMLElement {}
4
+ export const BcmLabel: {
5
+ prototype: BcmLabel;
6
+ new (): BcmLabel;
7
+ };
8
+ /**
9
+ * Used to define this component and all nested components recursively.
10
+ */
11
+ export const defineCustomElement: () => void;
@@ -0,0 +1,10 @@
1
+ /*!
2
+ * Built with Stencil
3
+ * Copyright (c) Bromcom.
4
+ */
5
+ import { B as BcmLabel$1, d as defineCustomElement$1 } from './label.js';
6
+
7
+ const BcmLabel = BcmLabel$1;
8
+ const defineCustomElement = defineCustomElement$1;
9
+
10
+ export { BcmLabel, defineCustomElement };
@@ -0,0 +1,11 @@
1
+ import type { Components, JSX } from "../types/components";
2
+
3
+ interface BcmLink extends Components.BcmLink, HTMLElement {}
4
+ export const BcmLink: {
5
+ prototype: BcmLink;
6
+ new (): BcmLink;
7
+ };
8
+ /**
9
+ * Used to define this component and all nested components recursively.
10
+ */
11
+ export const defineCustomElement: () => void;
@@ -0,0 +1,10 @@
1
+ /*!
2
+ * Built with Stencil
3
+ * Copyright (c) Bromcom.
4
+ */
5
+ import { B as BcmLink$1, d as defineCustomElement$1 } from './link.js';
6
+
7
+ const BcmLink = BcmLink$1;
8
+ const defineCustomElement = defineCustomElement$1;
9
+
10
+ export { BcmLink, defineCustomElement };
@@ -0,0 +1,11 @@
1
+ import type { Components, JSX } from "../types/components";
2
+
3
+ interface BcmLinked extends Components.BcmLinked, HTMLElement {}
4
+ export const BcmLinked: {
5
+ prototype: BcmLinked;
6
+ new (): BcmLinked;
7
+ };
8
+ /**
9
+ * Used to define this component and all nested components recursively.
10
+ */
11
+ export const defineCustomElement: () => void;
@@ -0,0 +1,201 @@
1
+ /*!
2
+ * Built with Stencil
3
+ * Copyright (c) Bromcom.
4
+ */
5
+ import { proxyCustomElement, HTMLElement, h, Host } from '@stencil/core/internal/client';
6
+ import { a as Bcm } from './bcm.js';
7
+ import './element-dragger.js';
8
+ import './string-helper.js';
9
+ import { d as delay } from './utils.js';
10
+ import { F as FloatingUI } from './floating-ui.js';
11
+ import './color-helper.js';
12
+ import './validators.js';
13
+ import { G as Generate } from './generate.js';
14
+ import './number-helper.js';
15
+ import { I as IsLoad } from './is-load-decorator.js';
16
+
17
+ var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
18
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
19
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
20
+ r = Reflect.decorate(decorators, target, key, desc);
21
+ else
22
+ for (var i = decorators.length - 1; i >= 0; i--)
23
+ if (d = decorators[i])
24
+ r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
25
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
26
+ };
27
+ const BcmLinked$1 = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
28
+ constructor() {
29
+ super();
30
+ this.__registerHost();
31
+ this._id = Generate.UID();
32
+ this.placement = Bcm.Placement['bottom-start'];
33
+ this.trigger = Bcm.TriggerType.click;
34
+ this.targetId = '';
35
+ this.minHeight = '50px';
36
+ this.isOpen = false;
37
+ }
38
+ target() {
39
+ const target = document.querySelectorAll(`[id="${this.targetId}"]`);
40
+ if (target.length > 0) {
41
+ target.length > 1 && console.warn(`[bcm-linked] - Target id "${this.targetId}" is duplicated`);
42
+ return target[0];
43
+ }
44
+ else {
45
+ // console.warn(`[bcm-linked] - id="${this._id}" was removed from the dom because id="${this.targetId}" could not be found.`);
46
+ this.el.remove();
47
+ return null;
48
+ }
49
+ }
50
+ dismissEvent() {
51
+ document.dispatchEvent(new CustomEvent('linked-data-dismiss', { detail: { id: this._id } }));
52
+ }
53
+ checkDataDismiss(e) {
54
+ Generate.findEventPathHasAttribute(e, 'data-dismiss') && this.dismissEvent();
55
+ }
56
+ hideChildLinked() {
57
+ this.el.querySelectorAll('[is-linked][linked-is-open]').forEach(item => {
58
+ var _a;
59
+ (_a = document.querySelector(`#${item.getAttribute('is-linked')}[is-open]`)) === null || _a === void 0 ? void 0 : _a.hide(false);
60
+ });
61
+ }
62
+ calculatePosition() {
63
+ const el = this.el;
64
+ if (el && this.target()) {
65
+ if (this.isOpen) {
66
+ FloatingUI({
67
+ ref: this.target(),
68
+ floating: el,
69
+ placement: this.placement,
70
+ offset: 4,
71
+ autoHidden: el.getAttribute('main-linked') === 'true' ? false : true,
72
+ autoSize: true,
73
+ style: {
74
+ height: this.height,
75
+ maxHeight: this.maxHeight,
76
+ minHeight: this.minHeight,
77
+ },
78
+ });
79
+ }
80
+ else {
81
+ el.style.visibility = 'hidden';
82
+ el.style.opacity = '0';
83
+ }
84
+ }
85
+ }
86
+ init() {
87
+ const target = this.target();
88
+ if (target) {
89
+ target.setAttribute('is-linked', this.el.id);
90
+ if (!Generate.getAncestor(target, 'bcm-linked')) {
91
+ this.el.setAttribute('main-linked', 'true');
92
+ }
93
+ else {
94
+ this.el.removeAttribute('main-linked');
95
+ }
96
+ }
97
+ }
98
+ componentDidLoad() {
99
+ this.init();
100
+ document.body.appendChild(this.el);
101
+ }
102
+ onLinkedDataDismis() {
103
+ this.hide(false);
104
+ }
105
+ onBcmFloatingIsHide(e) {
106
+ if (e.detail.id === this._id) {
107
+ this.hide(false);
108
+ }
109
+ }
110
+ async show(wait = true) {
111
+ wait && (await delay(50));
112
+ const target = this.target();
113
+ if (target) {
114
+ document.body.appendChild(this.el);
115
+ target.setAttribute('linked-is-open', 'true');
116
+ this.isOpen = true;
117
+ this.calculatePosition();
118
+ }
119
+ else {
120
+ this.hide(false);
121
+ }
122
+ return this.isOpen;
123
+ }
124
+ async hide(wait = true) {
125
+ wait && (await delay(50));
126
+ const target = this.target();
127
+ if (target) {
128
+ target.removeAttribute('linked-is-open');
129
+ this.hideChildLinked();
130
+ this.isOpen = false;
131
+ }
132
+ return this.isOpen;
133
+ }
134
+ async toggle(wait = true) {
135
+ return this.isOpen ? await this.hide(wait) : await this.show(wait);
136
+ }
137
+ clickListener(e) {
138
+ if (!this.target())
139
+ return;
140
+ const isTarget = Generate.findEventPath(e, this.target());
141
+ if (this.isOpen) {
142
+ isTarget && this.hide(false);
143
+ const isSelf = Generate.findEventPath(e, this.el);
144
+ const isLinked = Generate.findEventPathWithNodeName(e, 'BCM-LINKED');
145
+ isSelf && this.checkDataDismiss(e);
146
+ if (this.el.getAttribute('main-linked') === 'true' && !isTarget && !isSelf && !isLinked) {
147
+ this.dismissEvent();
148
+ }
149
+ }
150
+ else {
151
+ isTarget && this.show(false);
152
+ }
153
+ }
154
+ resizeListener() {
155
+ this.calculatePosition();
156
+ }
157
+ scrollListener() {
158
+ this.calculatePosition();
159
+ }
160
+ wheelListener() {
161
+ this.calculatePosition();
162
+ }
163
+ render() {
164
+ const openStyle = this.isOpen ? { visibility: 'visible', opacity: '1' } : { visibility: 'hidden', opacity: '0' };
165
+ return (h(Host, { class: "tw-block tw-opacity-0 tw-invisible tw-top-0 tw-left-0 tw-rounded tw-bg-white tw-z-tooltip tw-transition-opacity tw-duration-100 tw-shadow tw-overscroll-contain tw-scroll-smooth tw-absolute", style: Object.assign(Object.assign({}, openStyle), { overflow: 'auto' }) }, h("slot", null)));
166
+ }
167
+ get el() { return this; }
168
+ }, [4, "bcm-linked", {
169
+ "_id": [513, "id"],
170
+ "placement": [1],
171
+ "trigger": [1],
172
+ "targetId": [1, "target-id"],
173
+ "height": [1],
174
+ "maxHeight": [1, "max-height"],
175
+ "minHeight": [1, "min-height"],
176
+ "isOpen": [1540, "is-open"],
177
+ "show": [64],
178
+ "hide": [64],
179
+ "toggle": [64]
180
+ }, [[4, "linked-data-dismiss", "onLinkedDataDismis"], [4, "bcm-floating-is-hide", "onBcmFloatingIsHide"], [8, "click", "clickListener"], [9, "resize", "resizeListener"], [9, "scroll", "scrollListener"], [9, "wheel", "wheelListener"]]]);
181
+ __decorate([
182
+ IsLoad()
183
+ ], BcmLinked$1.prototype, "el", void 0);
184
+ function defineCustomElement$1() {
185
+ if (typeof customElements === "undefined") {
186
+ return;
187
+ }
188
+ const components = ["bcm-linked"];
189
+ components.forEach(tagName => { switch (tagName) {
190
+ case "bcm-linked":
191
+ if (!customElements.get(tagName)) {
192
+ customElements.define(tagName, BcmLinked$1);
193
+ }
194
+ break;
195
+ } });
196
+ }
197
+
198
+ const BcmLinked = BcmLinked$1;
199
+ const defineCustomElement = defineCustomElement$1;
200
+
201
+ export { BcmLinked, defineCustomElement };
@@ -0,0 +1,11 @@
1
+ import type { Components, JSX } from "../types/components";
2
+
3
+ interface BcmList extends Components.BcmList, HTMLElement {}
4
+ export const BcmList: {
5
+ prototype: BcmList;
6
+ new (): BcmList;
7
+ };
8
+ /**
9
+ * Used to define this component and all nested components recursively.
10
+ */
11
+ export const defineCustomElement: () => void;