@aurelia-ui-toolkits/headless 1.0.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 (284) hide show
  1. package/dist/alert/ui-alert.html +19 -0
  2. package/dist/alert/ui-alert.js +67 -0
  3. package/dist/alert/ui-alert.js.map +1 -0
  4. package/dist/alert-service/alert-configuration.js +11 -0
  5. package/dist/alert-service/alert-configuration.js.map +1 -0
  6. package/dist/alert-service/alert-modal/alert-modal.html +12 -0
  7. package/dist/alert-service/alert-modal/alert-modal.js +31 -0
  8. package/dist/alert-service/alert-modal/alert-modal.js.map +1 -0
  9. package/dist/alert-service/alert-modal/i-alert-modal-payload.js +2 -0
  10. package/dist/alert-service/alert-modal/i-alert-modal-payload.js.map +1 -0
  11. package/dist/alert-service/alert-service.js +108 -0
  12. package/dist/alert-service/alert-service.js.map +1 -0
  13. package/dist/alert-service/decorators/confirm-action.js +14 -0
  14. package/dist/alert-service/decorators/confirm-action.js.map +1 -0
  15. package/dist/alert-service/decorators/using-progress.js +23 -0
  16. package/dist/alert-service/decorators/using-progress.js.map +1 -0
  17. package/dist/alert-service/exceptions-tracker.js +4 -0
  18. package/dist/alert-service/exceptions-tracker.js.map +1 -0
  19. package/dist/alert-service/prompt-dialog/prompt-dialog.html +13 -0
  20. package/dist/alert-service/prompt-dialog/prompt-dialog.js +39 -0
  21. package/dist/alert-service/prompt-dialog/prompt-dialog.js.map +1 -0
  22. package/dist/badge/ui-badge.html +6 -0
  23. package/dist/badge/ui-badge.js +44 -0
  24. package/dist/badge/ui-badge.js.map +1 -0
  25. package/dist/base/boolean-attr.js +4 -0
  26. package/dist/base/boolean-attr.js.map +1 -0
  27. package/dist/base/i-validated-element.js +2 -0
  28. package/dist/base/i-validated-element.js.map +1 -0
  29. package/dist/base/keys.js +14 -0
  30. package/dist/base/keys.js.map +1 -0
  31. package/dist/breadcrumbs/ui-breadcrumbs.html +10 -0
  32. package/dist/breadcrumbs/ui-breadcrumbs.js +31 -0
  33. package/dist/breadcrumbs/ui-breadcrumbs.js.map +1 -0
  34. package/dist/button/enhance-ui-button.js +25 -0
  35. package/dist/button/enhance-ui-button.js.map +1 -0
  36. package/dist/button/ui-button.html +20 -0
  37. package/dist/button/ui-button.js +77 -0
  38. package/dist/button/ui-button.js.map +1 -0
  39. package/dist/button/ui-icon-button.html +20 -0
  40. package/dist/button/ui-icon-button.js +77 -0
  41. package/dist/button/ui-icon-button.js.map +1 -0
  42. package/dist/checkbox/ui-checkbox.html +32 -0
  43. package/dist/checkbox/ui-checkbox.js +186 -0
  44. package/dist/checkbox/ui-checkbox.js.map +1 -0
  45. package/dist/chip/ui-chip.html +32 -0
  46. package/dist/chip/ui-chip.js +129 -0
  47. package/dist/chip/ui-chip.js.map +1 -0
  48. package/dist/combobox/enhance-ui-combobox.js +26 -0
  49. package/dist/combobox/enhance-ui-combobox.js.map +1 -0
  50. package/dist/combobox/ui-combobox.html +76 -0
  51. package/dist/combobox/ui-combobox.js +478 -0
  52. package/dist/combobox/ui-combobox.js.map +1 -0
  53. package/dist/disclosure/ui-disclosure.html +28 -0
  54. package/dist/disclosure/ui-disclosure.js +75 -0
  55. package/dist/disclosure/ui-disclosure.js.map +1 -0
  56. package/dist/drawer/ui-drawer.html +35 -0
  57. package/dist/drawer/ui-drawer.js +246 -0
  58. package/dist/drawer/ui-drawer.js.map +1 -0
  59. package/dist/index.js +135 -0
  60. package/dist/index.js.map +1 -0
  61. package/dist/input/enhance-ui-input.js +26 -0
  62. package/dist/input/enhance-ui-input.js.map +1 -0
  63. package/dist/input/ui-input.html +56 -0
  64. package/dist/input/ui-input.js +259 -0
  65. package/dist/input/ui-input.js.map +1 -0
  66. package/dist/list/ui-list-item.html +22 -0
  67. package/dist/list/ui-list-item.js +59 -0
  68. package/dist/list/ui-list-item.js.map +1 -0
  69. package/dist/list/ui-list.html +10 -0
  70. package/dist/list/ui-list.js +316 -0
  71. package/dist/list/ui-list.js.map +1 -0
  72. package/dist/menu/ui-menu.html +20 -0
  73. package/dist/menu/ui-menu.js +154 -0
  74. package/dist/menu/ui-menu.js.map +1 -0
  75. package/dist/popup/ui-popup.html +16 -0
  76. package/dist/popup/ui-popup.js +397 -0
  77. package/dist/popup/ui-popup.js.map +1 -0
  78. package/dist/progress/ui-progress.html +17 -0
  79. package/dist/progress/ui-progress.js +76 -0
  80. package/dist/progress/ui-progress.js.map +1 -0
  81. package/dist/radio/ui-radio-group.html +27 -0
  82. package/dist/radio/ui-radio-group.js +259 -0
  83. package/dist/radio/ui-radio-group.js.map +1 -0
  84. package/dist/radio/ui-radio.html +11 -0
  85. package/dist/radio/ui-radio.js +55 -0
  86. package/dist/radio/ui-radio.js.map +1 -0
  87. package/dist/segmented-control/ui-segment.html +10 -0
  88. package/dist/segmented-control/ui-segment.js +44 -0
  89. package/dist/segmented-control/ui-segment.js.map +1 -0
  90. package/dist/segmented-control/ui-segmented-control.html +9 -0
  91. package/dist/segmented-control/ui-segmented-control.js +134 -0
  92. package/dist/segmented-control/ui-segmented-control.js.map +1 -0
  93. package/dist/select/enhance-ui-select.js +26 -0
  94. package/dist/select/enhance-ui-select.js.map +1 -0
  95. package/dist/select/ui-select.html +70 -0
  96. package/dist/select/ui-select.js +323 -0
  97. package/dist/select/ui-select.js.map +1 -0
  98. package/dist/slider/ui-slider.html +69 -0
  99. package/dist/slider/ui-slider.js +362 -0
  100. package/dist/slider/ui-slider.js.map +1 -0
  101. package/dist/splitter/ui-splitter.html +14 -0
  102. package/dist/splitter/ui-splitter.js +257 -0
  103. package/dist/splitter/ui-splitter.js.map +1 -0
  104. package/dist/switch/ui-switch.html +23 -0
  105. package/dist/switch/ui-switch.js +121 -0
  106. package/dist/switch/ui-switch.js.map +1 -0
  107. package/dist/table/enhance-ui-table.js +25 -0
  108. package/dist/table/enhance-ui-table.js.map +1 -0
  109. package/dist/table/ui-table-column.html +17 -0
  110. package/dist/table/ui-table-column.js +127 -0
  111. package/dist/table/ui-table-column.js.map +1 -0
  112. package/dist/table/ui-table.html +56 -0
  113. package/dist/table/ui-table.js +225 -0
  114. package/dist/table/ui-table.js.map +1 -0
  115. package/dist/tabs/ui-tab.html +10 -0
  116. package/dist/tabs/ui-tab.js +52 -0
  117. package/dist/tabs/ui-tab.js.map +1 -0
  118. package/dist/tabs/ui-tabs.html +3 -0
  119. package/dist/tabs/ui-tabs.js +112 -0
  120. package/dist/tabs/ui-tabs.js.map +1 -0
  121. package/dist/toast/ui-toast-region.html +11 -0
  122. package/dist/toast/ui-toast-region.js +38 -0
  123. package/dist/toast/ui-toast-region.js.map +1 -0
  124. package/dist/toast/ui-toast-service.js +70 -0
  125. package/dist/toast/ui-toast-service.js.map +1 -0
  126. package/dist/tooltip/ui-tooltip-service.js +63 -0
  127. package/dist/tooltip/ui-tooltip-service.js.map +1 -0
  128. package/dist/tooltip/ui-tooltip.js +221 -0
  129. package/dist/tooltip/ui-tooltip.js.map +1 -0
  130. package/dist/top-app-bar/ui-top-app-bar.html +24 -0
  131. package/dist/top-app-bar/ui-top-app-bar.js +68 -0
  132. package/dist/top-app-bar/ui-top-app-bar.js.map +1 -0
  133. package/dist/tree/ui-tree.html +38 -0
  134. package/dist/tree/ui-tree.js +340 -0
  135. package/dist/tree/ui-tree.js.map +1 -0
  136. package/dist/types/alert/ui-alert.d.ts +11 -0
  137. package/dist/types/alert-service/alert-configuration.d.ts +8 -0
  138. package/dist/types/alert-service/alert-modal/alert-modal.d.ts +7 -0
  139. package/dist/types/alert-service/alert-modal/i-alert-modal-payload.d.ts +14 -0
  140. package/dist/types/alert-service/alert-service.d.ts +17 -0
  141. package/dist/types/alert-service/decorators/confirm-action.d.ts +3 -0
  142. package/dist/types/alert-service/decorators/using-progress.d.ts +6 -0
  143. package/dist/types/alert-service/exceptions-tracker.d.ts +3 -0
  144. package/dist/types/alert-service/prompt-dialog/prompt-dialog.d.ts +17 -0
  145. package/dist/types/badge/ui-badge.d.ts +7 -0
  146. package/dist/types/base/boolean-attr.d.ts +1 -0
  147. package/dist/types/base/i-validated-element.d.ts +10 -0
  148. package/dist/types/base/keys.d.ts +12 -0
  149. package/dist/types/breadcrumbs/ui-breadcrumbs.d.ts +8 -0
  150. package/dist/types/button/enhance-ui-button.d.ts +3 -0
  151. package/dist/types/button/ui-button.d.ts +16 -0
  152. package/dist/types/button/ui-icon-button.d.ts +18 -0
  153. package/dist/types/checkbox/ui-checkbox.d.ts +32 -0
  154. package/dist/types/chip/ui-chip.d.ts +26 -0
  155. package/dist/types/combobox/enhance-ui-combobox.d.ts +3 -0
  156. package/dist/types/combobox/ui-combobox.d.ts +79 -0
  157. package/dist/types/disclosure/ui-disclosure.d.ts +18 -0
  158. package/dist/types/drawer/ui-drawer.d.ts +38 -0
  159. package/dist/types/index.d.ts +91 -0
  160. package/dist/types/input/enhance-ui-input.d.ts +3 -0
  161. package/dist/types/input/ui-input.d.ts +44 -0
  162. package/dist/types/list/ui-list-item.d.ts +10 -0
  163. package/dist/types/list/ui-list.d.ts +45 -0
  164. package/dist/types/menu/ui-menu.d.ts +29 -0
  165. package/dist/types/popup/ui-popup.d.ts +61 -0
  166. package/dist/types/progress/ui-progress.d.ts +15 -0
  167. package/dist/types/radio/ui-radio-group.d.ts +37 -0
  168. package/dist/types/radio/ui-radio.d.ts +11 -0
  169. package/dist/types/segmented-control/ui-segment.d.ts +8 -0
  170. package/dist/types/segmented-control/ui-segmented-control.d.ts +17 -0
  171. package/dist/types/select/enhance-ui-select.d.ts +3 -0
  172. package/dist/types/select/ui-select.d.ts +50 -0
  173. package/dist/types/slider/ui-slider.d.ts +58 -0
  174. package/dist/types/splitter/ui-splitter.d.ts +39 -0
  175. package/dist/types/switch/ui-switch.d.ts +23 -0
  176. package/dist/types/table/enhance-ui-table.d.ts +3 -0
  177. package/dist/types/table/ui-table-column.d.ts +22 -0
  178. package/dist/types/table/ui-table.d.ts +51 -0
  179. package/dist/types/tabs/ui-tab.d.ts +10 -0
  180. package/dist/types/tabs/ui-tabs.d.ts +16 -0
  181. package/dist/types/toast/ui-toast-region.d.ts +6 -0
  182. package/dist/types/toast/ui-toast-service.d.ts +28 -0
  183. package/dist/types/tooltip/ui-tooltip-service.d.ts +23 -0
  184. package/dist/types/tooltip/ui-tooltip.d.ts +35 -0
  185. package/dist/types/top-app-bar/ui-top-app-bar.d.ts +9 -0
  186. package/dist/types/tree/ui-tree.d.ts +70 -0
  187. package/dist/types/validation/ui-validation-controller-factory.d.ts +7 -0
  188. package/dist/types/validation/ui-validation-result-presenter.d.ts +4 -0
  189. package/dist/types/validation/validate.d.ts +13 -0
  190. package/dist/validation/ui-validation-controller-factory.js +17 -0
  191. package/dist/validation/ui-validation-controller-factory.js.map +1 -0
  192. package/dist/validation/ui-validation-result-presenter.js +23 -0
  193. package/dist/validation/ui-validation-result-presenter.js.map +1 -0
  194. package/dist/validation/validate.js +24 -0
  195. package/dist/validation/validate.js.map +1 -0
  196. package/package.json +50 -0
  197. package/src/alert/ui-alert.html +19 -0
  198. package/src/alert/ui-alert.ts +33 -0
  199. package/src/alert-service/alert-configuration.ts +11 -0
  200. package/src/alert-service/alert-modal/alert-modal.html +12 -0
  201. package/src/alert-service/alert-modal/alert-modal.ts +19 -0
  202. package/src/alert-service/alert-modal/i-alert-modal-payload.ts +14 -0
  203. package/src/alert-service/alert-service.ts +116 -0
  204. package/src/alert-service/decorators/confirm-action.ts +18 -0
  205. package/src/alert-service/decorators/using-progress.ts +32 -0
  206. package/src/alert-service/exceptions-tracker.ts +3 -0
  207. package/src/alert-service/prompt-dialog/prompt-dialog.html +13 -0
  208. package/src/alert-service/prompt-dialog/prompt-dialog.ts +37 -0
  209. package/src/badge/ui-badge.html +6 -0
  210. package/src/badge/ui-badge.ts +17 -0
  211. package/src/base/boolean-attr.ts +3 -0
  212. package/src/base/i-validated-element.ts +11 -0
  213. package/src/base/keys.ts +12 -0
  214. package/src/breadcrumbs/ui-breadcrumbs.html +10 -0
  215. package/src/breadcrumbs/ui-breadcrumbs.ts +14 -0
  216. package/src/button/enhance-ui-button.ts +9 -0
  217. package/src/button/ui-button.html +20 -0
  218. package/src/button/ui-button.ts +60 -0
  219. package/src/button/ui-icon-button.html +20 -0
  220. package/src/button/ui-icon-button.ts +62 -0
  221. package/src/checkbox/ui-checkbox.html +32 -0
  222. package/src/checkbox/ui-checkbox.ts +188 -0
  223. package/src/chip/ui-chip.html +32 -0
  224. package/src/chip/ui-chip.ts +118 -0
  225. package/src/combobox/enhance-ui-combobox.ts +10 -0
  226. package/src/combobox/ui-combobox.html +76 -0
  227. package/src/combobox/ui-combobox.ts +450 -0
  228. package/src/disclosure/ui-disclosure.html +28 -0
  229. package/src/disclosure/ui-disclosure.ts +68 -0
  230. package/src/drawer/ui-drawer.html +35 -0
  231. package/src/drawer/ui-drawer.ts +219 -0
  232. package/src/index.ts +152 -0
  233. package/src/input/enhance-ui-input.ts +10 -0
  234. package/src/input/ui-input.html +56 -0
  235. package/src/input/ui-input.ts +225 -0
  236. package/src/list/ui-list-item.html +22 -0
  237. package/src/list/ui-list-item.ts +25 -0
  238. package/src/list/ui-list.html +10 -0
  239. package/src/list/ui-list.ts +330 -0
  240. package/src/menu/ui-menu.html +20 -0
  241. package/src/menu/ui-menu.ts +103 -0
  242. package/src/popup/ui-popup.html +16 -0
  243. package/src/popup/ui-popup.ts +391 -0
  244. package/src/progress/ui-progress.html +17 -0
  245. package/src/progress/ui-progress.ts +51 -0
  246. package/src/radio/ui-radio-group.html +27 -0
  247. package/src/radio/ui-radio-group.ts +250 -0
  248. package/src/radio/ui-radio.html +11 -0
  249. package/src/radio/ui-radio.ts +35 -0
  250. package/src/resource.d.ts +4 -0
  251. package/src/segmented-control/ui-segment.html +10 -0
  252. package/src/segmented-control/ui-segment.ts +20 -0
  253. package/src/segmented-control/ui-segmented-control.html +9 -0
  254. package/src/segmented-control/ui-segmented-control.ts +119 -0
  255. package/src/select/enhance-ui-select.ts +10 -0
  256. package/src/select/ui-select.html +70 -0
  257. package/src/select/ui-select.ts +294 -0
  258. package/src/slider/ui-slider.html +69 -0
  259. package/src/slider/ui-slider.ts +329 -0
  260. package/src/splitter/ui-splitter.html +14 -0
  261. package/src/splitter/ui-splitter.ts +249 -0
  262. package/src/switch/ui-switch.html +23 -0
  263. package/src/switch/ui-switch.ts +121 -0
  264. package/src/table/enhance-ui-table.ts +9 -0
  265. package/src/table/ui-table-column.html +17 -0
  266. package/src/table/ui-table-column.ts +108 -0
  267. package/src/table/ui-table.html +56 -0
  268. package/src/table/ui-table.ts +209 -0
  269. package/src/tabs/ui-tab.html +10 -0
  270. package/src/tabs/ui-tab.ts +30 -0
  271. package/src/tabs/ui-tabs.html +3 -0
  272. package/src/tabs/ui-tabs.ts +105 -0
  273. package/src/toast/ui-toast-region.html +11 -0
  274. package/src/toast/ui-toast-region.ts +18 -0
  275. package/src/toast/ui-toast-service.ts +100 -0
  276. package/src/tooltip/ui-tooltip-service.ts +84 -0
  277. package/src/tooltip/ui-tooltip.ts +200 -0
  278. package/src/top-app-bar/ui-top-app-bar.html +24 -0
  279. package/src/top-app-bar/ui-top-app-bar.ts +27 -0
  280. package/src/tree/ui-tree.html +38 -0
  281. package/src/tree/ui-tree.ts +363 -0
  282. package/src/validation/ui-validation-controller-factory.ts +20 -0
  283. package/src/validation/ui-validation-result-presenter.ts +26 -0
  284. package/src/validation/validate.ts +35 -0
@@ -0,0 +1,19 @@
1
+ <template class="ui-alert"
2
+ role.bind="role"
3
+ show.bind="open"
4
+ data-tone.attr="tone"
5
+ data-dismissible.attr="dismissible ? '' : null">
6
+ <div class="ui-alert__icon" aria-hidden="true"></div>
7
+ <div class="ui-alert__content">
8
+ <strong class="ui-alert__title" if.bind="title">${title}</strong>
9
+ <div class="ui-alert__message">
10
+ <au-slot></au-slot>
11
+ </div>
12
+ <div class="ui-alert__actions" if.bind="actionNodes.length">
13
+ <au-slot name="actions"></au-slot>
14
+ </div>
15
+ </div>
16
+ <button class="ui-alert__close" type="button" if.bind="dismissible" click.trigger="close()" aria-label="Dismiss alert">
17
+ <span class="ui-alert__close-icon" aria-hidden="true"></span>
18
+ </button>
19
+ </template>
@@ -0,0 +1,67 @@
1
+ import { __esDecorate, __runInitializers } from "tslib";
2
+ import { bindable, BindingMode, customElement, INode, resolve, slotted } from 'aurelia';
3
+ import { booleanAttr } from '../base/boolean-attr';
4
+ import template from './ui-alert.html?raw';
5
+ let UiAlert = (() => {
6
+ let _classDecorators = [customElement({ name: 'ui-alert', template })];
7
+ let _classDescriptor;
8
+ let _classExtraInitializers = [];
9
+ let _classThis;
10
+ let _tone_decorators;
11
+ let _tone_initializers = [];
12
+ let _tone_extraInitializers = [];
13
+ let _title_decorators;
14
+ let _title_initializers = [];
15
+ let _title_extraInitializers = [];
16
+ let _role_decorators;
17
+ let _role_initializers = [];
18
+ let _role_extraInitializers = [];
19
+ let _open_decorators;
20
+ let _open_initializers = [];
21
+ let _open_extraInitializers = [];
22
+ let _dismissible_decorators;
23
+ let _dismissible_initializers = [];
24
+ let _dismissible_extraInitializers = [];
25
+ let _actionNodes_decorators;
26
+ let _actionNodes_initializers = [];
27
+ let _actionNodes_extraInitializers = [];
28
+ var UiAlert = class {
29
+ static { _classThis = this; }
30
+ static {
31
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
32
+ _tone_decorators = [bindable];
33
+ _title_decorators = [bindable];
34
+ _role_decorators = [bindable];
35
+ _open_decorators = [bindable({ mode: BindingMode.twoWay, set: booleanAttr })];
36
+ _dismissible_decorators = [bindable({ set: booleanAttr })];
37
+ _actionNodes_decorators = [slotted({ slotName: 'actions' })];
38
+ __esDecorate(null, null, _tone_decorators, { kind: "field", name: "tone", static: false, private: false, access: { has: obj => "tone" in obj, get: obj => obj.tone, set: (obj, value) => { obj.tone = value; } }, metadata: _metadata }, _tone_initializers, _tone_extraInitializers);
39
+ __esDecorate(null, null, _title_decorators, { kind: "field", name: "title", static: false, private: false, access: { has: obj => "title" in obj, get: obj => obj.title, set: (obj, value) => { obj.title = value; } }, metadata: _metadata }, _title_initializers, _title_extraInitializers);
40
+ __esDecorate(null, null, _role_decorators, { kind: "field", name: "role", static: false, private: false, access: { has: obj => "role" in obj, get: obj => obj.role, set: (obj, value) => { obj.role = value; } }, metadata: _metadata }, _role_initializers, _role_extraInitializers);
41
+ __esDecorate(null, null, _open_decorators, { kind: "field", name: "open", static: false, private: false, access: { has: obj => "open" in obj, get: obj => obj.open, set: (obj, value) => { obj.open = value; } }, metadata: _metadata }, _open_initializers, _open_extraInitializers);
42
+ __esDecorate(null, null, _dismissible_decorators, { kind: "field", name: "dismissible", static: false, private: false, access: { has: obj => "dismissible" in obj, get: obj => obj.dismissible, set: (obj, value) => { obj.dismissible = value; } }, metadata: _metadata }, _dismissible_initializers, _dismissible_extraInitializers);
43
+ __esDecorate(null, null, _actionNodes_decorators, { kind: "field", name: "actionNodes", static: false, private: false, access: { has: obj => "actionNodes" in obj, get: obj => obj.actionNodes, set: (obj, value) => { obj.actionNodes = value; } }, metadata: _metadata }, _actionNodes_initializers, _actionNodes_extraInitializers);
44
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
45
+ UiAlert = _classThis = _classDescriptor.value;
46
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
47
+ __runInitializers(_classThis, _classExtraInitializers);
48
+ }
49
+ host = resolve(INode);
50
+ tone = __runInitializers(this, _tone_initializers, 'info');
51
+ title = (__runInitializers(this, _tone_extraInitializers), __runInitializers(this, _title_initializers, void 0));
52
+ role = (__runInitializers(this, _title_extraInitializers), __runInitializers(this, _role_initializers, 'status'));
53
+ open = (__runInitializers(this, _role_extraInitializers), __runInitializers(this, _open_initializers, true));
54
+ dismissible = (__runInitializers(this, _open_extraInitializers), __runInitializers(this, _dismissible_initializers, false));
55
+ actionNodes = (__runInitializers(this, _dismissible_extraInitializers), __runInitializers(this, _actionNodes_initializers, []));
56
+ close() {
57
+ this.open = false;
58
+ this.host.dispatchEvent(new CustomEvent('alert-close', { bubbles: true }));
59
+ }
60
+ constructor() {
61
+ __runInitializers(this, _actionNodes_extraInitializers);
62
+ }
63
+ };
64
+ return UiAlert = _classThis;
65
+ })();
66
+ export { UiAlert };
67
+ //# sourceMappingURL=ui-alert.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ui-alert.js","sourceRoot":"","sources":["../../src/alert/ui-alert.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,aAAa,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AACxF,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,QAAQ,MAAM,qBAAqB,CAAC;IAK9B,OAAO;4BADnB,aAAa,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;gCAI3C,QAAQ;iCAGR,QAAQ;gCAGR,QAAQ;gCAGR,QAAQ,CAAC,EAAE,IAAI,EAAE,WAAW,CAAC,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,CAAC;uCAGxD,QAAQ,CAAC,EAAE,GAAG,EAAE,WAAW,EAAE,CAAC;uCAG9B,OAAO,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,CAAC;YAdjC,8JAAA,IAAI,6BAAJ,IAAI,mFAAqB;YAGzB,iKAAA,KAAK,6BAAL,KAAK,qFAAqB;YAG1B,8JAAA,IAAI,6BAAJ,IAAI,mFAAyC;YAG7C,8JAAA,IAAI,6BAAJ,IAAI,mFAAiB;YAGrB,mLAAA,WAAW,6BAAX,WAAW,iGAAkB;YAG7B,mLAAA,WAAW,6BAAX,WAAW,iGAAuB;YAnBpC,6KAyBC;;;YAzBY,uDAAO;;QACD,IAAI,GAAG,OAAO,CAAC,KAAK,CAAgB,CAAC;QAGtD,IAAI,+CAAc,MAAM,EAAC;QAGzB,KAAK,4GAAqB;QAG1B,IAAI,mGAAgC,QAAQ,GAAC;QAG7C,IAAI,kGAAY,IAAI,GAAC;QAGrB,WAAW,yGAAY,KAAK,GAAC;QAG7B,WAAW,gHAAoB,EAAE,GAAC;QAElC,KAAK;YACH,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;YAClB,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,aAAa,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;QAC7E,CAAC;;;;;;;SAxBU,OAAO","sourcesContent":["import { bindable, BindingMode, customElement, INode, resolve, slotted } from 'aurelia';\nimport { booleanAttr } from '../base/boolean-attr';\nimport template from './ui-alert.html?raw';\n\nexport type AlertTone = 'info' | 'success' | 'warning' | 'danger';\n\n@customElement({ name: 'ui-alert', template })\nexport class UiAlert {\n private readonly host = resolve(INode) as HTMLElement;\n\n @bindable\n tone: AlertTone = 'info';\n\n @bindable\n title: string | undefined;\n\n @bindable\n role: 'status' | 'alert' | 'note' = 'status';\n\n @bindable({ mode: BindingMode.twoWay, set: booleanAttr })\n open: boolean = true;\n\n @bindable({ set: booleanAttr })\n dismissible: boolean = false;\n\n @slotted({ slotName: 'actions' })\n actionNodes: readonly Node[] = [];\n\n close(): void {\n this.open = false;\n this.host.dispatchEvent(new CustomEvent('alert-close', { bubbles: true }));\n }\n}\n"]}
@@ -0,0 +1,11 @@
1
+ import { AlertModal } from './alert-modal/alert-modal';
2
+ import { PromptDialog } from './prompt-dialog/prompt-dialog';
3
+ export class AlertConfiguration {
4
+ defaultAlertModal = AlertModal;
5
+ defaultPromptDialog = PromptDialog;
6
+ okText = 'Ok';
7
+ cancelText = 'Cancel';
8
+ yesText = 'Yes';
9
+ noText = 'No';
10
+ }
11
+ //# sourceMappingURL=alert-configuration.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"alert-configuration.js","sourceRoot":"","sources":["../../src/alert-service/alert-configuration.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAE7D,MAAM,OAAO,kBAAkB;IAC7B,iBAAiB,GAAqC,UAAU,CAAC;IACjE,mBAAmB,GAAqC,YAAY,CAAC;IACrE,MAAM,GAAW,IAAI,CAAC;IACtB,UAAU,GAAW,QAAQ,CAAC;IAC9B,OAAO,GAAW,KAAK,CAAC;IACxB,MAAM,GAAW,IAAI,CAAC;CACvB","sourcesContent":["import { AlertModal } from './alert-modal/alert-modal';\nimport { PromptDialog } from './prompt-dialog/prompt-dialog';\n\nexport class AlertConfiguration {\n defaultAlertModal: new (...args: never[]) => object = AlertModal;\n defaultPromptDialog: new (...args: never[]) => object = PromptDialog;\n okText: string = 'Ok';\n cancelText: string = 'Cancel';\n yesText: string = 'Yes';\n noText: string = 'No';\n}\n"]}
@@ -0,0 +1,12 @@
1
+ <template class="ui-alert-modal" data-tone.attr="payload.tone ?? 'info'">
2
+ <div class="ui-alert-modal__icon" aria-hidden="true">${payload.icon}</div>
3
+ <div class="ui-alert-modal__body">
4
+ <h2 class="ui-alert-modal__title" if.bind="payload.caption">${payload.caption}</h2>
5
+ <p class="ui-alert-modal__message" if.bind="payload.message">${payload.message}</p>
6
+ <div class="ui-alert-modal__html" if.bind="payload.html" innerhtml.bind="payload.html"></div>
7
+ <div class="ui-alert-modal__actions">
8
+ <button ui-button outlined type="button" if.bind="payload.button1Text" click.trigger="close(payload.button1Action)">${payload.button1Text}</button>
9
+ <button ui-button primary type="button" if.bind="payload.button2Text" click.trigger="close(payload.button2Action)" autofocus>${payload.button2Text}</button>
10
+ </div>
11
+ </div>
12
+ </template>
@@ -0,0 +1,31 @@
1
+ import { __esDecorate, __runInitializers } from "tslib";
2
+ import { IDialogController } from '@aurelia/dialog';
3
+ import { customElement, resolve } from 'aurelia';
4
+ import template from './alert-modal.html?raw';
5
+ let AlertModal = (() => {
6
+ let _classDecorators = [customElement({ name: 'alert-modal', template })];
7
+ let _classDescriptor;
8
+ let _classExtraInitializers = [];
9
+ let _classThis;
10
+ var AlertModal = class {
11
+ static { _classThis = this; }
12
+ static {
13
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
14
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
15
+ AlertModal = _classThis = _classDescriptor.value;
16
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
17
+ __runInitializers(_classThis, _classExtraInitializers);
18
+ }
19
+ dialog = resolve(IDialogController);
20
+ payload = {};
21
+ activate(payload) {
22
+ this.payload = payload;
23
+ }
24
+ close(action) {
25
+ return this.dialog.ok(action);
26
+ }
27
+ };
28
+ return AlertModal = _classThis;
29
+ })();
30
+ export { AlertModal };
31
+ //# sourceMappingURL=alert-modal.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"alert-modal.js","sourceRoot":"","sources":["../../../src/alert-service/alert-modal/alert-modal.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AACjD,OAAO,QAAQ,MAAM,wBAAwB,CAAC;IAIjC,UAAU;4BADtB,aAAa,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,QAAQ,EAAE,CAAC;;;;;;;;YACjD,6KAYC;;;YAZY,uDAAU;;QACJ,MAAM,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAC;QAErD,OAAO,GAAuB,EAAE,CAAC;QAEjC,QAAQ,CAAC,OAA2B;YAClC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACzB,CAAC;QAED,KAAK,CAAC,MAA0B;YAC9B,OAAO,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC;QAChC,CAAC;;;;SAXU,UAAU","sourcesContent":["import { IDialogController } from '@aurelia/dialog';\nimport { customElement, resolve } from 'aurelia';\nimport template from './alert-modal.html?raw';\nimport { IAlertModalPayload } from './i-alert-modal-payload';\n\n@customElement({ name: 'alert-modal', template })\nexport class AlertModal {\n private readonly dialog = resolve(IDialogController);\n\n payload: IAlertModalPayload = {};\n\n activate(payload: IAlertModalPayload): void {\n this.payload = payload;\n }\n\n close(action: string | undefined): Promise<unknown> {\n return this.dialog.ok(action);\n }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=i-alert-modal-payload.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"i-alert-modal-payload.js","sourceRoot":"","sources":["../../../src/alert-service/alert-modal/i-alert-modal-payload.ts"],"names":[],"mappings":"","sourcesContent":["export interface IAlertModalPayload {\n icon?: string;\n tone?: 'info' | 'success' | 'warning' | 'danger';\n caption?: string;\n message?: string;\n html?: string;\n button1Text?: string;\n button2Text?: string;\n button1Action?: string;\n button2Action?: string;\n defaultAction?: string;\n successAction?: string;\n defensive?: boolean;\n}\n"]}
@@ -0,0 +1,108 @@
1
+ import { IDialogService } from '@aurelia/dialog';
2
+ import { resolve } from 'aurelia';
3
+ import { AlertConfiguration } from './alert-configuration';
4
+ import { AlertModal } from './alert-modal/alert-modal';
5
+ import { ExceptionsTracker } from './exceptions-tracker';
6
+ import { PromptDialog } from './prompt-dialog/prompt-dialog';
7
+ export class AlertService {
8
+ dialogService = resolve(IDialogService);
9
+ exceptionsTracker = resolve(ExceptionsTracker);
10
+ configuration = resolve(AlertConfiguration);
11
+ progressDepth = 0;
12
+ showProgress() {
13
+ this.progressDepth++;
14
+ document.dispatchEvent(new CustomEvent('alert-service:progress', { detail: { busy: true } }));
15
+ }
16
+ hideProgress() {
17
+ this.progressDepth = Math.max(0, this.progressDepth - 1);
18
+ document.dispatchEvent(new CustomEvent('alert-service:progress', { detail: { busy: this.progressDepth > 0 } }));
19
+ }
20
+ async usingProgress(action, catchHandler) {
21
+ try {
22
+ this.showProgress();
23
+ return await action();
24
+ }
25
+ catch (e) {
26
+ if (catchHandler) {
27
+ return await catchHandler(e);
28
+ }
29
+ throw e;
30
+ }
31
+ finally {
32
+ this.hideProgress();
33
+ }
34
+ }
35
+ async showModal(model) {
36
+ const payload = { ...model };
37
+ const result = await this.dialogService.open({
38
+ component: () => this.configuration.defaultAlertModal || AlertModal,
39
+ model: payload,
40
+ rejectOnCancel: false,
41
+ options: { modal: true, closedby: 'closerequest' }
42
+ }).whenClosed();
43
+ return typeof result.value === 'string' ? result.value : undefined;
44
+ }
45
+ async alert(message) {
46
+ const payload = typeof message === 'string' ? { message } : message;
47
+ const model = {
48
+ icon: 'i',
49
+ tone: 'info',
50
+ button2Text: this.configuration.okText,
51
+ button2Action: 'ok',
52
+ defaultAction: 'ok',
53
+ successAction: 'ok',
54
+ ...payload
55
+ };
56
+ return await this.showModal(model) === model.successAction;
57
+ }
58
+ async confirm(message) {
59
+ const payload = typeof message === 'string' ? { message } : message;
60
+ const model = payload.defensive
61
+ ? {
62
+ icon: '?',
63
+ tone: 'warning',
64
+ button1Text: this.configuration.yesText,
65
+ button1Action: 'yes',
66
+ button2Text: this.configuration.noText,
67
+ button2Action: 'no',
68
+ defaultAction: 'no',
69
+ successAction: 'yes',
70
+ ...payload
71
+ }
72
+ : {
73
+ icon: '?',
74
+ tone: 'info',
75
+ button1Text: this.configuration.noText,
76
+ button1Action: 'no',
77
+ button2Text: this.configuration.yesText,
78
+ button2Action: 'yes',
79
+ defaultAction: 'yes',
80
+ successAction: 'yes',
81
+ ...payload
82
+ };
83
+ return await this.showModal(model) === model.successAction;
84
+ }
85
+ async prompt(data) {
86
+ data.okText ??= this.configuration.okText;
87
+ data.cancelText ??= this.configuration.cancelText;
88
+ const result = await this.dialogService.open({
89
+ component: () => this.configuration.defaultPromptDialog || PromptDialog,
90
+ model: data,
91
+ rejectOnCancel: false,
92
+ options: { modal: true, closedby: 'closerequest' }
93
+ }).whenClosed();
94
+ if (result.status === 'ok' && typeof result.value === 'string') {
95
+ data.text = result.value;
96
+ }
97
+ return result.status === 'ok';
98
+ }
99
+ async error(message) {
100
+ const payload = typeof message === 'string' ? { message } : message;
101
+ return this.alert({ icon: '!', tone: 'danger', ...payload });
102
+ }
103
+ async criticalError(message, error) {
104
+ this.exceptionsTracker.track(error);
105
+ return this.error(message);
106
+ }
107
+ }
108
+ //# sourceMappingURL=alert-service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"alert-service.js","sourceRoot":"","sources":["../../src/alert-service/alert-service.ts"],"names":[],"mappings":"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","sourcesContent":["import { DialogCloseResult, IDialogService } from '@aurelia/dialog';\nimport { resolve } from 'aurelia';\nimport { AlertConfiguration } from './alert-configuration';\nimport { AlertModal } from './alert-modal/alert-modal';\nimport { IAlertModalPayload } from './alert-modal/i-alert-modal-payload';\nimport { ExceptionsTracker } from './exceptions-tracker';\nimport { IPromptDialogData, PromptDialog } from './prompt-dialog/prompt-dialog';\n\nexport class AlertService {\n private readonly dialogService = resolve(IDialogService);\n private readonly exceptionsTracker = resolve(ExceptionsTracker);\n private readonly configuration = resolve(AlertConfiguration);\n private progressDepth: number = 0;\n\n showProgress(): void {\n this.progressDepth++;\n document.dispatchEvent(new CustomEvent('alert-service:progress', { detail: { busy: true } }));\n }\n\n hideProgress(): void {\n this.progressDepth = Math.max(0, this.progressDepth - 1);\n document.dispatchEvent(new CustomEvent('alert-service:progress', { detail: { busy: this.progressDepth > 0 } }));\n }\n\n async usingProgress<T, E = never>(action: () => Promise<T>, catchHandler?: (e: unknown) => Promise<E> | E): Promise<T | E> {\n try {\n this.showProgress();\n return await action();\n } catch (e) {\n if (catchHandler) {\n return await catchHandler(e);\n }\n throw e;\n } finally {\n this.hideProgress();\n }\n }\n\n async showModal(model: Partial<IAlertModalPayload>): Promise<string | undefined> {\n const payload: IAlertModalPayload = { ...model };\n const result = await this.dialogService.open({\n component: () => this.configuration.defaultAlertModal || AlertModal,\n model: payload,\n rejectOnCancel: false,\n options: { modal: true, closedby: 'closerequest' }\n }).whenClosed() as DialogCloseResult;\n return typeof result.value === 'string' ? result.value : undefined;\n }\n\n async alert(message: string | Partial<IAlertModalPayload>): Promise<boolean> {\n const payload = typeof message === 'string' ? { message } : message;\n const model: IAlertModalPayload = {\n icon: 'i',\n tone: 'info',\n button2Text: this.configuration.okText,\n button2Action: 'ok',\n defaultAction: 'ok',\n successAction: 'ok',\n ...payload\n };\n return await this.showModal(model) === model.successAction;\n }\n\n async confirm(message: string | Partial<IAlertModalPayload>): Promise<boolean> {\n const payload = typeof message === 'string' ? { message } : message;\n const model: IAlertModalPayload = payload.defensive\n ? {\n icon: '?',\n tone: 'warning',\n button1Text: this.configuration.yesText,\n button1Action: 'yes',\n button2Text: this.configuration.noText,\n button2Action: 'no',\n defaultAction: 'no',\n successAction: 'yes',\n ...payload\n }\n : {\n icon: '?',\n tone: 'info',\n button1Text: this.configuration.noText,\n button1Action: 'no',\n button2Text: this.configuration.yesText,\n button2Action: 'yes',\n defaultAction: 'yes',\n successAction: 'yes',\n ...payload\n };\n return await this.showModal(model) === model.successAction;\n }\n\n async prompt(data: Partial<IPromptDialogData>): Promise<boolean> {\n data.okText ??= this.configuration.okText;\n data.cancelText ??= this.configuration.cancelText;\n const result = await this.dialogService.open({\n component: () => this.configuration.defaultPromptDialog || PromptDialog,\n model: data,\n rejectOnCancel: false,\n options: { modal: true, closedby: 'closerequest' }\n }).whenClosed() as DialogCloseResult;\n if (result.status === 'ok' && typeof result.value === 'string') {\n data.text = result.value;\n }\n return result.status === 'ok';\n }\n\n async error(message: string | Partial<IAlertModalPayload>): Promise<boolean> {\n const payload = typeof message === 'string' ? { message } : message;\n return this.alert({ icon: '!', tone: 'danger', ...payload });\n }\n\n async criticalError(message: string | Partial<IAlertModalPayload>, error: Error): Promise<boolean> {\n this.exceptionsTracker.track(error);\n return this.error(message);\n }\n}\n"]}
@@ -0,0 +1,14 @@
1
+ export function confirmAction(message) {
2
+ return function actualDecorator(originalMethod, _context) {
3
+ return async function replacementMethod(...args) {
4
+ if (!this.alertService) {
5
+ throw new Error('Did you forget to inject AlertService?');
6
+ }
7
+ if (!await this.alertService.confirm(message)) {
8
+ return;
9
+ }
10
+ return originalMethod.call(this, ...args);
11
+ };
12
+ };
13
+ }
14
+ //# sourceMappingURL=confirm-action.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"confirm-action.js","sourceRoot":"","sources":["../../../src/alert-service/decorators/confirm-action.ts"],"names":[],"mappings":"AAGA,MAAM,UAAU,aAAa,CAAC,OAA6C;IACzE,OAAO,SAAS,eAAe,CAAiE,cAAqD,EACnJ,QAAkF;QAClF,OAAO,KAAK,UAAU,iBAAiB,CAAa,GAAG,IAAU;YAC/D,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;gBACvB,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;YAC5D,CAAC;YAED,IAAI,CAAC,MAAM,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;gBAC9C,OAAO;YACT,CAAC;YACD,OAAO,cAAc,CAAC,IAAI,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC,CAAC;QAC5C,CAAC,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC","sourcesContent":["import { IAlertModalPayload } from '../alert-modal/i-alert-modal-payload';\nimport { IWithAlertService } from './using-progress';\n\nexport function confirmAction(message: string | Partial<IAlertModalPayload>) {\n return function actualDecorator<This extends IWithAlertService, Args extends unknown[], Return>(originalMethod: (this: This, ...args: Args) => Return,\n _context: ClassMethodDecoratorContext<This, (this: This, ...args: Args) => Return>) {\n return async function replacementMethod(this: This, ...args: Args) {\n if (!this.alertService) {\n throw new Error('Did you forget to inject AlertService?');\n }\n\n if (!await this.alertService.confirm(message)) {\n return;\n }\n return originalMethod.call(this, ...args);\n };\n };\n}\n"]}
@@ -0,0 +1,23 @@
1
+ export function usingProgress(errorMessage) {
2
+ return function actualDecorator(originalMethod, _context) {
3
+ return function replacementMethod(...args) {
4
+ if (!this.alertService) {
5
+ throw new Error('Did you forget to inject AlertService?');
6
+ }
7
+ return this.alertService.usingProgress(async () => {
8
+ return await originalMethod.call(this, ...args);
9
+ }, async (e) => {
10
+ const message = errorMessage instanceof Function ? errorMessage(e) : errorMessage;
11
+ await this.alertService.criticalError(message ?? errorToMessage(e), errorToError(e));
12
+ throw e;
13
+ });
14
+ };
15
+ };
16
+ }
17
+ function errorToMessage(error) {
18
+ return error instanceof Error ? error.message : String(error);
19
+ }
20
+ function errorToError(error) {
21
+ return error instanceof Error ? error : new Error(String(error));
22
+ }
23
+ //# sourceMappingURL=using-progress.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"using-progress.js","sourceRoot":"","sources":["../../../src/alert-service/decorators/using-progress.ts"],"names":[],"mappings":"AAOA,MAAM,UAAU,aAAa,CAAC,YAA4G;IACxI,OAAO,SAAS,eAAe,CAAiE,cAAqD,EACnJ,QAAkF;QAClF,OAAO,SAAS,iBAAiB,CAAa,GAAG,IAAU;YACzD,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;gBACvB,MAAM,IAAI,KAAK,CAAC,wCAAwC,CAAC,CAAC;YAC5D,CAAC;YACD,OAAO,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,IAAI,EAAE;gBAChD,OAAO,MAAM,cAAc,CAAC,IAAI,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC,CAAC;YAClD,CAAC,EAAE,KAAK,EAAC,CAAC,EAAC,EAAE;gBACX,MAAM,OAAO,GAAG,YAAY,YAAY,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC;gBAClF,MAAM,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,OAAO,IAAI,cAAc,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC;gBACrF,MAAM,CAAC,CAAC;YACV,CAAC,CAAC,CAAC;QACL,CAAC,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC;AAED,SAAS,cAAc,CAAC,KAAc;IACpC,OAAO,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;AAChE,CAAC;AAED,SAAS,YAAY,CAAC,KAAc;IAClC,OAAO,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;AACnE,CAAC","sourcesContent":["import { IAlertModalPayload } from '../alert-modal/i-alert-modal-payload';\nimport { AlertService } from '../alert-service';\n\nexport interface IWithAlertService {\n alertService: AlertService;\n}\n\nexport function usingProgress(errorMessage?: string | Partial<IAlertModalPayload> | ((e: unknown) => string | Partial<IAlertModalPayload>)) {\n return function actualDecorator<This extends IWithAlertService, Args extends unknown[], Return>(originalMethod: (this: This, ...args: Args) => Return,\n _context: ClassMethodDecoratorContext<This, (this: This, ...args: Args) => Return>) {\n return function replacementMethod(this: This, ...args: Args) {\n if (!this.alertService) {\n throw new Error('Did you forget to inject AlertService?');\n }\n return this.alertService.usingProgress(async () => {\n return await originalMethod.call(this, ...args);\n }, async e => {\n const message = errorMessage instanceof Function ? errorMessage(e) : errorMessage;\n await this.alertService.criticalError(message ?? errorToMessage(e), errorToError(e));\n throw e;\n });\n };\n };\n}\n\nfunction errorToMessage(error: unknown): string {\n return error instanceof Error ? error.message : String(error);\n}\n\nfunction errorToError(error: unknown): Error {\n return error instanceof Error ? error : new Error(String(error));\n}\n"]}
@@ -0,0 +1,4 @@
1
+ export class ExceptionsTracker {
2
+ track(_error) { }
3
+ }
4
+ //# sourceMappingURL=exceptions-tracker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"exceptions-tracker.js","sourceRoot":"","sources":["../../src/alert-service/exceptions-tracker.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,iBAAiB;IAC5B,KAAK,CAAC,MAAa,IAAU,CAAC;CAC/B","sourcesContent":["export class ExceptionsTracker {\n track(_error: Error): void { }\n}\n"]}
@@ -0,0 +1,13 @@
1
+ <template class="prompt-dialog">
2
+ <h2 class="prompt-dialog__title" if.bind="data.title">${data.title}</h2>
3
+ <label class="prompt-dialog__field">
4
+ <span class="prompt-dialog__label" if.bind="data.label">${data.label}</span>
5
+ <textarea class="prompt-dialog__control" if.bind="data.textarea" value.bind="data.text" required.bind="data.required" autofocus></textarea>
6
+ <input class="prompt-dialog__control" else type="text" value.bind="data.text" required.bind="data.required" autofocus>
7
+ </label>
8
+ <div class="prompt-dialog__error" if.bind="invalid">This field is required.</div>
9
+ <div class="prompt-dialog__actions">
10
+ <button ui-button outlined type="button" if.bind="data.cancelText" click.trigger="cancel()">${data.cancelText}</button>
11
+ <button ui-button primary type="button" if.bind="data.okText" click.trigger="ok()">${data.okText}</button>
12
+ </div>
13
+ </template>
@@ -0,0 +1,39 @@
1
+ import { __esDecorate, __runInitializers } from "tslib";
2
+ import { IDialogController } from '@aurelia/dialog';
3
+ import { customElement, resolve } from 'aurelia';
4
+ import template from './prompt-dialog.html?raw';
5
+ let PromptDialog = (() => {
6
+ let _classDecorators = [customElement({ name: 'prompt-dialog', template })];
7
+ let _classDescriptor;
8
+ let _classExtraInitializers = [];
9
+ let _classThis;
10
+ var PromptDialog = class {
11
+ static { _classThis = this; }
12
+ static {
13
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
14
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
15
+ PromptDialog = _classThis = _classDescriptor.value;
16
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
17
+ __runInitializers(_classThis, _classExtraInitializers);
18
+ }
19
+ dialog = resolve(IDialogController);
20
+ data = {};
21
+ invalid = false;
22
+ activate(data) {
23
+ this.data = data;
24
+ }
25
+ cancel() {
26
+ return this.dialog.cancel();
27
+ }
28
+ ok() {
29
+ this.invalid = !!this.data.required && !this.data.text?.trim();
30
+ if (this.invalid) {
31
+ return;
32
+ }
33
+ return this.dialog.ok(this.data.text ?? '');
34
+ }
35
+ };
36
+ return PromptDialog = _classThis;
37
+ })();
38
+ export { PromptDialog };
39
+ //# sourceMappingURL=prompt-dialog.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prompt-dialog.js","sourceRoot":"","sources":["../../../src/alert-service/prompt-dialog/prompt-dialog.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AACjD,OAAO,QAAQ,MAAM,0BAA0B,CAAC;IAanC,YAAY;4BADxB,aAAa,CAAC,EAAE,IAAI,EAAE,eAAe,EAAE,QAAQ,EAAE,CAAC;;;;;;;;YACnD,6KAqBC;;;YArBY,uDAAY;;QACN,MAAM,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAC;QAErD,IAAI,GAAsB,EAAE,CAAC;QAC7B,OAAO,GAAY,KAAK,CAAC;QAEzB,QAAQ,CAAC,IAAuB;YAC9B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACnB,CAAC;QAED,MAAM;YACJ,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;QAC9B,CAAC;QAED,EAAE;YACA,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC;YAC/D,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;gBACjB,OAAO;YACT,CAAC;YACD,OAAO,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;QAC9C,CAAC;;;;SApBU,YAAY","sourcesContent":["import { IDialogController } from '@aurelia/dialog';\nimport { customElement, resolve } from 'aurelia';\nimport template from './prompt-dialog.html?raw';\n\nexport interface IPromptDialogData {\n title?: string;\n label?: string;\n text?: string;\n required?: boolean;\n textarea?: boolean;\n okText?: string;\n cancelText?: string;\n}\n\n@customElement({ name: 'prompt-dialog', template })\nexport class PromptDialog {\n private readonly dialog = resolve(IDialogController);\n\n data: IPromptDialogData = {};\n invalid: boolean = false;\n\n activate(data: IPromptDialogData): void {\n this.data = data;\n }\n\n cancel(): Promise<unknown> {\n return this.dialog.cancel();\n }\n\n ok(): Promise<unknown> | void {\n this.invalid = !!this.data.required && !this.data.text?.trim();\n if (this.invalid) {\n return;\n }\n return this.dialog.ok(this.data.text ?? '');\n }\n}\n"]}
@@ -0,0 +1,6 @@
1
+ <template class="ui-badge"
2
+ data-tone.attr="tone"
3
+ data-pill.attr="pill ? '' : null"
4
+ data-outlined.attr="outlined ? '' : null">
5
+ <au-slot></au-slot>
6
+ </template>
@@ -0,0 +1,44 @@
1
+ import { __esDecorate, __runInitializers } from "tslib";
2
+ import { bindable, customElement } from 'aurelia';
3
+ import { booleanAttr } from '../base/boolean-attr';
4
+ import template from './ui-badge.html?raw';
5
+ let UiBadge = (() => {
6
+ let _classDecorators = [customElement({ name: 'ui-badge', template })];
7
+ let _classDescriptor;
8
+ let _classExtraInitializers = [];
9
+ let _classThis;
10
+ let _tone_decorators;
11
+ let _tone_initializers = [];
12
+ let _tone_extraInitializers = [];
13
+ let _pill_decorators;
14
+ let _pill_initializers = [];
15
+ let _pill_extraInitializers = [];
16
+ let _outlined_decorators;
17
+ let _outlined_initializers = [];
18
+ let _outlined_extraInitializers = [];
19
+ var UiBadge = class {
20
+ static { _classThis = this; }
21
+ static {
22
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
23
+ _tone_decorators = [bindable];
24
+ _pill_decorators = [bindable({ set: booleanAttr })];
25
+ _outlined_decorators = [bindable({ set: booleanAttr })];
26
+ __esDecorate(null, null, _tone_decorators, { kind: "field", name: "tone", static: false, private: false, access: { has: obj => "tone" in obj, get: obj => obj.tone, set: (obj, value) => { obj.tone = value; } }, metadata: _metadata }, _tone_initializers, _tone_extraInitializers);
27
+ __esDecorate(null, null, _pill_decorators, { kind: "field", name: "pill", static: false, private: false, access: { has: obj => "pill" in obj, get: obj => obj.pill, set: (obj, value) => { obj.pill = value; } }, metadata: _metadata }, _pill_initializers, _pill_extraInitializers);
28
+ __esDecorate(null, null, _outlined_decorators, { kind: "field", name: "outlined", static: false, private: false, access: { has: obj => "outlined" in obj, get: obj => obj.outlined, set: (obj, value) => { obj.outlined = value; } }, metadata: _metadata }, _outlined_initializers, _outlined_extraInitializers);
29
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
30
+ UiBadge = _classThis = _classDescriptor.value;
31
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
32
+ __runInitializers(_classThis, _classExtraInitializers);
33
+ }
34
+ tone = __runInitializers(this, _tone_initializers, 'neutral');
35
+ pill = (__runInitializers(this, _tone_extraInitializers), __runInitializers(this, _pill_initializers, false));
36
+ outlined = (__runInitializers(this, _pill_extraInitializers), __runInitializers(this, _outlined_initializers, false));
37
+ constructor() {
38
+ __runInitializers(this, _outlined_extraInitializers);
39
+ }
40
+ };
41
+ return UiBadge = _classThis;
42
+ })();
43
+ export { UiBadge };
44
+ //# sourceMappingURL=ui-badge.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ui-badge.js","sourceRoot":"","sources":["../../src/badge/ui-badge.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,QAAQ,MAAM,qBAAqB,CAAC;IAK9B,OAAO;4BADnB,aAAa,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC;;;;;;;;;;;;;;;;;gCAE3C,QAAQ;gCAGR,QAAQ,CAAC,EAAE,GAAG,EAAE,WAAW,EAAE,CAAC;oCAG9B,QAAQ,CAAC,EAAE,GAAG,EAAE,WAAW,EAAE,CAAC;YAL/B,8JAAA,IAAI,6BAAJ,IAAI,mFAAwB;YAG5B,8JAAA,IAAI,6BAAJ,IAAI,mFAAS;YAGb,0KAAA,QAAQ,6BAAR,QAAQ,2FAAS;YARnB,6KASC;;;YATY,uDAAO;;QAElB,IAAI,+CAAc,SAAS,EAAC;QAG5B,IAAI,kGAAG,KAAK,GAAC;QAGb,QAAQ,sGAAG,KAAK,GAAC;;;;;;;SARN,OAAO","sourcesContent":["import { bindable, customElement } from 'aurelia';\nimport { booleanAttr } from '../base/boolean-attr';\nimport template from './ui-badge.html?raw';\n\ntype BadgeTone = 'neutral' | 'primary' | 'success' | 'warning' | 'danger';\n\n@customElement({ name: 'ui-badge', template })\nexport class UiBadge {\n @bindable\n tone: BadgeTone = 'neutral';\n\n @bindable({ set: booleanAttr })\n pill = false;\n\n @bindable({ set: booleanAttr })\n outlined = false;\n}\n"]}
@@ -0,0 +1,4 @@
1
+ export function booleanAttr(val) {
2
+ return val === '' || !!val;
3
+ }
4
+ //# sourceMappingURL=boolean-attr.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"boolean-attr.js","sourceRoot":"","sources":["../../src/base/boolean-attr.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,WAAW,CAAC,GAAY;IACtC,OAAO,GAAG,KAAK,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC;AAC7B,CAAC","sourcesContent":["export function booleanAttr(val: unknown): boolean {\n return val === '' || !!val;\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=i-validated-element.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"i-validated-element.js","sourceRoot":"","sources":["../../src/base/i-validated-element.ts"],"names":[],"mappings":"","sourcesContent":["/** @hidden */\r\nexport interface IError {\r\n message: string | undefined;\r\n}\r\n\r\n/** @hidden */\r\nexport interface IValidatedElement extends HTMLElement {\r\n addError(error: IError): void;\r\n removeError(error: IError): void;\r\n valid: boolean;\r\n}\r\n"]}
@@ -0,0 +1,14 @@
1
+ export var Keys;
2
+ (function (Keys) {
3
+ Keys["ArrowDown"] = "ArrowDown";
4
+ Keys["ArrowLeft"] = "ArrowLeft";
5
+ Keys["ArrowRight"] = "ArrowRight";
6
+ Keys["ArrowUp"] = "ArrowUp";
7
+ Keys["End"] = "End";
8
+ Keys["Escape"] = "Escape";
9
+ Keys["Enter"] = "Enter";
10
+ Keys["Home"] = "Home";
11
+ Keys["Space"] = " ";
12
+ Keys["Tab"] = "Tab";
13
+ })(Keys || (Keys = {}));
14
+ //# sourceMappingURL=keys.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"keys.js","sourceRoot":"","sources":["../../src/base/keys.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,IAWX;AAXD,WAAY,IAAI;IACd,+BAAuB,CAAA;IACvB,+BAAuB,CAAA;IACvB,iCAAyB,CAAA;IACzB,2BAAmB,CAAA;IACnB,mBAAW,CAAA;IACX,yBAAiB,CAAA;IACjB,uBAAe,CAAA;IACf,qBAAa,CAAA;IACb,mBAAW,CAAA;IACX,mBAAW,CAAA;AACb,CAAC,EAXW,IAAI,KAAJ,IAAI,QAWf","sourcesContent":["export enum Keys {\n ArrowDown = 'ArrowDown',\n ArrowLeft = 'ArrowLeft',\n ArrowRight = 'ArrowRight',\n ArrowUp = 'ArrowUp',\n End = 'End',\n Escape = 'Escape',\n Enter = 'Enter',\n Home = 'Home',\n Space = ' ',\n Tab = 'Tab'\n}\n"]}
@@ -0,0 +1,10 @@
1
+ <template class="ui-breadcrumbs">
2
+ <nav class="ui-breadcrumbs__nav" aria-label="Breadcrumb">
3
+ <ol class="ui-breadcrumbs__list">
4
+ <li class="ui-breadcrumbs__item" repeat.for="item of items" data-current.attr="item.current ? '' : null">
5
+ <a class="ui-breadcrumbs__link" if.bind="item.href && !item.current" href.bind="item.href">${item.label}</a>
6
+ <span class="ui-breadcrumbs__current" else aria-current.bind="item.current ? 'page' : null">${item.label}</span>
7
+ </li>
8
+ </ol>
9
+ </nav>
10
+ </template>
@@ -0,0 +1,31 @@
1
+ import { __esDecorate, __runInitializers } from "tslib";
2
+ import { bindable, customElement } from 'aurelia';
3
+ import template from './ui-breadcrumbs.html?raw';
4
+ let UiBreadcrumbs = (() => {
5
+ let _classDecorators = [customElement({ name: 'ui-breadcrumbs', template })];
6
+ let _classDescriptor;
7
+ let _classExtraInitializers = [];
8
+ let _classThis;
9
+ let _items_decorators;
10
+ let _items_initializers = [];
11
+ let _items_extraInitializers = [];
12
+ var UiBreadcrumbs = class {
13
+ static { _classThis = this; }
14
+ static {
15
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
16
+ _items_decorators = [bindable];
17
+ __esDecorate(null, null, _items_decorators, { kind: "field", name: "items", static: false, private: false, access: { has: obj => "items" in obj, get: obj => obj.items, set: (obj, value) => { obj.items = value; } }, metadata: _metadata }, _items_initializers, _items_extraInitializers);
18
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
19
+ UiBreadcrumbs = _classThis = _classDescriptor.value;
20
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
21
+ __runInitializers(_classThis, _classExtraInitializers);
22
+ }
23
+ items = __runInitializers(this, _items_initializers, []);
24
+ constructor() {
25
+ __runInitializers(this, _items_extraInitializers);
26
+ }
27
+ };
28
+ return UiBreadcrumbs = _classThis;
29
+ })();
30
+ export { UiBreadcrumbs };
31
+ //# sourceMappingURL=ui-breadcrumbs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ui-breadcrumbs.js","sourceRoot":"","sources":["../../src/breadcrumbs/ui-breadcrumbs.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAClD,OAAO,QAAQ,MAAM,2BAA2B,CAAC;IASpC,aAAa;4BADzB,aAAa,CAAC,EAAE,IAAI,EAAE,gBAAgB,EAAE,QAAQ,EAAE,CAAC;;;;;;;;;;;iCAEjD,QAAQ;YACT,iKAAA,KAAK,6BAAL,KAAK,qFAAmC;YAF1C,6KAGC;;;YAHY,uDAAa;;QAExB,KAAK,gDAAgC,EAAE,EAAC;;;;;;;SAF7B,aAAa","sourcesContent":["import { bindable, customElement } from 'aurelia';\nimport template from './ui-breadcrumbs.html?raw';\n\nexport interface UiBreadcrumbItem {\n label: string;\n href?: string;\n current?: boolean;\n}\n\n@customElement({ name: 'ui-breadcrumbs', template })\nexport class UiBreadcrumbs {\n @bindable\n items: readonly UiBreadcrumbItem[] = [];\n}\n"]}
@@ -0,0 +1,25 @@
1
+ import { __esDecorate, __runInitializers } from "tslib";
2
+ import { templateCompilerHooks } from 'aurelia';
3
+ let EnhanceUiButton = (() => {
4
+ let _classDecorators = [templateCompilerHooks];
5
+ let _classDescriptor;
6
+ let _classExtraInitializers = [];
7
+ let _classThis;
8
+ var EnhanceUiButton = class {
9
+ static { _classThis = this; }
10
+ static {
11
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(null) : void 0;
12
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
13
+ EnhanceUiButton = _classThis = _classDescriptor.value;
14
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
15
+ __runInitializers(_classThis, _classExtraInitializers);
16
+ }
17
+ compiling(template) {
18
+ template.innerHTML = template.innerHTML.replace(/\sui-button(?:="")?(?=\s|>)/g, ' as-element="ui-button"');
19
+ template.innerHTML = template.innerHTML.replace(/\sui-icon-button(?:="")?(?=\s|>)/g, ' as-element="ui-icon-button"');
20
+ }
21
+ };
22
+ return EnhanceUiButton = _classThis;
23
+ })();
24
+ export { EnhanceUiButton };
25
+ //# sourceMappingURL=enhance-ui-button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"enhance-ui-button.js","sourceRoot":"","sources":["../../src/button/enhance-ui-button.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAC;IAGnC,eAAe;4BAD3B,qBAAqB;;;;;;;;YACtB,6KAKC;;;YALY,uDAAe;;QAC1B,SAAS,CAAC,QAA2C;YACnD,QAAQ,CAAC,SAAS,GAAG,QAAQ,CAAC,SAAS,CAAC,OAAO,CAAC,8BAA8B,EAAE,yBAAyB,CAAC,CAAC;YAC3G,QAAQ,CAAC,SAAS,GAAG,QAAQ,CAAC,SAAS,CAAC,OAAO,CAAC,mCAAmC,EAAE,8BAA8B,CAAC,CAAC;QACvH,CAAC;;;;SAJU,eAAe","sourcesContent":["import { templateCompilerHooks } from 'aurelia';\r\n\r\n@templateCompilerHooks\r\nexport class EnhanceUiButton {\n compiling(template: HTMLElement | HTMLTemplateElement) {\n template.innerHTML = template.innerHTML.replace(/\\sui-button(?:=\"\")?(?=\\s|>)/g, ' as-element=\"ui-button\"');\n template.innerHTML = template.innerHTML.replace(/\\sui-icon-button(?:=\"\")?(?=\\s|>)/g, ' as-element=\"ui-icon-button\"');\n }\n}\n"]}