@dnncommunity/dnn-elements 0.15.0-beta.7 → 0.15.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 (221) hide show
  1. package/dist/cjs/dnn-button_17.cjs.entry.js +1 -1
  2. package/dist/cjs/dnn-button_17.cjs.entry.js.map +1 -1
  3. package/dist/cjs/dnn.cjs.js +4 -116
  4. package/dist/cjs/dnn.cjs.js.map +1 -1
  5. package/dist/cjs/loader.cjs.js +2 -18
  6. package/dist/cjs/loader.cjs.js.map +1 -1
  7. package/dist/collection/components/dnn-tabs/dnn-tabs.css +0 -1
  8. package/dist/collection/components/dnn-tabs/dnn-tabs.stories.js +5 -0
  9. package/dist/collection/components/dnn-tabs/dnn-tabs.stories.js.map +1 -1
  10. package/dist/dnn/dnn.esm.js +1 -130
  11. package/dist/dnn/dnn.esm.js.map +1 -1
  12. package/dist/dnn/dnn.js +1 -1
  13. package/dist/dnn/index.esm.js +1 -46
  14. package/dist/dnn/index.esm.js.map +1 -1
  15. package/dist/dnn/{p-c222c8b7.entry.js → p-058a3145.entry.js} +2 -2
  16. package/dist/dnn/{p-c222c8b7.entry.js.map → p-058a3145.entry.js.map} +1 -1
  17. package/dist/dnn/{p-31dc68a7.system.entry.js → p-1893c229.system.entry.js} +2 -2
  18. package/dist/dnn/{p-31dc68a7.system.entry.js.map → p-1893c229.system.entry.js.map} +1 -1
  19. package/dist/dnn/p-5bcf3629.system.js +1 -1
  20. package/dist/esm/dnn-button_17.entry.js +1 -1
  21. package/dist/esm/dnn-button_17.entry.js.map +1 -1
  22. package/dist/esm/dnn.js +4 -116
  23. package/dist/esm/dnn.js.map +1 -1
  24. package/dist/esm/loader.js +2 -18
  25. package/dist/esm/loader.js.map +1 -1
  26. package/dist/esm-es5/dnn-button_17.entry.js +1 -1
  27. package/dist/esm-es5/dnn-button_17.entry.js.map +1 -1
  28. package/dist/index.js +1 -1
  29. package/package.json +6 -3
  30. package/dist/cjs/app-globals-3a1e7e63.js +0 -7
  31. package/dist/cjs/app-globals-3a1e7e63.js.map +0 -1
  32. package/dist/cjs/css-shim-aaf4fec9.js +0 -8
  33. package/dist/cjs/css-shim-aaf4fec9.js.map +0 -1
  34. package/dist/cjs/dnn-button.cjs.entry.js +0 -92
  35. package/dist/cjs/dnn-button.cjs.entry.js.map +0 -1
  36. package/dist/cjs/dnn-checkbox.cjs.entry.js +0 -58
  37. package/dist/cjs/dnn-checkbox.cjs.entry.js.map +0 -1
  38. package/dist/cjs/dnn-chevron.cjs.entry.js +0 -34
  39. package/dist/cjs/dnn-chevron.cjs.entry.js.map +0 -1
  40. package/dist/cjs/dnn-collapsible.cjs.entry.js +0 -69
  41. package/dist/cjs/dnn-collapsible.cjs.entry.js.map +0 -1
  42. package/dist/cjs/dnn-color-picker.cjs.entry.js +0 -508
  43. package/dist/cjs/dnn-color-picker.cjs.entry.js.map +0 -1
  44. package/dist/cjs/dnn-dropzone.cjs.entry.js +0 -153
  45. package/dist/cjs/dnn-dropzone.cjs.entry.js.map +0 -1
  46. package/dist/cjs/dnn-image-cropper.cjs.entry.js +0 -408
  47. package/dist/cjs/dnn-image-cropper.cjs.entry.js.map +0 -1
  48. package/dist/cjs/dnn-modal.cjs.entry.js +0 -65
  49. package/dist/cjs/dnn-modal.cjs.entry.js.map +0 -1
  50. package/dist/cjs/dnn-permissions-grid.cjs.entry.js +0 -320
  51. package/dist/cjs/dnn-permissions-grid.cjs.entry.js.map +0 -1
  52. package/dist/cjs/dnn-searchbox.cjs.entry.js +0 -66
  53. package/dist/cjs/dnn-searchbox.cjs.entry.js.map +0 -1
  54. package/dist/cjs/dnn-sort-icon.cjs.entry.js +0 -43
  55. package/dist/cjs/dnn-sort-icon.cjs.entry.js.map +0 -1
  56. package/dist/cjs/dnn-tab.cjs.entry.js +0 -31
  57. package/dist/cjs/dnn-tab.cjs.entry.js.map +0 -1
  58. package/dist/cjs/dnn-tabs.cjs.entry.js +0 -52
  59. package/dist/cjs/dnn-tabs.cjs.entry.js.map +0 -1
  60. package/dist/cjs/dnn-toggle.cjs.entry.js +0 -37
  61. package/dist/cjs/dnn-toggle.cjs.entry.js.map +0 -1
  62. package/dist/cjs/dnn-treeview-item.cjs.entry.js +0 -68
  63. package/dist/cjs/dnn-treeview-item.cjs.entry.js.map +0 -1
  64. package/dist/cjs/dnn-vertical-overflow-menu.cjs.entry.js +0 -124
  65. package/dist/cjs/dnn-vertical-overflow-menu.cjs.entry.js.map +0 -1
  66. package/dist/cjs/dnn-vertical-splitview.cjs.entry.js +0 -133
  67. package/dist/cjs/dnn-vertical-splitview.cjs.entry.js.map +0 -1
  68. package/dist/cjs/dom-14886762.js +0 -77
  69. package/dist/cjs/dom-14886762.js.map +0 -1
  70. package/dist/cjs/index-d53702a3.js +0 -3095
  71. package/dist/cjs/index-d53702a3.js.map +0 -1
  72. package/dist/cjs/mouseUtilities-ecd5ecf7.js +0 -25
  73. package/dist/cjs/mouseUtilities-ecd5ecf7.js.map +0 -1
  74. package/dist/cjs/shadow-css-c44ea13a.js +0 -392
  75. package/dist/cjs/shadow-css-c44ea13a.js.map +0 -1
  76. package/dist/dnn/app-globals-0f993ce5.js +0 -5
  77. package/dist/dnn/app-globals-0f993ce5.js.map +0 -1
  78. package/dist/dnn/app-globals-497eb362.system.js +0 -2
  79. package/dist/dnn/app-globals-497eb362.system.js.map +0 -1
  80. package/dist/dnn/css-shim-091f949f.js +0 -6
  81. package/dist/dnn/css-shim-091f949f.js.map +0 -1
  82. package/dist/dnn/css-shim-c5bffe6b.system.js +0 -2
  83. package/dist/dnn/css-shim-c5bffe6b.system.js.map +0 -1
  84. package/dist/dnn/debounce-6be67abd.js +0 -22
  85. package/dist/dnn/debounce-6be67abd.js.map +0 -1
  86. package/dist/dnn/debounce-db438a09.system.js +0 -2
  87. package/dist/dnn/debounce-db438a09.system.js.map +0 -1
  88. package/dist/dnn/dnn-button.entry.js +0 -88
  89. package/dist/dnn/dnn-button.entry.js.map +0 -1
  90. package/dist/dnn/dnn-button.system.entry.js +0 -2
  91. package/dist/dnn/dnn-button.system.entry.js.map +0 -1
  92. package/dist/dnn/dnn-checkbox.entry.js +0 -54
  93. package/dist/dnn/dnn-checkbox.entry.js.map +0 -1
  94. package/dist/dnn/dnn-checkbox.system.entry.js +0 -2
  95. package/dist/dnn/dnn-checkbox.system.entry.js.map +0 -1
  96. package/dist/dnn/dnn-chevron.entry.js +0 -30
  97. package/dist/dnn/dnn-chevron.entry.js.map +0 -1
  98. package/dist/dnn/dnn-chevron.system.entry.js +0 -2
  99. package/dist/dnn/dnn-chevron.system.entry.js.map +0 -1
  100. package/dist/dnn/dnn-collapsible.entry.js +0 -65
  101. package/dist/dnn/dnn-collapsible.entry.js.map +0 -1
  102. package/dist/dnn/dnn-collapsible.system.entry.js +0 -2
  103. package/dist/dnn/dnn-collapsible.system.entry.js.map +0 -1
  104. package/dist/dnn/dnn-color-picker.entry.js +0 -504
  105. package/dist/dnn/dnn-color-picker.entry.js.map +0 -1
  106. package/dist/dnn/dnn-color-picker.system.entry.js +0 -12
  107. package/dist/dnn/dnn-color-picker.system.entry.js.map +0 -1
  108. package/dist/dnn/dnn-dropzone.entry.js +0 -149
  109. package/dist/dnn/dnn-dropzone.entry.js.map +0 -1
  110. package/dist/dnn/dnn-dropzone.system.entry.js +0 -2
  111. package/dist/dnn/dnn-dropzone.system.entry.js.map +0 -1
  112. package/dist/dnn/dnn-image-cropper.entry.js +0 -404
  113. package/dist/dnn/dnn-image-cropper.entry.js.map +0 -1
  114. package/dist/dnn/dnn-image-cropper.system.entry.js +0 -2
  115. package/dist/dnn/dnn-image-cropper.system.entry.js.map +0 -1
  116. package/dist/dnn/dnn-modal.entry.js +0 -61
  117. package/dist/dnn/dnn-modal.entry.js.map +0 -1
  118. package/dist/dnn/dnn-modal.system.entry.js +0 -2
  119. package/dist/dnn/dnn-modal.system.entry.js.map +0 -1
  120. package/dist/dnn/dnn-permissions-grid.entry.js +0 -316
  121. package/dist/dnn/dnn-permissions-grid.entry.js.map +0 -1
  122. package/dist/dnn/dnn-permissions-grid.system.entry.js +0 -2
  123. package/dist/dnn/dnn-permissions-grid.system.entry.js.map +0 -1
  124. package/dist/dnn/dnn-searchbox.entry.js +0 -62
  125. package/dist/dnn/dnn-searchbox.entry.js.map +0 -1
  126. package/dist/dnn/dnn-searchbox.system.entry.js +0 -2
  127. package/dist/dnn/dnn-searchbox.system.entry.js.map +0 -1
  128. package/dist/dnn/dnn-sort-icon.entry.js +0 -39
  129. package/dist/dnn/dnn-sort-icon.entry.js.map +0 -1
  130. package/dist/dnn/dnn-sort-icon.system.entry.js +0 -2
  131. package/dist/dnn/dnn-sort-icon.system.entry.js.map +0 -1
  132. package/dist/dnn/dnn-tab.entry.js +0 -27
  133. package/dist/dnn/dnn-tab.entry.js.map +0 -1
  134. package/dist/dnn/dnn-tab.system.entry.js +0 -2
  135. package/dist/dnn/dnn-tab.system.entry.js.map +0 -1
  136. package/dist/dnn/dnn-tabs.entry.js +0 -48
  137. package/dist/dnn/dnn-tabs.entry.js.map +0 -1
  138. package/dist/dnn/dnn-tabs.system.entry.js +0 -2
  139. package/dist/dnn/dnn-tabs.system.entry.js.map +0 -1
  140. package/dist/dnn/dnn-toggle.entry.js +0 -33
  141. package/dist/dnn/dnn-toggle.entry.js.map +0 -1
  142. package/dist/dnn/dnn-toggle.system.entry.js +0 -2
  143. package/dist/dnn/dnn-toggle.system.entry.js.map +0 -1
  144. package/dist/dnn/dnn-treeview-item.entry.js +0 -64
  145. package/dist/dnn/dnn-treeview-item.entry.js.map +0 -1
  146. package/dist/dnn/dnn-treeview-item.system.entry.js +0 -2
  147. package/dist/dnn/dnn-treeview-item.system.entry.js.map +0 -1
  148. package/dist/dnn/dnn-vertical-overflow-menu.entry.js +0 -120
  149. package/dist/dnn/dnn-vertical-overflow-menu.entry.js.map +0 -1
  150. package/dist/dnn/dnn-vertical-overflow-menu.system.entry.js +0 -2
  151. package/dist/dnn/dnn-vertical-overflow-menu.system.entry.js.map +0 -1
  152. package/dist/dnn/dnn-vertical-splitview.entry.js +0 -129
  153. package/dist/dnn/dnn-vertical-splitview.entry.js.map +0 -1
  154. package/dist/dnn/dnn-vertical-splitview.system.entry.js +0 -2
  155. package/dist/dnn/dnn-vertical-splitview.system.entry.js.map +0 -1
  156. package/dist/dnn/dnn.system.js +0 -2
  157. package/dist/dnn/dnn.system.js.map +0 -1
  158. package/dist/dnn/dom-99eb7b76.system.js +0 -22
  159. package/dist/dnn/dom-99eb7b76.system.js.map +0 -1
  160. package/dist/dnn/dom-a385e381.js +0 -75
  161. package/dist/dnn/dom-a385e381.js.map +0 -1
  162. package/dist/dnn/index-20e42ad7.js +0 -3059
  163. package/dist/dnn/index-20e42ad7.js.map +0 -1
  164. package/dist/dnn/index-c3cc3b5b.system.js +0 -2
  165. package/dist/dnn/index-c3cc3b5b.system.js.map +0 -1
  166. package/dist/dnn/index.system.js +0 -2
  167. package/dist/dnn/index.system.js.map +0 -1
  168. package/dist/dnn/mouseUtilities-233ad7e3.system.js +0 -2
  169. package/dist/dnn/mouseUtilities-233ad7e3.system.js.map +0 -1
  170. package/dist/dnn/mouseUtilities-b261ca4f.js +0 -23
  171. package/dist/dnn/mouseUtilities-b261ca4f.js.map +0 -1
  172. package/dist/dnn/shadow-css-27708fdd.system.js +0 -14
  173. package/dist/dnn/shadow-css-27708fdd.system.js.map +0 -1
  174. package/dist/dnn/shadow-css-ef431969.js +0 -390
  175. package/dist/dnn/shadow-css-ef431969.js.map +0 -1
  176. package/dist/esm/app-globals-0f993ce5.js +0 -5
  177. package/dist/esm/app-globals-0f993ce5.js.map +0 -1
  178. package/dist/esm/css-shim-091f949f.js +0 -6
  179. package/dist/esm/css-shim-091f949f.js.map +0 -1
  180. package/dist/esm/dnn-button.entry.js +0 -88
  181. package/dist/esm/dnn-button.entry.js.map +0 -1
  182. package/dist/esm/dnn-checkbox.entry.js +0 -54
  183. package/dist/esm/dnn-checkbox.entry.js.map +0 -1
  184. package/dist/esm/dnn-chevron.entry.js +0 -30
  185. package/dist/esm/dnn-chevron.entry.js.map +0 -1
  186. package/dist/esm/dnn-collapsible.entry.js +0 -65
  187. package/dist/esm/dnn-collapsible.entry.js.map +0 -1
  188. package/dist/esm/dnn-color-picker.entry.js +0 -504
  189. package/dist/esm/dnn-color-picker.entry.js.map +0 -1
  190. package/dist/esm/dnn-dropzone.entry.js +0 -149
  191. package/dist/esm/dnn-dropzone.entry.js.map +0 -1
  192. package/dist/esm/dnn-image-cropper.entry.js +0 -404
  193. package/dist/esm/dnn-image-cropper.entry.js.map +0 -1
  194. package/dist/esm/dnn-modal.entry.js +0 -61
  195. package/dist/esm/dnn-modal.entry.js.map +0 -1
  196. package/dist/esm/dnn-permissions-grid.entry.js +0 -316
  197. package/dist/esm/dnn-permissions-grid.entry.js.map +0 -1
  198. package/dist/esm/dnn-searchbox.entry.js +0 -62
  199. package/dist/esm/dnn-searchbox.entry.js.map +0 -1
  200. package/dist/esm/dnn-sort-icon.entry.js +0 -39
  201. package/dist/esm/dnn-sort-icon.entry.js.map +0 -1
  202. package/dist/esm/dnn-tab.entry.js +0 -27
  203. package/dist/esm/dnn-tab.entry.js.map +0 -1
  204. package/dist/esm/dnn-tabs.entry.js +0 -48
  205. package/dist/esm/dnn-tabs.entry.js.map +0 -1
  206. package/dist/esm/dnn-toggle.entry.js +0 -33
  207. package/dist/esm/dnn-toggle.entry.js.map +0 -1
  208. package/dist/esm/dnn-treeview-item.entry.js +0 -64
  209. package/dist/esm/dnn-treeview-item.entry.js.map +0 -1
  210. package/dist/esm/dnn-vertical-overflow-menu.entry.js +0 -120
  211. package/dist/esm/dnn-vertical-overflow-menu.entry.js.map +0 -1
  212. package/dist/esm/dnn-vertical-splitview.entry.js +0 -129
  213. package/dist/esm/dnn-vertical-splitview.entry.js.map +0 -1
  214. package/dist/esm/dom-a385e381.js +0 -75
  215. package/dist/esm/dom-a385e381.js.map +0 -1
  216. package/dist/esm/index-20e42ad7.js +0 -3059
  217. package/dist/esm/index-20e42ad7.js.map +0 -1
  218. package/dist/esm/mouseUtilities-b261ca4f.js +0 -23
  219. package/dist/esm/mouseUtilities-b261ca4f.js.map +0 -1
  220. package/dist/esm/shadow-css-ef431969.js +0 -390
  221. package/dist/esm/shadow-css-ef431969.js.map +0 -1
@@ -1,62 +0,0 @@
1
- import { r as registerInstance, e as createEvent, h, f as Host } from './index-20e42ad7.js';
2
- import { D as Debounce } from './debounce-6be67abd.js';
3
-
4
- const dnnSearchboxCss = ":host{position:relative;display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between;--background-color:transparent;--color:#333;--border-size:1px;--border-color:grey;--border-active-color:black;--border-radius:var(--dnn-controls-radius, 5px);--padding:var(--dnn-controls-padding, 5px);--focus-color:var(--dnn-color-primary, blue)}:host input{width:100%;border:var(--border-size) solid var(--border-color);outline:none;border-radius:var(--border-radius);padding:var(--padding);padding-right:32px;-webkit-transition:all 300ms ease-in-out;transition:all 300ms ease-in-out}:host input:focus,:host input:hover{outline:none;-webkit-box-shadow:0 0 2px 2px var(--focus-color);box-shadow:0 0 2px 2px var(--focus-color)}:host svg{position:absolute;top:0;right:0;height:100%;-webkit-transform:scale(0.7);transform:scale(0.7);fill:var(--color);outline:var(--color);color:var(--color);-webkit-transition:all 300ms ease-in-out;transition:all 300ms ease-in-out}:host button{background:transparent;border:0;margin:0;padding:0}:host button:focus svg,:host button:hover svg{fill:var(--focus-color);outline:var(--focus-color);color:var(--focus-color)}";
5
-
6
- var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
7
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
8
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
9
- r = Reflect.decorate(decorators, target, key, desc);
10
- else
11
- for (var i = decorators.length - 1; i >= 0; i--)
12
- if (d = decorators[i])
13
- r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
14
- return c > 3 && r && Object.defineProperty(target, key, r), r;
15
- };
16
- const DnnSearchbox = class {
17
- constructor(hostRef) {
18
- registerInstance(this, hostRef);
19
- this.queryChanged = createEvent(this, "queryChanged", 7);
20
- /**
21
- * Sets the field placeholder text.
22
- */
23
- this.placeholder = "";
24
- /**
25
- * Debounces the queryChanged by 500ms.
26
- */
27
- this.debounced = true;
28
- /** Sets the query */
29
- this.query = "";
30
- }
31
- fireQueryChanged() {
32
- if (this.debounced) {
33
- this.debouncedHandleQueryChanged();
34
- }
35
- else {
36
- this.handleQueryChanged();
37
- }
38
- }
39
- handleQueryChanged() {
40
- this.queryChanged.emit(this.query);
41
- }
42
- debouncedHandleQueryChanged() {
43
- this.handleQueryChanged();
44
- }
45
- render() {
46
- return (h(Host, null, h("input", { type: "text", value: this.query, placeholder: this.placeholder, onInput: e => this.query = e.target.value }), this.query !== "" ?
47
- h("button", { class: "svg clear", onClick: () => this.query = "" }, h("svg", { xmlns: "http://www.w3.org/2000/svg", height: "24px", viewBox: "0 0 24 24", width: "24px", fill: "#000000" }, h("path", { d: "M0 0h24v24H0z", fill: "none" }), h("path", { d: "M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12 17 15.59z" })))
48
- :
49
- h("svg", { xmlns: "http://www.w3.org/2000/svg", height: "24px", viewBox: "0 0 24 24", width: "24px", fill: "#000000" }, h("path", { d: "M0 0h24v24H0z", fill: "none" }), h("path", { d: "M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z" }))));
50
- }
51
- static get watchers() { return {
52
- "query": ["fireQueryChanged"]
53
- }; }
54
- };
55
- __decorate([
56
- Debounce(500)
57
- ], DnnSearchbox.prototype, "debouncedHandleQueryChanged", null);
58
- DnnSearchbox.style = dnnSearchboxCss;
59
-
60
- export { DnnSearchbox as dnn_searchbox };
61
-
62
- //# sourceMappingURL=dnn-searchbox.entry.js.map
@@ -1 +0,0 @@
1
- {"file":"dnn-searchbox.entry.js","mappings":";;;AAAA,MAAM,eAAe,GAAG,uoCAAuoC;;;;;;;;;;;;MCOlpC,YAAY;EALzB;;;;;;IAUU,gBAAW,GAAY,EAAE,CAAC;;;;IAK1B,cAAS,GAAY,IAAI,CAAC;;IAGX,UAAK,GAAW,EAAE,CAAC;GA+C3C;EAtCC,gBAAgB;IACd,IAAI,IAAI,CAAC,SAAS,EAAC;MACjB,IAAI,CAAC,2BAA2B,EAAE,CAAC;KACpC;SACG;MACF,IAAI,CAAC,kBAAkB,EAAE,CAAC;KAC3B;GACF;EAEO,kBAAkB;IACxB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;GACpC;EAGO,2BAA2B;IACjC,IAAI,CAAC,kBAAkB,EAAE,CAAC;GAC3B;EAED,MAAM;IACJ,QACE,EAAC,IAAI,QACH,aAAO,IAAI,EAAC,MAAM,EAAC,KAAK,EAAE,IAAI,CAAC,KAAK,EAClC,WAAW,EAAE,IAAI,CAAC,WAAW,EAC7B,OAAO,EAAE,CAAC,IAAI,IAAI,CAAC,KAAK,GAAI,CAAC,CAAC,MAA2B,CAAC,KAAK,GAC/D,EACD,IAAI,CAAC,KAAK,KAAK,EAAE;MAChB,cAAQ,KAAK,EAAC,WAAW,EACvB,OAAO,EAAE,MAAM,IAAI,CAAC,KAAK,GAAG,EAAE,IAE9B,WAAK,KAAK,EAAC,4BAA4B,EAAC,MAAM,EAAC,MAAM,EAAC,OAAO,EAAC,WAAW,EAAC,KAAK,EAAC,MAAM,EAAC,IAAI,EAAC,SAAS,IAAC,YAAM,CAAC,EAAC,eAAe,EAAC,IAAI,EAAC,MAAM,GAAE,EAAA,YAAM,CAAC,EAAC,iLAAiL,GAAE,CAAM,CACrU;;QAEX,WAAK,KAAK,EAAC,4BAA4B,EAAC,MAAM,EAAC,MAAM,EAAC,OAAO,EAAC,WAAW,EAAC,KAAK,EAAC,MAAM,EAAC,IAAI,EAAC,SAAS,IAAC,YAAM,CAAC,EAAC,eAAe,EAAC,IAAI,EAAC,MAAM,GAAE,EAAA,YAAM,CAAC,EAAC,4OAA4O,GAAE,CAAM,CAElY,EACP;GACH;;;;;AAtBD;EADC,QAAQ,CAAC,GAAG,CAAC;+DAGb;;;;;","names":[],"sources":["./src/components/dnn-searchbox/dnn-searchbox.scss?tag=dnn-searchbox&encapsulation=shadow","./src/components/dnn-searchbox/dnn-searchbox.tsx"],"sourcesContent":[":host {\n position: relative;\n display: flex;\n justify-content: space-between;\n --background-color: transparent;\n --color: #333;\n --border-size: 1px;\n --border-color: grey;\n --border-active-color: black;\n --border-radius: var(--dnn-controls-radius, 5px);\n --padding: var(--dnn-controls-padding, 5px);\n --focus-color: var(--dnn-color-primary, blue);\n input {\n width:100%;\n border: var(--border-size) solid var(--border-color);\n outline: none;\n border-radius: var(--border-radius);\n padding: var(--padding);\n padding-right: 32px;\n transition: all 300ms ease-in-out;\n &:focus, &:hover{\n outline: none;\n box-shadow: 0 0 2px 2px var(--focus-color);\n }\n }\n svg{\n position: absolute;\n top:0;\n right:0;\n height: 100%;\n transform: scale(0.7);\n fill: var(--color);\n outline: var(--color);\n color: var(--color);\n transition: all 300ms ease-in-out;\n }\n button{\n background: transparent;\n border: 0;\n margin: 0;\n padding: 0;\n &:focus, &:hover{\n svg{\n fill: var(--focus-color);\n outline: var(--focus-color);\n color: var(--focus-color);\n }\n }\n }\n}\n","import { Component, Host, h, Event, EventEmitter, Watch, Prop } from '@stencil/core';\nimport { Debounce } from '../../utilities/debounce';\n@Component({\n tag: 'dnn-searchbox',\n styleUrl: 'dnn-searchbox.scss',\n shadow: true\n})\nexport class DnnSearchbox {\n\n /**\n * Sets the field placeholder text.\n */\n @Prop() placeholder?: string = \"\";\n\n /**\n * Debounces the queryChanged by 500ms.\n */\n @Prop() debounced: boolean = true;\n\n /** Sets the query */\n @Prop({mutable: true}) query: string = \"\";\n\n /**\n * Fires up each time the search query changes.\n * The data passed is the new query.\n */\n @Event() queryChanged: EventEmitter<string>;\n\n @Watch('query')\n fireQueryChanged(){\n if (this.debounced){\n this.debouncedHandleQueryChanged();\n }\n else{\n this.handleQueryChanged();\n }\n }\n \n private handleQueryChanged(){\n this.queryChanged.emit(this.query);\n }\n\n @Debounce(500)\n private debouncedHandleQueryChanged(){\n this.handleQueryChanged();\n }\n\n render() {\n return (\n <Host>\n <input type=\"text\" value={this.query}\n placeholder={this.placeholder}\n onInput={e => this.query = (e.target as HTMLInputElement).value}\n />\n {this.query !== \"\" ?\n <button class=\"svg clear\"\n onClick={() => this.query = \"\"}\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 0 24 24\" width=\"24px\" fill=\"#000000\"><path d=\"M0 0h24v24H0z\" fill=\"none\"/><path d=\"M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12 17 15.59z\"/></svg>\n </button>\n :\n <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 0 24 24\" width=\"24px\" fill=\"#000000\"><path d=\"M0 0h24v24H0z\" fill=\"none\"/><path d=\"M15.5 14h-.79l-.28-.27C15.41 12.59 16 11.11 16 9.5 16 5.91 13.09 3 9.5 3S3 5.91 3 9.5 5.91 16 9.5 16c1.61 0 3.09-.59 4.23-1.57l.27.28v.79l5 4.99L20.49 19l-4.99-5zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z\"/></svg>\n }\n </Host>\n );\n }\n\n}\n"],"version":3}
@@ -1,39 +0,0 @@
1
- import { r as registerInstance, e as createEvent, h, f as Host } from './index-20e42ad7.js';
2
-
3
- const dnnSortIconCss = ":host{--color:#888;--color-sorted:var(--dnn-color-primary, rgb(2,139,255));--color-hover:var(--dnn-color-primary-light, #36a1ff);display:inline-block}button{outline:none;border:none;margin:0;padding:0;background-color:transparent;outline:none;display:inline-block;line-height:1em;position:relative;top:0.25em}button svg{height:1.5em;width:auto;fill:var(--color)}button.active svg{fill:var(--color-sorted)}button:hover svg,button:focus svg{fill:var(--color-hover)}";
4
-
5
- const DnnSortIcon = class {
6
- constructor(hostRef) {
7
- registerInstance(this, hostRef);
8
- this.sortChanged = createEvent(this, "sortChanged", 7);
9
- /** Defines the current sort direction */
10
- this.sortDirection = "none";
11
- }
12
- changeSort() {
13
- switch (this.sortDirection) {
14
- case "asc":
15
- this.sortDirection = "desc";
16
- break;
17
- case "desc":
18
- this.sortDirection = "asc";
19
- break;
20
- case "none":
21
- this.sortDirection = "asc";
22
- break;
23
- default:
24
- break;
25
- }
26
- this.sortChanged.emit(this.sortDirection);
27
- }
28
- render() {
29
- return (h(Host, null, h("button", { class: { "active": this.sortDirection != "none" }, onClick: () => this.changeSort() }, this.sortDirection == "none" &&
30
- h("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 12 16" }, h("path", { d: "M 0 7 H 12 L 6 0 Z M 0 9 H 12 L 6 16 Z" })), this.sortDirection == "asc" &&
31
- h("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 12 16" }, h("path", { d: "M 0 7 H 12 L 6 0 Z" })), this.sortDirection == "desc" &&
32
- h("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 12 16" }, h("path", { d: "M 0 9 H 12 L 6 16 Z" })))));
33
- }
34
- };
35
- DnnSortIcon.style = dnnSortIconCss;
36
-
37
- export { DnnSortIcon as dnn_sort_icon };
38
-
39
- //# sourceMappingURL=dnn-sort-icon.entry.js.map
@@ -1 +0,0 @@
1
- {"file":"dnn-sort-icon.entry.js","mappings":";;AAAA,MAAM,cAAc,GAAG,idAAid;;MCO3d,WAAW;EALxB;;;;IAOU,kBAAa,GAA4B,MAAM,CAAC;GA2CzD;EAtCS,UAAU;IAChB,QAAQ,IAAI,CAAC,aAAa;MACxB,KAAK,KAAK;QACR,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC;QAC5B,MAAM;MACR,KAAK,MAAM;QACT,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,MAAM;MACR,KAAK,MAAM;QACT,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,MAAM;MACR;QACE,MAAM;KACT;IAED,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;GAC3C;EAED,MAAM;IACJ,QACE,EAAC,IAAI,QACH,cACE,KAAK,EAAE,EAAC,QAAQ,EAAE,IAAI,CAAC,aAAa,IAAI,MAAM,EAAC,EAC/C,OAAO,EAAE,MAAM,IAAI,CAAC,UAAU,EAAE,IAE/B,IAAI,CAAC,aAAa,IAAI,MAAM;MAC3B,WAAK,KAAK,EAAC,4BAA4B,EAAC,OAAO,EAAC,WAAW,IAAC,YAAM,CAAC,EAAC,wCAAwC,GAAQ,CAAM,EAE3H,IAAI,CAAC,aAAa,IAAI,KAAK;MAC1B,WAAK,KAAK,EAAC,4BAA4B,EAAC,OAAO,EAAC,WAAW,IAAC,YAAM,CAAC,EAAC,oBAAoB,GAAQ,CAAM,EAEvG,IAAI,CAAC,aAAa,IAAI,MAAM;MAC3B,WAAK,KAAK,EAAC,4BAA4B,EAAC,OAAO,EAAC,WAAW,IAAC,YAAM,CAAC,EAAC,qBAAqB,GAAQ,CAAM,CAElG,CACJ,EACP;GACH;;;;;;","names":[],"sources":["./src/components/dnn-sort-icon/dnn-sort-icon.scss?tag=dnn-sort-icon&encapsulation=shadow","./src/components/dnn-sort-icon/dnn-sort-icon.tsx"],"sourcesContent":[":host {\n /**\n * @prop --color: Normal Color of the inactive sort icon.\n * @prop --color-sorted: Color of the sorted sort icon.\n * @prop --color-hover: Color of the icons when hovered.\n */\n --color: #888;\n --color-sorted: var(--dnn-color-primary, rgb(2,139,255));\n --color-hover: var(--dnn-color-primary-light, #36a1ff);\n \n display: inline-block;\n}\n\nbutton {\n outline: none;\n border: none;\n margin: 0;\n padding: 0;\n background-color: transparent;\n outline: none;\n display: inline-block;\n line-height: 1em;\n position: relative;\n top: 0.25em;\n svg{\n height: 1.5em;\n width: auto;\n fill: var(--color);\n }\n &.active{\n svg{\n fill: var(--color-sorted);\n }\n }\n &:hover, &:focus{\n svg{\n fill: var(--color-hover);\n }\n }\n}","import { Component, Host, h, Prop, Event, EventEmitter } from '@stencil/core';\n\n@Component({\n tag: 'dnn-sort-icon',\n styleUrl: 'dnn-sort-icon.scss',\n shadow: true\n})\nexport class DnnSortIcon {\n /** Defines the current sort direction */\n @Prop() sortDirection: \"asc\" | \"desc\" | \"none\" = \"none\";\n\n /** Emitted when the sort is changed. */\n @Event() sortChanged!: EventEmitter<\"asc\"|\"desc\"|\"none\">;\n \n private changeSort(): void {\n switch (this.sortDirection) {\n case \"asc\":\n this.sortDirection = \"desc\";\n break;\n case \"desc\":\n this.sortDirection = \"asc\";\n break;\n case \"none\":\n this.sortDirection = \"asc\";\n break;\n default:\n break;\n }\n\n this.sortChanged.emit(this.sortDirection);\n }\n\n render() {\n return (\n <Host>\n <button\n class={{\"active\": this.sortDirection != \"none\"}}\n onClick={() => this.changeSort()}\n >\n {this.sortDirection == \"none\" &&\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 16\"><path d=\"M 0 7 H 12 L 6 0 Z M 0 9 H 12 L 6 16 Z\"></path></svg>\n }\n {this.sortDirection == \"asc\" &&\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 16\"><path d=\"M 0 7 H 12 L 6 0 Z\"></path></svg>\n }\n {this.sortDirection == \"desc\" &&\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 12 16\"><path d=\"M 0 9 H 12 L 6 16 Z\"></path></svg>\n }\n </button>\n </Host>\n );\n }\n}\n"],"version":3}
@@ -1,27 +0,0 @@
1
- import { r as registerInstance, h, f as Host } from './index-20e42ad7.js';
2
-
3
- const dnnTabCss = "";
4
-
5
- const DnnTab = class {
6
- constructor(hostRef) {
7
- registerInstance(this, hostRef);
8
- this.visible = false;
9
- }
10
- /** Shows the tab. */
11
- async show() {
12
- this.visible = true;
13
- }
14
- /** Hides the modal */
15
- async hide() {
16
- this.visible = false;
17
- }
18
- render() {
19
- return (h(Host, null, this.visible &&
20
- h("slot", null)));
21
- }
22
- };
23
- DnnTab.style = dnnTabCss;
24
-
25
- export { DnnTab as dnn_tab };
26
-
27
- //# sourceMappingURL=dnn-tab.entry.js.map
@@ -1 +0,0 @@
1
- {"file":"dnn-tab.entry.js","mappings":";;AAAA,MAAM,SAAS,GAAG,EAAE;;MCQP,MAAM;EALnB;;IASa,YAAO,GAAY,KAAK,CAAC;GAuBrC;;EAnBG,MAAM,IAAI;IACN,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;GACvB;;EAID,MAAM,IAAI;IACN,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;GACxB;EAED,MAAM;IACF,QACI,EAAC,IAAI,QACA,IAAI,CAAC,OAAO;MACT,eAAa,CAEd,EACT;GACL;;;;;;","names":[],"sources":["./src/components/dnn-tab/dnn-tab.scss?tag=dnn-tab&encapsulation=shadow","./src/components/dnn-tab/dnn-tab.tsx"],"sourcesContent":["","import { Component, Host, h, Prop, State, Method } from \"@stencil/core\";\r\n\r\n/** Represents a single tab and must be used inside a dnn-tabs element. */\r\n@Component({\r\n tag: 'dnn-tab',\r\n styleUrl: 'dnn-tab.scss',\r\n shadow: true,\r\n})\r\nexport class DnnTab {\r\n /** Defines the tab title. */\r\n @Prop() tabTitle!: string;\r\n\r\n @State() visible: boolean = false;\r\n\r\n /** Shows the tab. */\r\n @Method()\r\n async show(){\r\n this.visible = true;\r\n }\r\n\r\n /** Hides the modal */\r\n @Method()\r\n async hide(){\r\n this.visible = false;\r\n }\r\n\r\n render() {\r\n return (\r\n <Host>\r\n {this.visible &&\r\n <slot></slot>\r\n }\r\n </Host>\r\n );\r\n }\r\n}"],"version":3}
@@ -1,48 +0,0 @@
1
- import { r as registerInstance, h, f as Host } from './index-20e42ad7.js';
2
-
3
- const dnnTabsCss = ":host{display:block;--color-background:var(--dnn-color-secondary-dark, lightgray);--color-text:var(--dnn-color-secondary-contrast, #333);--color-visible:var(--dnn-color-primary, #3792ED);--color-visible-text:var(--dnn-color-primary-contrast, #FFF);--color-focus:var(--dnn-color-primary, #3792ed)}.tabTitles{display:-ms-flexbox;display:flex;background-color:var(--color-background);color:var(--color-text)}.tabTitles button{padding:0.5rem 1rem;border:0;margin:0;background-color:transparent}.tabTitles button.visible{background-color:var(--color-visible);color:var(--color-bisible-text)}.tabTitles button:focus,.tabTitles button:hover{outline:none;-webkit-box-shadow:0 0 2px 2px var(--color-focus);box-shadow:0 0 2px 2px var(--color-focus)}.currentTab{border:1px solid var(--color-background);padding:1rem}";
4
-
5
- const DnnTabs = class {
6
- constructor(hostRef) {
7
- registerInstance(this, hostRef);
8
- this.tabTitles = [];
9
- this.selectedTabTitle = "";
10
- }
11
- componentDidLoad() {
12
- requestAnimationFrame(() => {
13
- this.updateTitles();
14
- this.showFirstTab();
15
- });
16
- }
17
- getTabs() {
18
- return this.component.shadowRoot.querySelector("slot").assignedElements();
19
- }
20
- updateTitles() {
21
- const tabs = this.getTabs();
22
- tabs.forEach(tab => this.tabTitles = [...this.tabTitles, tab.tabTitle]);
23
- }
24
- showFirstTab() {
25
- const tab = this.getTabs()[0];
26
- tab.show();
27
- this.selectedTabTitle = tab.tabTitle;
28
- }
29
- showTab(tabTitle) {
30
- const tabs = this.getTabs();
31
- tabs.forEach(tab => {
32
- if (tab.tabTitle == tabTitle) {
33
- tab.show();
34
- return;
35
- }
36
- tab.hide();
37
- });
38
- this.selectedTabTitle = tabTitle;
39
- }
40
- render() {
41
- return (h(Host, { ref: el => this.component = el }, h("div", { class: "tabTitles" }, this.tabTitles.map(tabTitle => h("button", { class: this.selectedTabTitle == tabTitle ? "visible" : "", onClick: () => this.showTab(tabTitle) }, tabTitle))), h("div", { class: "currentTab" }, h("slot", null))));
42
- }
43
- };
44
- DnnTabs.style = dnnTabsCss;
45
-
46
- export { DnnTabs as dnn_tabs };
47
-
48
- //# sourceMappingURL=dnn-tabs.entry.js.map
@@ -1 +0,0 @@
1
- {"file":"dnn-tabs.entry.js","mappings":";;AAAA,MAAM,UAAU,GAAG,uyBAAuyB;;MCO7yB,OAAO;EALpB;;IAQa,cAAS,GAAa,EAAE,CAAC;IACzB,qBAAgB,GAAW,EAAE,CAAC;GAwD1C;EAtDG,gBAAgB;IACZ,qBAAqB,CAAC;MAClB,IAAI,CAAC,YAAY,EAAE,CAAC;MACpB,IAAI,CAAC,YAAY,EAAE,CAAC;KACvB,CAAC,CAAC;GACN;EAEO,OAAO;IACX,OAAO,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,gBAAgB,EAAyB,CAAC;GACpG;EAEO,YAAY;IAChB,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;IAC5B,IAAI,CAAC,OAAO,CAAC,GAAG,IAAI,IAAI,CAAC,SAAS,GAAG,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC;GAC3E;EAEO,YAAY;IAChB,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC;IAC9B,GAAG,CAAC,IAAI,EAAE,CAAC;IACX,IAAI,CAAC,gBAAgB,GAAG,GAAG,CAAC,QAAQ,CAAC;GACxC;EAEO,OAAO,CAAC,QAAgB;IAC5B,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;IAC5B,IAAI,CAAC,OAAO,CAAC,GAAG;MACZ,IAAI,GAAG,CAAC,QAAQ,IAAI,QAAQ,EAAC;QACzB,GAAG,CAAC,IAAI,EAAE,CAAC;QACX,OAAO;OACV;MAED,GAAG,CAAC,IAAI,EAAE,CAAC;KACd,CAAC,CAAC;IACH,IAAI,CAAC,gBAAgB,GAAG,QAAQ,CAAC;GACpC;EAED,MAAM;IACF,QACI,EAAC,IAAI,IAAC,GAAG,EAAE,EAAE,IAAI,IAAI,CAAC,SAAS,GAAG,EAAE,IAChC,WAAK,KAAK,EAAC,WAAW,IACjB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,IACxB,cACI,KAAK,EAAE,IAAI,CAAC,gBAAgB,IAAI,QAAQ,GAAG,SAAS,GAAE,EAAE,EACxD,OAAO,EAAE,MAAM,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,IAEpC,QAAQ,CACJ,CACZ,CACC,EACN,WAAK,KAAK,EAAC,YAAY,IACnB,eAAa,CACX,CACH,EACT;GACL;;;;;;","names":[],"sources":["./src/components/dnn-tabs/dnn-tabs.scss?tag=dnn-tabs&encapsulation=shadow","./src/components/dnn-tabs/dnn-tabs.tsx"],"sourcesContent":[":host {\r\n /**\r\n * @prop --color-background: The color of the inactive tabs.\r\n * @prop --color-text: The color of the text for inactive tabs.\r\n * @prop --color-visible: The color of the active tab.\r\n * @prop --color-visible-text: The color of the text for the active tab.\r\n * @prop --color-focus: outline color when hovering or pre-selecting a tab.\r\n */\r\n display: block;\r\n --color-background: var(--dnn-color-secondary-dark, lightgray);\r\n --color-text: var(--dnn-color-secondary-contrast, #333);\r\n --color-visible: var(--dnn-color-primary, #3792ED);\r\n --color-visible-text: var(--dnn-color-primary-contrast, #FFF);\r\n --color-focus: var(--dnn-color-primary, #3792ed);\r\n }\r\n\r\n .tabTitles{\r\n display: flex;\r\n background-color: var(--color-background);\r\n color: var(--color-text);\r\n button{\r\n padding: 0.5rem 1rem;\r\n border: 0;\r\n margin: 0;\r\n background-color: transparent;\r\n &.visible{\r\n background-color: var(--color-visible);\r\n color: var(--color-bisible-text);\r\n }\r\n &:focus, &:hover{\r\n outline: none;\r\n box-shadow: 0 0 2px 2px var(--color-focus);\r\n }\r\n }\r\n }\r\n\r\n .currentTab{\r\n border: 1px solid var(--color-background);\r\n padding: 1rem;\r\n }","import { Component, Host, h, State } from \"@stencil/core\";\r\n\r\n@Component({\r\n tag: 'dnn-tabs',\r\n styleUrl: 'dnn-tabs.scss',\r\n shadow: true,\r\n})\r\nexport class DnnTabs {\r\n private component: HTMLElement;\r\n\r\n @State() tabTitles: string[] = [];\r\n @State() selectedTabTitle: string = \"\";\r\n\r\n componentDidLoad(){\r\n requestAnimationFrame(() => {\r\n this.updateTitles();\r\n this.showFirstTab();\r\n });\r\n }\r\n\r\n private getTabs() {\r\n return this.component.shadowRoot.querySelector(\"slot\").assignedElements() as HTMLDnnTabElement[];\r\n }\r\n\r\n private updateTitles(){\r\n const tabs = this.getTabs();\r\n tabs.forEach(tab => this.tabTitles = [...this.tabTitles, tab.tabTitle]);\r\n }\r\n\r\n private showFirstTab(){\r\n const tab = this.getTabs()[0];\r\n tab.show();\r\n this.selectedTabTitle = tab.tabTitle;\r\n }\r\n\r\n private showTab(tabTitle: string) {\r\n const tabs = this.getTabs();\r\n tabs.forEach(tab => {\r\n if (tab.tabTitle == tabTitle){\r\n tab.show();\r\n return;\r\n }\r\n\r\n tab.hide();\r\n });\r\n this.selectedTabTitle = tabTitle;\r\n }\r\n\r\n render() {\r\n return (\r\n <Host ref={el => this.component = el}>\r\n <div class=\"tabTitles\">\r\n {this.tabTitles.map(tabTitle =>\r\n <button\r\n class={this.selectedTabTitle == tabTitle ? \"visible\": \"\"}\r\n onClick={() => this.showTab(tabTitle)}\r\n >\r\n {tabTitle}\r\n </button>\r\n )}\r\n </div>\r\n <div class=\"currentTab\">\r\n <slot></slot>\r\n </div>\r\n </Host>\r\n );\r\n }\r\n}"],"version":3}
@@ -1,33 +0,0 @@
1
- import { r as registerInstance, e as createEvent, h, f as Host, g as getElement } from './index-20e42ad7.js';
2
-
3
- const dnnToggleCss = ":host{display:inline-block;outline:none;cursor:pointer}button{height:1.5em;width:2.5em;outline:none;background-color:var(--background, #888);border:0;border-radius:var(--border-radius, var(--dnn-controls-radius, 0.75em));padding:0.1em;position:relative;margin:0;-webkit-transition:background-color 300ms ease-in-out;transition:background-color 300ms ease-in-out;position:relative;cursor:pointer}button:hover,button:focus{-webkit-box-shadow:0 0 2px 2px var(--dnn-color-primary);box-shadow:0 0 2px 2px var(--dnn-color-primary)}button.checked{background-color:var(--background-checked, var(--dnn-color-primary, blue))}button.checked .handle{left:calc(1em + 4px)}button:disabled{opacity:0.5;cursor:not-allowed;-webkit-box-shadow:none;box-shadow:none}button .handle{-webkit-transition:all 300ms ease-in-out;transition:all 300ms ease-in-out;background-color:white;width:1em;height:1em;border-radius:var(--handle-border-radius, var(--dnn-controls-radius, 50%));position:absolute;top:calc(50% - 0.5em);left:2px}";
4
-
5
- const DnnToggle = class {
6
- constructor(hostRef) {
7
- registerInstance(this, hostRef);
8
- this.checkChanged = createEvent(this, "checkChanged", 7);
9
- /** If 'true' the toggle is checked (on). */
10
- this.checked = false;
11
- /** If 'true' the toggle is not be interacted with. */
12
- this.disabled = false;
13
- }
14
- checkedChanged(isChecked) {
15
- this.checkChanged.emit({ checked: isChecked });
16
- }
17
- render() {
18
- return (h(Host, null, h("button", { disabled: this.disabled, class: { 'checked': this.checked }, onClick: () => {
19
- if (!this.disabled) {
20
- this.checked = !this.checked;
21
- }
22
- } }, h("div", { class: "handle" }))));
23
- }
24
- get element() { return getElement(this); }
25
- static get watchers() { return {
26
- "checked": ["checkedChanged"]
27
- }; }
28
- };
29
- DnnToggle.style = dnnToggleCss;
30
-
31
- export { DnnToggle as dnn_toggle };
32
-
33
- //# sourceMappingURL=dnn-toggle.entry.js.map
@@ -1 +0,0 @@
1
- {"file":"dnn-toggle.entry.js","mappings":";;AAAA,MAAM,YAAY,GAAG,6+BAA6+B;;MCSr/B,SAAS;EALtB;;;;IAU2B,YAAO,GAAG,KAAK,CAAC;;IAG/B,aAAQ,GAAG,KAAK,CAAC;GAyB5B;EAnBG,cAAc,CAAC,SAAkB;IAC7B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,SAAS,EAAC,CAAC,CAAC;GAChD;EAED,MAAM;IACF,QACI,EAAC,IAAI,QACD,cAAQ,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAC,SAAS,EAAE,IAAI,CAAC,OAAO,EAAC,EAC7D,OAAO,EAAE;QACL,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;UAChB,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC;SAChC;OACJ,IAED,WAAK,KAAK,EAAC,QAAQ,GAAO,CACrB,CACN,EACT;GACL;;;;;;;;;;","names":[],"sources":["./src/components/dnn-toggle/dnn-toggle.scss?tag=dnn-toggle&encapsulation=shadow","./src/components/dnn-toggle/dnn-toggle.tsx"],"sourcesContent":[":host {\n /**\n * @prop --background: Background of the toggle.\n * @prop --background-checked: Background of the toggle when checked.\n * @prop --handle-background: Background of the handle.\n * @prop --handle-background-checked: Background of the handle when checked.\n * @prop --border-radius: The radius of the background borders.\n * @prop --handle-border-radius: The radius of the handle.\n */\n\n display: inline-block;\n outline: none;\n cursor: pointer;\n}\n\nbutton {\n height: 1.5em;\n width: 2.5em;\n outline: none;\n background-color: var(--background, #888);\n border: 0;\n border-radius: var(--border-radius, var(--dnn-controls-radius, 0.75em));\n padding: 0.1em;\n position: relative;\n margin: 0;\n transition: background-color 300ms ease-in-out;\n position: relative;\n cursor: pointer;\n &:hover, &:focus{\n box-shadow: 0 0 2px 2px var(--dnn-color-primary);\n }\n &.checked{\n background-color: var(--background-checked, var(--dnn-color-primary, blue));\n .handle{\n left: calc(1em + 4px);\n }\n }\n &:disabled{\n opacity: 0.5;\n cursor: not-allowed;\n box-shadow: none;\n }\n .handle{\n transition: all 300ms ease-in-out;\n background-color:white;\n width: 1em;\n height: 1em;\n border-radius: var(--handle-border-radius, var(--dnn-controls-radius, 50%));\n position: absolute;\n top: calc(50% - 0.5em);\n left: 2px;\n }\n}","import { Component, h, Element, Prop, Event, EventEmitter, Watch, Host } from \"@stencil/core\";\nimport { DnnToggleChangeEventDetail } from \"./toggle-interface\";\n\n\n@Component({\n tag: \"dnn-toggle\",\n styleUrl: \"dnn-toggle.scss\",\n shadow: true\n})\nexport class DnnToggle {\n\n @Element() element: HTMLDnnToggleElement;\n\n /** If 'true' the toggle is checked (on). */\n @Prop({mutable: true}) checked = false;\n\n /** If 'true' the toggle is not be interacted with. */\n @Prop() disabled = false;\n\n /** Fires when the toggle changed */\n @Event() checkChanged!: EventEmitter<DnnToggleChangeEventDetail>;\n\n @Watch(\"checked\")\n checkedChanged(isChecked: boolean){\n this.checkChanged.emit({checked: isChecked});\n }\n\n render() {\n return (\n <Host>\n <button disabled={this.disabled} class={{'checked': this.checked}}\n onClick={() => {\n if (!this.disabled) {\n this.checked = !this.checked;\n }\n }}\n >\n <div class=\"handle\"></div>\n </button>\n </Host>\n );\n }\n}\n"],"version":3}
@@ -1,64 +0,0 @@
1
- import { r as registerInstance, e as createEvent, h, f as Host, g as getElement } from './index-20e42ad7.js';
2
-
3
- const dnnTreeviewItemCss = ":host{display:-ms-flexbox;display:flex;overflow:visible}.expander{width:24px;height:24px}.expander button{-webkit-transition:all 150ms ease-in-out;transition:all 150ms ease-in-out;background-color:transparent;border:none;padding:0;margin:0;height:1em;display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center;-ms-flex-align:center;align-items:center;cursor:pointer;position:relative;top:2px}.expander button svg :first-child{-webkit-transition:all 150ms ease-in-out;transition:all 150ms ease-in-out;fill:white;stroke:black}.expander.expanded button{-webkit-transform:rotate(45deg);transform:rotate(45deg)}.expander.expanded button svg :first-child{fill:black;stroke:black}div.item .item-slot{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;gap:0.25em;min-height:24px}div.item div.children{overflow:hidden;height:0;-webkit-transition:all 150ms ease-in-out;transition:all 150ms ease-in-out}";
4
-
5
- const DnnTreeviewItem = class {
6
- constructor(hostRef) {
7
- registerInstance(this, hostRef);
8
- this.userExpanded = createEvent(this, "userExpanded", 3);
9
- this.userCollapsed = createEvent(this, "userCollapsed", 3);
10
- /** Defines if the current node is expanded. */
11
- this.expanded = false;
12
- /** Manages state for whether or not item has children. */
13
- this.hasChildren = false;
14
- }
15
- /** Watch expanded Prop */
16
- watchExpanded(expanded) {
17
- if (expanded) {
18
- this.expander.classList.add("expanded");
19
- this.collapsible.expanded = true;
20
- return;
21
- }
22
- this.expander.classList.remove("expanded");
23
- this.collapsible.expanded = false;
24
- }
25
- componentDidLoad() {
26
- requestAnimationFrame(() => {
27
- const child = this.childElement.children[0];
28
- const count = child.assignedElements().length;
29
- if (count > 0) {
30
- this.hasChildren = true;
31
- }
32
- if (this.expanded) {
33
- this.expander.classList.add("expanded");
34
- this.collapsible.expanded = false;
35
- setTimeout(() => {
36
- this.collapsible.expanded = true;
37
- }, 300);
38
- }
39
- });
40
- }
41
- toggleCollapse() {
42
- this.expanded = !this.expanded;
43
- if (this.expanded) {
44
- this.expander.classList.add("expanded");
45
- this.userExpanded.emit();
46
- return;
47
- }
48
- this.expander.classList.remove("expanded");
49
- this.userCollapsed.emit();
50
- }
51
- render() {
52
- return (h(Host, null, h("div", { class: "expander", ref: el => this.expander = el }, this.hasChildren &&
53
- h("button", { onClick: () => this.toggleCollapse() }, h("svg", { xmlns: "http://www.w3.org/2000/svg", height: "24px", viewBox: "0 0 24 24", width: "24px", fill: "#000000" }, h("path", { d: "M10 17l5-5-5-5v10z" }), h("path", { d: "M0 24V0h24v24H0z", fill: "none" })))), h("div", { class: "item" }, h("div", { class: "item-slot" }, h("slot", null)), h("dnn-collapsible", { ref: el => this.collapsible = el, expanded: this.expanded }, h("div", { ref: el => this.childElement = el }, h("slot", { name: "children" }))))));
54
- }
55
- get el() { return getElement(this); }
56
- static get watchers() { return {
57
- "expanded": ["watchExpanded"]
58
- }; }
59
- };
60
- DnnTreeviewItem.style = dnnTreeviewItemCss;
61
-
62
- export { DnnTreeviewItem as dnn_treeview_item };
63
-
64
- //# sourceMappingURL=dnn-treeview-item.entry.js.map
@@ -1 +0,0 @@
1
- {"file":"dnn-treeview-item.entry.js","mappings":";;AAAA,MAAM,kBAAkB,GAAG,u6BAAu6B;;MCWr7B,eAAe;EAL5B;;;;;IAYwC,aAAQ,GAAY,KAAK,CAAC;;IASvD,gBAAW,GAAY,KAAK,CAAC;GAyEvC;;EArEC,aAAa,CAAC,QAAiB;IAC7B,IAAI,QAAQ,EAAE;MACZ,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;MACxC,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,IAAI,CAAC;MACjC,OAAO;KACR;IAED,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IAC3C,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,KAAK,CAAC;GACnC;EAMD,gBAAgB;IACd,qBAAqB,CAAC;MACpB,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAoB,CAAC;MAC/D,MAAM,KAAK,GAAG,KAAK,CAAC,gBAAgB,EAAE,CAAC,MAAM,CAAA;MAC7C,IAAI,KAAK,GAAG,CAAC,EAAC;QACZ,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;OACzB;MACD,IAAI,IAAI,CAAC,QAAQ,EAAC;QAChB,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACxC,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,KAAK,CAAC;QAClC,UAAU,CAAC;UACT,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,IAAI,CAAC;SAClC,EAAE,GAAG,CAAC,CAAC;OACT;KACF,CAAC,CAAC;GACJ;EAEO,cAAc;IACpB,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC;IAC/B,IAAI,IAAI,CAAC,QAAQ,EAAC;MAChB,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;MACxC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;MACzB,OAAO;KACR;IAED,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IAC3C,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;GAC3B;EAED,MAAM;IACJ,QACE,EAAC,IAAI,QACH,WAAK,KAAK,EAAC,UAAU,EAAC,GAAG,EAAE,EAAE,IAAI,IAAI,CAAC,QAAQ,GAAG,EAAE,IAChD,IAAI,CAAC,WAAW;MACf,cACE,OAAO,EAAE,MAAM,IAAI,CAAC,cAAc,EAAE,IAEpC,WAAK,KAAK,EAAC,4BAA4B,EAAC,MAAM,EAAC,MAAM,EAAC,OAAO,EAAC,WAAW,EAAC,KAAK,EAAC,MAAM,EAAC,IAAI,EAAC,SAAS,IAAC,YAAM,CAAC,EAAC,oBAAoB,GAAE,EAAA,YAAM,CAAC,EAAC,kBAAkB,EAAC,IAAI,EAAC,MAAM,GAAE,CAAM,CAC3K,CAEP,EACN,WAAK,KAAK,EAAC,MAAM,IACf,WAAK,KAAK,EAAC,WAAW,IACpB,eAAa,CACT,EACN,uBAAiB,GAAG,EAAE,EAAE,IAAI,IAAI,CAAC,WAAW,GAAG,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,IACxE,WAAK,GAAG,EAAE,EAAE,IAAI,IAAI,CAAC,YAAY,GAAG,EAAE,IACpC,YAAM,IAAI,EAAC,UAAU,GAAQ,CACzB,CACU,CACZ,CACH,EACP;GACH;;;;;;;;;;","names":[],"sources":["./src/components/dnn-treeview-item/dnn-treeview-item.scss?tag=dnn-treeview-item&encapsulation=shadow","./src/components/dnn-treeview-item/dnn-treeview-item.tsx"],"sourcesContent":[":host {\n display: flex;\n overflow: visible;\n}\n.expander{\n width: 24px;\n height: 24px;\n button{\n transition: all 150ms ease-in-out;\n background-color:transparent;\n border: none;\n padding: 0;\n margin: 0;\n height: 1em;\n display: flex;\n justify-content: center;\n align-items: center;\n cursor: pointer;\n position: relative;\n top: 2px;\n svg{\n :first-child{\n transition: all 150ms ease-in-out;\n fill: white;\n stroke: black\n }\n }\n }\n &.expanded{\n button{\n transform: rotate(45deg);\n svg{\n :first-child{\n fill: black;\n stroke: black;\n }\n }\n }\n }\n}\ndiv.item{\n .item-slot{\n display: flex;\n align-items: center;\n gap: 0.25em;\n min-height: 24px;\n }\n div.children{\n overflow: hidden;\n height:0;\n transition: all 150ms ease-in-out;\n }\n}","import { Component, Host, h, Prop, State, Element, Event, EventEmitter, Watch } from '@stencil/core';\n\n/** \n * @slot - The content of this node.\n * @slot children - The content nested under this node.\n*/\n@Component({\n tag: 'dnn-treeview-item',\n styleUrl: 'dnn-treeview-item.scss',\n shadow: true,\n})\nexport class DnnTreeviewItem {\n \n private expander!: HTMLDivElement;\n\n @Element() el!: HTMLDnnTreeviewItemElement;\n \n /** Defines if the current node is expanded. */\n @Prop({mutable: true, reflect: true}) expanded: boolean = false;\n\n /** Fires when the user expands a node. */\n @Event({bubbles: false}) userExpanded: EventEmitter<void>;\n\n /** Fires when the user collapses a node. */\n @Event({bubbles: false}) userCollapsed: EventEmitter<void>;\n\n /** Manages state for whether or not item has children. */\n @State() hasChildren: boolean = false;\n\n /** Watch expanded Prop */\n @Watch('expanded')\n watchExpanded(expanded: boolean) {\n if (expanded) {\n this.expander.classList.add(\"expanded\");\n this.collapsible.expanded = true;\n return;\n }\n \n this.expander.classList.remove(\"expanded\");\n this.collapsible.expanded = false;\n }\n \n \n private childElement!: HTMLDivElement;\n private collapsible!: HTMLDnnCollapsibleElement;\n\n componentDidLoad() {\n requestAnimationFrame(() => {\n const child = this.childElement.children[0] as HTMLSlotElement;\n const count = child.assignedElements().length\n if (count > 0){\n this.hasChildren = true;\n }\n if (this.expanded){\n this.expander.classList.add(\"expanded\");\n this.collapsible.expanded = false;\n setTimeout(() => {\n this.collapsible.expanded = true;\n }, 300);\n }\n });\n }\n\n private toggleCollapse(): void {\n this.expanded = !this.expanded;\n if (this.expanded){\n this.expander.classList.add(\"expanded\");\n this.userExpanded.emit();\n return;\n }\n\n this.expander.classList.remove(\"expanded\");\n this.userCollapsed.emit();\n }\n\n render() {\n return (\n <Host>\n <div class=\"expander\" ref={el => this.expander = el}>\n {this.hasChildren &&\n <button\n onClick={() => this.toggleCollapse()}\n >\n <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 0 24 24\" width=\"24px\" fill=\"#000000\"><path d=\"M10 17l5-5-5-5v10z\"/><path d=\"M0 24V0h24v24H0z\" fill=\"none\"/></svg>\n </button>\n }\n </div>\n <div class=\"item\">\n <div class=\"item-slot\">\n <slot></slot>\n </div>\n <dnn-collapsible ref={el => this.collapsible = el} expanded={this.expanded}>\n <div ref={el => this.childElement = el}>\n <slot name=\"children\"></slot>\n </div>\n </dnn-collapsible>\n </div>\n </Host>\n );\n }\n}\n\nexport interface ExpandedToggledEvent{\n state: \"expanded\" | \"collapsed\";\n height: number;\n}"],"version":3}
@@ -1,120 +0,0 @@
1
- import { r as registerInstance, h, f as Host, g as getElement } from './index-20e42ad7.js';
2
-
3
- const dnnVerticalOverflowMenuCss = ":host{--background-color:var(--dnn-color-primary-contrast, white);--foreground-color:var(--dnn-color-primary, #3792ED);display:block}.menu-container{display:-ms-flexbox;display:flex;-ms-flex-pack:start;justify-content:flex-start;-ms-flex-align:center;align-items:center;background-color:var(--background-color)}.menu-container .menu{margin:0.5em;display:-ms-flexbox;display:flex;gap:1em;-ms-flex-pack:start;justify-content:flex-start;-ms-flex-align:center;align-items:center;white-space:nowrap;width:100%}.menu-container .overflow{margin-left:auto;position:relative}.menu-container .overflow button{cursor:pointer;padding:0;margin:0;background-color:transparent;border:none}.menu-container .overflow button svg{fill:var(--foreground-color)}.menu-container .overflow .dropdown{position:absolute;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;white-space:nowrap;right:0;-webkit-transition:100ms ease-in-out;transition:100ms ease-in-out;height:0;overflow:hidden}.menu-container .overflow .dropdown.visible{padding:1em;gap:0.5em;background-color:var(--background-color);-webkit-box-shadow:2px 2px 4px rgba(0, 0, 0, 0.7);box-shadow:2px 2px 4px rgba(0, 0, 0, 0.7)}";
4
-
5
- const DnnVerticalOverflowMenu = class {
6
- constructor(hostRef) {
7
- registerInstance(this, hostRef);
8
- this.showDropdownButton = false;
9
- this.showDropdownMenu = false;
10
- this.previousMenuWidth = 0;
11
- }
12
- componentDidRender() {
13
- requestAnimationFrame(() => {
14
- this.moveItemsToDropDownIfNecessery();
15
- this.resizeObserver = new ResizeObserver(entries => {
16
- for (let entry of entries) {
17
- if (entry.contentRect.width < this.previousMenuWidth) {
18
- this.moveItemsToDropDownIfNecessery();
19
- }
20
- if (this.previousMenuWidth > 0 && entry.contentRect.width > this.previousMenuWidth) {
21
- this.moveItemsToMenuIfPossible();
22
- }
23
- this.previousMenuWidth = entry.contentRect.width;
24
- }
25
- });
26
- this.resizeObserver.observe(this.element);
27
- });
28
- }
29
- moveItemsToDropDownIfNecessery() {
30
- const menuItems = Array.from(this.menu.querySelector("slot").assignedElements());
31
- const availableWidth = this.menu.getBoundingClientRect().width;
32
- let neededWidth = parseFloat(getComputedStyle(this.element).fontSize) * 2;
33
- menuItems.forEach(item => neededWidth += this.getFullWidth(item));
34
- neededWidth += (menuItems.length - 1) * parseFloat(getComputedStyle(this.element).fontSize);
35
- if (neededWidth > availableWidth) {
36
- this.showDropdownButton = true;
37
- var lastItem = menuItems[menuItems.length - 1];
38
- if (this.dropdown == undefined) {
39
- return;
40
- }
41
- lastItem.slot = "dropdown";
42
- this.moveItemsToDropDownIfNecessery();
43
- }
44
- }
45
- moveItemsToMenuIfPossible() {
46
- if (this.dropdown == undefined || !this.dropdown.hasChildNodes()) {
47
- return;
48
- }
49
- const menuItems = Array.from(this.menu.querySelector("slot").assignedElements());
50
- const availableWidth = this.menu.getBoundingClientRect().width;
51
- let neededWidth = parseFloat(getComputedStyle(this.element).fontSize) * 2;
52
- neededWidth += (menuItems.length - 1) * parseFloat(getComputedStyle(this.element).fontSize);
53
- menuItems.forEach(item => neededWidth += this.getFullWidth(item));
54
- const firstItem = this.dropdown.querySelector("slot").assignedElements()[0];
55
- if (firstItem != undefined) {
56
- neededWidth += this.getFullWidth(firstItem);
57
- }
58
- if (neededWidth < availableWidth) {
59
- if (firstItem != undefined) {
60
- firstItem.slot = "";
61
- }
62
- if (firstItem == undefined) {
63
- this.dropdown.classList.remove("visible");
64
- this.showDropdownMenu = false;
65
- this.showDropdownButton = false;
66
- }
67
- }
68
- }
69
- getFullWidth(item) {
70
- var width = item.getBoundingClientRect().width;
71
- var styles = getComputedStyle(item);
72
- width += parseFloat(styles.marginLeft);
73
- width += parseFloat(styles.marginRight);
74
- width += parseFloat(styles.paddingLeft);
75
- width += parseFloat(styles.paddingRight);
76
- return width;
77
- }
78
- toggleOverflowMenu() {
79
- this.showDropdownMenu = !this.showDropdownMenu;
80
- if (this.showDropdownMenu) {
81
- this.dropdown.classList.add("visible");
82
- let contentHeight = 0;
83
- const items = Array.from(this.dropdown.querySelector("slot").assignedElements());
84
- items.forEach(item => contentHeight += item.getBoundingClientRect().height);
85
- const emHeight = parseFloat(getComputedStyle(this.dropdown).fontSize);
86
- const gapsHeight = emHeight * (this.dropdown.children.length - 1) / 2;
87
- contentHeight += gapsHeight;
88
- const marginHeight = emHeight * 2;
89
- contentHeight += marginHeight;
90
- this.dropdown.style.height = `${contentHeight}px`;
91
- const dismissMenu = (e) => {
92
- const buttonRect = this.button.getBoundingClientRect();
93
- if (e.clientX < buttonRect.left ||
94
- e.clientX > buttonRect.right ||
95
- e.clientY < buttonRect.top ||
96
- e.clientY > buttonRect.bottom) {
97
- this.toggleOverflowMenu();
98
- }
99
- document.removeEventListener("click", dismissMenu);
100
- };
101
- setTimeout(() => {
102
- document.addEventListener("click", dismissMenu, false);
103
- }, 100);
104
- }
105
- else {
106
- this.dropdown.classList.remove("visible");
107
- this.dropdown.style.height = "0px";
108
- }
109
- }
110
- render() {
111
- return (h(Host, null, h("div", { class: "menu-container" }, h("div", { class: "menu", ref: el => this.menu = el }, h("slot", null)), this.showDropdownButton &&
112
- h("div", { class: "overflow" }, h("button", { ref: el => this.button = el, class: "icon", onClick: () => this.toggleOverflowMenu() }, h("svg", { xmlns: "http://www.w3.org/2000/svg", height: "24px", viewBox: "0 0 24 24", width: "24px", fill: "#000000" }, h("path", { d: "M0 0h24v24H0z", fill: "none" }), h("path", { d: "M12 8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm0 2c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z" }))), h("div", { class: "dropdown", ref: el => this.dropdown = el }, h("slot", { name: "dropdown" }))))));
113
- }
114
- get element() { return getElement(this); }
115
- };
116
- DnnVerticalOverflowMenu.style = dnnVerticalOverflowMenuCss;
117
-
118
- export { DnnVerticalOverflowMenu as dnn_vertical_overflow_menu };
119
-
120
- //# sourceMappingURL=dnn-vertical-overflow-menu.entry.js.map
@@ -1 +0,0 @@
1
- {"file":"dnn-vertical-overflow-menu.entry.js","mappings":"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","names":[],"sources":["./src/components/dnn-vertical-overflow-menu/dnn-vertical-overflow-menu.scss?tag=dnn-vertical-overflow-menu&encapsulation=shadow","./src/components/dnn-vertical-overflow-menu/dnn-vertical-overflow-menu.tsx"],"sourcesContent":[":host {\n /**\n * @prop --background-color: Defines the menu background color.\n * @prop --foreground-color: A color that contrasts with the background color.\n */\n --background-color: var(--dnn-color-primary-contrast, white);\n --foreground-color: var(--dnn-color-primary, #3792ED);\n\n display: block;\n}\n\n.menu-container{\n display: flex;\n justify-content: flex-start;\n align-items: center;\n background-color: var(--background-color);\n .menu{\n margin: 0.5em;\n display: flex;\n gap: 1em;\n justify-content: flex-start;\n align-items: center;\n white-space: nowrap;\n width: 100%;\n }\n .overflow {\n margin-left: auto;\n position: relative;\n button{\n cursor: pointer;\n svg{\n fill: var(--foreground-color);\n }\n padding: 0;\n margin: 0;\n background-color: transparent;\n border: none;\n }\n .dropdown{\n position:absolute;\n display: flex;\n flex-direction: column;\n white-space: nowrap;\n right: 0;\n transition: 100ms ease-in-out;\n height: 0;\n overflow: hidden;\n &.visible{\n padding: 1em;\n gap: 0.5em;\n background-color: var(--background-color);\n box-shadow: 2px 2px 4px rgba(0,0,0,0.7);\n }\n }\n }\n}\n","import { Component, Element, Host, h, State } from '@stencil/core';\n\n@Component({\n tag: 'dnn-vertical-overflow-menu',\n styleUrl: 'dnn-vertical-overflow-menu.scss',\n shadow: true,\n})\nexport class DnnVerticalOverflowMenu {\n\n @Element() element!: HTMLDnnVerticalOverflowMenuElement;\n \n @State() showDropdownButton = false;\n @State() showDropdownMenu = false;\n\n private menu!: HTMLDivElement;\n private dropdown: HTMLDivElement;\n private resizeObserver: ResizeObserver;\n private button!: HTMLButtonElement;\n private previousMenuWidth = 0;\n\n componentDidRender() {\n requestAnimationFrame(() => {\n this.moveItemsToDropDownIfNecessery();\n this.resizeObserver = new ResizeObserver(entries => {\n for (let entry of entries){\n if (entry.contentRect.width < this.previousMenuWidth){\n this.moveItemsToDropDownIfNecessery()\n }\n if (this.previousMenuWidth > 0 && entry.contentRect.width > this.previousMenuWidth){\n this.moveItemsToMenuIfPossible();\n }\n this.previousMenuWidth = entry.contentRect.width;\n }\n });\n this.resizeObserver.observe(this.element);\n });\n }\n\n private moveItemsToDropDownIfNecessery(){\n const menuItems = Array.from(this.menu.querySelector(\"slot\").assignedElements());\n const availableWidth = this.menu.getBoundingClientRect().width;\n let neededWidth = parseFloat(getComputedStyle(this.element).fontSize)*2;\n menuItems.forEach(item => neededWidth += this.getFullWidth(item));\n neededWidth += (menuItems.length - 1) * parseFloat(getComputedStyle(this.element).fontSize);\n if (neededWidth > availableWidth){\n this.showDropdownButton = true;\n var lastItem = menuItems[menuItems.length -1];\n if (this.dropdown == undefined){\n return;\n }\n lastItem.slot = \"dropdown\";\n this.moveItemsToDropDownIfNecessery();\n }\n }\n \n private moveItemsToMenuIfPossible(){\n if (this.dropdown == undefined || !this.dropdown.hasChildNodes()){\n return;\n }\n const menuItems = Array.from(this.menu.querySelector(\"slot\").assignedElements());\n const availableWidth = this.menu.getBoundingClientRect().width;\n let neededWidth = parseFloat(getComputedStyle(this.element).fontSize)*2;\n neededWidth += (menuItems.length - 1) * parseFloat(getComputedStyle(this.element).fontSize);\n menuItems.forEach(item => neededWidth += this.getFullWidth(item));\n const firstItem = this.dropdown.querySelector(\"slot\").assignedElements()[0];\n if (firstItem != undefined){\n neededWidth += this.getFullWidth(firstItem);\n }\n\n if (neededWidth < availableWidth){\n if (firstItem != undefined){\n firstItem.slot = \"\";\n }\n if(firstItem == undefined){\n this.dropdown.classList.remove(\"visible\");\n this.showDropdownMenu = false;\n this.showDropdownButton = false;\n }\n } \n }\n\n private getFullWidth(item: Element) {\n var width = item.getBoundingClientRect().width;\n var styles = getComputedStyle(item);\n width += parseFloat(styles.marginLeft);\n width += parseFloat(styles.marginRight);\n width += parseFloat(styles.paddingLeft);\n width += parseFloat(styles.paddingRight);\n return width;\n }\n\n private toggleOverflowMenu(): void {\n this.showDropdownMenu = !this.showDropdownMenu;\n if (this.showDropdownMenu){\n this.dropdown.classList.add(\"visible\");\n let contentHeight = 0;\n const items = Array.from(this.dropdown.querySelector(\"slot\").assignedElements());\n items.forEach(item => contentHeight += item.getBoundingClientRect().height);\n const emHeight = parseFloat(getComputedStyle(this.dropdown).fontSize);\n const gapsHeight = emHeight * (this.dropdown.children.length - 1) / 2;\n contentHeight += gapsHeight;\n const marginHeight = emHeight * 2;\n contentHeight += marginHeight;\n this.dropdown.style.height = `${contentHeight}px`;\n const dismissMenu = (e: MouseEvent) => {\n const buttonRect = this.button.getBoundingClientRect();\n if (\n e.clientX < buttonRect.left ||\n e.clientX > buttonRect.right ||\n e.clientY < buttonRect.top ||\n e.clientY > buttonRect.bottom){\n this.toggleOverflowMenu();\n }\n document.removeEventListener(\"click\", dismissMenu);\n };\n setTimeout(() => {\n document.addEventListener(\"click\", dismissMenu, false);\n }, 100);\n }\n else{\n this.dropdown.classList.remove(\"visible\");\n this.dropdown.style.height = \"0px\";\n }\n }\n\n render() {\n return (\n <Host>\n <div class=\"menu-container\">\n <div class=\"menu\" ref={el => this.menu = el}>\n <slot></slot>\n </div>\n {this.showDropdownButton &&\n <div class=\"overflow\">\n <button\n ref={el => this.button = el}\n class=\"icon\"\n onClick={() => this.toggleOverflowMenu()}>\n <svg xmlns=\"http://www.w3.org/2000/svg\" height=\"24px\" viewBox=\"0 0 24 24\" width=\"24px\" fill=\"#000000\"><path d=\"M0 0h24v24H0z\" fill=\"none\"/><path d=\"M12 8c1.1 0 2-.9 2-2s-.9-2-2-2-2 .9-2 2 .9 2 2 2zm0 2c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2zm0 6c-1.1 0-2 .9-2 2s.9 2 2 2 2-.9 2-2-.9-2-2-2z\"/></svg>\n </button>\n <div class=\"dropdown\" ref={el => this.dropdown = el}>\n <slot name=\"dropdown\"></slot>\n </div>\n </div>\n }\n </div>\n </Host>\n );\n }\n}\n"],"version":3}
@@ -1,129 +0,0 @@
1
- import { r as registerInstance, e as createEvent, h, f as Host, g as getElement } from './index-20e42ad7.js';
2
- import { g as getMovementFromEvent } from './mouseUtilities-b261ca4f.js';
3
-
4
- const dnnVerticalSplitviewCss = ":host{display:-ms-flexbox;display:flex;-ms-flex-align:stretch;align-items:stretch;margin:0 auto;position:relative;--left-pane-background-color:transparent;--right-pane-background-color:transparent}button{border:none;margin:0;padding:0;cursor:ew-resize;position:absolute;height:100%;background-color:transparent}button.transition{-webkit-transition:all 300ms ease-in-out;transition:all 300ms ease-in-out}.pane{overflow-y:auto}.pane.transition{-webkit-transition:all 300ms ease-in-out;transition:all 300ms ease-in-out}.pane.left{background-color:var(--left-pane-background-color)}.pane.right{background-color:var(--right-pane-background-color);-ms-flex-positive:1;flex-grow:1}";
5
-
6
- const DnnVerticalSplitview = class {
7
- constructor(hostRef) {
8
- registerInstance(this, hostRef);
9
- this.widthChanged = createEvent(this, "widthChanged", 7);
10
- /** The width of the splitter area. */
11
- this.splitterWidth = 16;
12
- /** The percentage position of the splitter in the container. */
13
- this.splitWidthPercentage = 30;
14
- this.leftWidth = 0;
15
- this.rightWidth = 0;
16
- }
17
- /** Sets the width percentage of the divider */
18
- async setSplitWidthPercentage(newWidth) {
19
- const panes = this.element.shadowRoot.querySelectorAll(".pane");
20
- requestAnimationFrame(() => {
21
- panes.forEach(pane => pane.classList.add("transition"));
22
- this.splitter.classList.add("transition");
23
- requestAnimationFrame(() => {
24
- const fullWidth = this.element.getBoundingClientRect().width;
25
- let newLeft = fullWidth * newWidth / 100;
26
- if (newLeft < 0) {
27
- newLeft = 0;
28
- }
29
- if (newLeft > fullWidth) {
30
- newLeft = fullWidth;
31
- }
32
- this.leftWidth = newLeft;
33
- this.rightWidth = fullWidth - newLeft;
34
- setTimeout(() => {
35
- panes.forEach(pane => pane.classList.remove("transition"));
36
- this.splitter.classList.remove("transition");
37
- }, 300);
38
- });
39
- });
40
- }
41
- /** Gets the current divider position percentage. */
42
- async getSplitWidthPercentage() {
43
- const fullWidth = this.element.getBoundingClientRect().width;
44
- return this.leftWidth / fullWidth;
45
- }
46
- componentDidLoad() {
47
- requestAnimationFrame(() => {
48
- this.resizeObserver = new ResizeObserver(() => {
49
- const fullWidth = this.element.getBoundingClientRect().width;
50
- this.leftWidth = fullWidth * this.splitWidthPercentage / 100;
51
- this.rightWidth = fullWidth - this.leftWidth;
52
- this.widthChanged.emit(this.splitWidthPercentage);
53
- });
54
- this.resizeObserver.observe(this.element);
55
- });
56
- }
57
- handleMouseDown(event) {
58
- event.preventDefault();
59
- const handleDrag = (ev) => {
60
- requestAnimationFrame(() => {
61
- let fullWidth = this.element.getBoundingClientRect().width;
62
- let { movementX } = getMovementFromEvent(ev, this.previousTouch);
63
- let newLeft = this.leftWidth + movementX;
64
- if (newLeft < 0) {
65
- newLeft = 0;
66
- }
67
- if (newLeft > fullWidth) {
68
- newLeft = fullWidth;
69
- }
70
- this.leftWidth = newLeft;
71
- this.rightWidth = fullWidth - newLeft;
72
- this.splitWidthPercentage = this.leftWidth / fullWidth * 100;
73
- });
74
- };
75
- const handleDragFinished = () => {
76
- document.removeEventListener("mousemove", handleDrag);
77
- document.removeEventListener("touchmove", handleDrag);
78
- const fullWidth = this.element.getBoundingClientRect().width;
79
- const newPercentage = this.leftWidth / fullWidth * 100;
80
- this.widthChanged.emit(newPercentage);
81
- };
82
- document.addEventListener("mouseup", handleDragFinished);
83
- document.addEventListener("touchend", handleDragFinished);
84
- document.addEventListener("mousemove", handleDrag);
85
- document.addEventListener("touchmove", handleDrag);
86
- }
87
- handleKeyDown(e) {
88
- let movementX = 0;
89
- switch (e.key) {
90
- case "ArrowLeft":
91
- movementX = -10;
92
- break;
93
- case "ArrowRight":
94
- movementX = 10;
95
- break;
96
- default:
97
- return;
98
- }
99
- if (e.shiftKey) {
100
- movementX = movementX * 10;
101
- }
102
- const fullWidth = this.element.getBoundingClientRect().width;
103
- let newLeft = this.leftWidth + movementX;
104
- if (newLeft < 0) {
105
- newLeft = 0;
106
- }
107
- if (newLeft > fullWidth) {
108
- newLeft = fullWidth;
109
- }
110
- this.leftWidth = newLeft;
111
- this.rightWidth = fullWidth - this.leftWidth;
112
- }
113
- render() {
114
- return (h(Host, null, h("div", { class: "left pane", style: {
115
- width: `${this.leftWidth}px`,
116
- } }, h("slot", { name: "left" })), h("button", { onMouseDown: e => this.handleMouseDown(e), onTouchStart: e => this.handleMouseDown(e), onKeyDown: e => this.handleKeyDown(e), ref: el => this.splitter = el, style: {
117
- minWidth: `${this.splitterWidth.toString()}px`,
118
- left: `${this.leftWidth - 2}px`,
119
- } }, h("slot", null)), h("div", { class: "right pane", style: {
120
- width: `${this.rightWidth}px`,
121
- } }, h("slot", { name: "right" }))));
122
- }
123
- get element() { return getElement(this); }
124
- };
125
- DnnVerticalSplitview.style = dnnVerticalSplitviewCss;
126
-
127
- export { DnnVerticalSplitview as dnn_vertical_splitview };
128
-
129
- //# sourceMappingURL=dnn-vertical-splitview.entry.js.map