@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.
- package/dist/alert/ui-alert.html +19 -0
- package/dist/alert/ui-alert.js +67 -0
- package/dist/alert/ui-alert.js.map +1 -0
- package/dist/alert-service/alert-configuration.js +11 -0
- package/dist/alert-service/alert-configuration.js.map +1 -0
- package/dist/alert-service/alert-modal/alert-modal.html +12 -0
- package/dist/alert-service/alert-modal/alert-modal.js +31 -0
- package/dist/alert-service/alert-modal/alert-modal.js.map +1 -0
- package/dist/alert-service/alert-modal/i-alert-modal-payload.js +2 -0
- package/dist/alert-service/alert-modal/i-alert-modal-payload.js.map +1 -0
- package/dist/alert-service/alert-service.js +108 -0
- package/dist/alert-service/alert-service.js.map +1 -0
- package/dist/alert-service/decorators/confirm-action.js +14 -0
- package/dist/alert-service/decorators/confirm-action.js.map +1 -0
- package/dist/alert-service/decorators/using-progress.js +23 -0
- package/dist/alert-service/decorators/using-progress.js.map +1 -0
- package/dist/alert-service/exceptions-tracker.js +4 -0
- package/dist/alert-service/exceptions-tracker.js.map +1 -0
- package/dist/alert-service/prompt-dialog/prompt-dialog.html +13 -0
- package/dist/alert-service/prompt-dialog/prompt-dialog.js +39 -0
- package/dist/alert-service/prompt-dialog/prompt-dialog.js.map +1 -0
- package/dist/badge/ui-badge.html +6 -0
- package/dist/badge/ui-badge.js +44 -0
- package/dist/badge/ui-badge.js.map +1 -0
- package/dist/base/boolean-attr.js +4 -0
- package/dist/base/boolean-attr.js.map +1 -0
- package/dist/base/i-validated-element.js +2 -0
- package/dist/base/i-validated-element.js.map +1 -0
- package/dist/base/keys.js +14 -0
- package/dist/base/keys.js.map +1 -0
- package/dist/breadcrumbs/ui-breadcrumbs.html +10 -0
- package/dist/breadcrumbs/ui-breadcrumbs.js +31 -0
- package/dist/breadcrumbs/ui-breadcrumbs.js.map +1 -0
- package/dist/button/enhance-ui-button.js +25 -0
- package/dist/button/enhance-ui-button.js.map +1 -0
- package/dist/button/ui-button.html +20 -0
- package/dist/button/ui-button.js +77 -0
- package/dist/button/ui-button.js.map +1 -0
- package/dist/button/ui-icon-button.html +20 -0
- package/dist/button/ui-icon-button.js +77 -0
- package/dist/button/ui-icon-button.js.map +1 -0
- package/dist/checkbox/ui-checkbox.html +32 -0
- package/dist/checkbox/ui-checkbox.js +186 -0
- package/dist/checkbox/ui-checkbox.js.map +1 -0
- package/dist/chip/ui-chip.html +32 -0
- package/dist/chip/ui-chip.js +129 -0
- package/dist/chip/ui-chip.js.map +1 -0
- package/dist/combobox/enhance-ui-combobox.js +26 -0
- package/dist/combobox/enhance-ui-combobox.js.map +1 -0
- package/dist/combobox/ui-combobox.html +76 -0
- package/dist/combobox/ui-combobox.js +478 -0
- package/dist/combobox/ui-combobox.js.map +1 -0
- package/dist/disclosure/ui-disclosure.html +28 -0
- package/dist/disclosure/ui-disclosure.js +75 -0
- package/dist/disclosure/ui-disclosure.js.map +1 -0
- package/dist/drawer/ui-drawer.html +35 -0
- package/dist/drawer/ui-drawer.js +246 -0
- package/dist/drawer/ui-drawer.js.map +1 -0
- package/dist/index.js +135 -0
- package/dist/index.js.map +1 -0
- package/dist/input/enhance-ui-input.js +26 -0
- package/dist/input/enhance-ui-input.js.map +1 -0
- package/dist/input/ui-input.html +56 -0
- package/dist/input/ui-input.js +259 -0
- package/dist/input/ui-input.js.map +1 -0
- package/dist/list/ui-list-item.html +22 -0
- package/dist/list/ui-list-item.js +59 -0
- package/dist/list/ui-list-item.js.map +1 -0
- package/dist/list/ui-list.html +10 -0
- package/dist/list/ui-list.js +316 -0
- package/dist/list/ui-list.js.map +1 -0
- package/dist/menu/ui-menu.html +20 -0
- package/dist/menu/ui-menu.js +154 -0
- package/dist/menu/ui-menu.js.map +1 -0
- package/dist/popup/ui-popup.html +16 -0
- package/dist/popup/ui-popup.js +397 -0
- package/dist/popup/ui-popup.js.map +1 -0
- package/dist/progress/ui-progress.html +17 -0
- package/dist/progress/ui-progress.js +76 -0
- package/dist/progress/ui-progress.js.map +1 -0
- package/dist/radio/ui-radio-group.html +27 -0
- package/dist/radio/ui-radio-group.js +259 -0
- package/dist/radio/ui-radio-group.js.map +1 -0
- package/dist/radio/ui-radio.html +11 -0
- package/dist/radio/ui-radio.js +55 -0
- package/dist/radio/ui-radio.js.map +1 -0
- package/dist/segmented-control/ui-segment.html +10 -0
- package/dist/segmented-control/ui-segment.js +44 -0
- package/dist/segmented-control/ui-segment.js.map +1 -0
- package/dist/segmented-control/ui-segmented-control.html +9 -0
- package/dist/segmented-control/ui-segmented-control.js +134 -0
- package/dist/segmented-control/ui-segmented-control.js.map +1 -0
- package/dist/select/enhance-ui-select.js +26 -0
- package/dist/select/enhance-ui-select.js.map +1 -0
- package/dist/select/ui-select.html +70 -0
- package/dist/select/ui-select.js +323 -0
- package/dist/select/ui-select.js.map +1 -0
- package/dist/slider/ui-slider.html +69 -0
- package/dist/slider/ui-slider.js +362 -0
- package/dist/slider/ui-slider.js.map +1 -0
- package/dist/splitter/ui-splitter.html +14 -0
- package/dist/splitter/ui-splitter.js +257 -0
- package/dist/splitter/ui-splitter.js.map +1 -0
- package/dist/switch/ui-switch.html +23 -0
- package/dist/switch/ui-switch.js +121 -0
- package/dist/switch/ui-switch.js.map +1 -0
- package/dist/table/enhance-ui-table.js +25 -0
- package/dist/table/enhance-ui-table.js.map +1 -0
- package/dist/table/ui-table-column.html +17 -0
- package/dist/table/ui-table-column.js +127 -0
- package/dist/table/ui-table-column.js.map +1 -0
- package/dist/table/ui-table.html +56 -0
- package/dist/table/ui-table.js +225 -0
- package/dist/table/ui-table.js.map +1 -0
- package/dist/tabs/ui-tab.html +10 -0
- package/dist/tabs/ui-tab.js +52 -0
- package/dist/tabs/ui-tab.js.map +1 -0
- package/dist/tabs/ui-tabs.html +3 -0
- package/dist/tabs/ui-tabs.js +112 -0
- package/dist/tabs/ui-tabs.js.map +1 -0
- package/dist/toast/ui-toast-region.html +11 -0
- package/dist/toast/ui-toast-region.js +38 -0
- package/dist/toast/ui-toast-region.js.map +1 -0
- package/dist/toast/ui-toast-service.js +70 -0
- package/dist/toast/ui-toast-service.js.map +1 -0
- package/dist/tooltip/ui-tooltip-service.js +63 -0
- package/dist/tooltip/ui-tooltip-service.js.map +1 -0
- package/dist/tooltip/ui-tooltip.js +221 -0
- package/dist/tooltip/ui-tooltip.js.map +1 -0
- package/dist/top-app-bar/ui-top-app-bar.html +24 -0
- package/dist/top-app-bar/ui-top-app-bar.js +68 -0
- package/dist/top-app-bar/ui-top-app-bar.js.map +1 -0
- package/dist/tree/ui-tree.html +38 -0
- package/dist/tree/ui-tree.js +340 -0
- package/dist/tree/ui-tree.js.map +1 -0
- package/dist/types/alert/ui-alert.d.ts +11 -0
- package/dist/types/alert-service/alert-configuration.d.ts +8 -0
- package/dist/types/alert-service/alert-modal/alert-modal.d.ts +7 -0
- package/dist/types/alert-service/alert-modal/i-alert-modal-payload.d.ts +14 -0
- package/dist/types/alert-service/alert-service.d.ts +17 -0
- package/dist/types/alert-service/decorators/confirm-action.d.ts +3 -0
- package/dist/types/alert-service/decorators/using-progress.d.ts +6 -0
- package/dist/types/alert-service/exceptions-tracker.d.ts +3 -0
- package/dist/types/alert-service/prompt-dialog/prompt-dialog.d.ts +17 -0
- package/dist/types/badge/ui-badge.d.ts +7 -0
- package/dist/types/base/boolean-attr.d.ts +1 -0
- package/dist/types/base/i-validated-element.d.ts +10 -0
- package/dist/types/base/keys.d.ts +12 -0
- package/dist/types/breadcrumbs/ui-breadcrumbs.d.ts +8 -0
- package/dist/types/button/enhance-ui-button.d.ts +3 -0
- package/dist/types/button/ui-button.d.ts +16 -0
- package/dist/types/button/ui-icon-button.d.ts +18 -0
- package/dist/types/checkbox/ui-checkbox.d.ts +32 -0
- package/dist/types/chip/ui-chip.d.ts +26 -0
- package/dist/types/combobox/enhance-ui-combobox.d.ts +3 -0
- package/dist/types/combobox/ui-combobox.d.ts +79 -0
- package/dist/types/disclosure/ui-disclosure.d.ts +18 -0
- package/dist/types/drawer/ui-drawer.d.ts +38 -0
- package/dist/types/index.d.ts +91 -0
- package/dist/types/input/enhance-ui-input.d.ts +3 -0
- package/dist/types/input/ui-input.d.ts +44 -0
- package/dist/types/list/ui-list-item.d.ts +10 -0
- package/dist/types/list/ui-list.d.ts +45 -0
- package/dist/types/menu/ui-menu.d.ts +29 -0
- package/dist/types/popup/ui-popup.d.ts +61 -0
- package/dist/types/progress/ui-progress.d.ts +15 -0
- package/dist/types/radio/ui-radio-group.d.ts +37 -0
- package/dist/types/radio/ui-radio.d.ts +11 -0
- package/dist/types/segmented-control/ui-segment.d.ts +8 -0
- package/dist/types/segmented-control/ui-segmented-control.d.ts +17 -0
- package/dist/types/select/enhance-ui-select.d.ts +3 -0
- package/dist/types/select/ui-select.d.ts +50 -0
- package/dist/types/slider/ui-slider.d.ts +58 -0
- package/dist/types/splitter/ui-splitter.d.ts +39 -0
- package/dist/types/switch/ui-switch.d.ts +23 -0
- package/dist/types/table/enhance-ui-table.d.ts +3 -0
- package/dist/types/table/ui-table-column.d.ts +22 -0
- package/dist/types/table/ui-table.d.ts +51 -0
- package/dist/types/tabs/ui-tab.d.ts +10 -0
- package/dist/types/tabs/ui-tabs.d.ts +16 -0
- package/dist/types/toast/ui-toast-region.d.ts +6 -0
- package/dist/types/toast/ui-toast-service.d.ts +28 -0
- package/dist/types/tooltip/ui-tooltip-service.d.ts +23 -0
- package/dist/types/tooltip/ui-tooltip.d.ts +35 -0
- package/dist/types/top-app-bar/ui-top-app-bar.d.ts +9 -0
- package/dist/types/tree/ui-tree.d.ts +70 -0
- package/dist/types/validation/ui-validation-controller-factory.d.ts +7 -0
- package/dist/types/validation/ui-validation-result-presenter.d.ts +4 -0
- package/dist/types/validation/validate.d.ts +13 -0
- package/dist/validation/ui-validation-controller-factory.js +17 -0
- package/dist/validation/ui-validation-controller-factory.js.map +1 -0
- package/dist/validation/ui-validation-result-presenter.js +23 -0
- package/dist/validation/ui-validation-result-presenter.js.map +1 -0
- package/dist/validation/validate.js +24 -0
- package/dist/validation/validate.js.map +1 -0
- package/package.json +50 -0
- package/src/alert/ui-alert.html +19 -0
- package/src/alert/ui-alert.ts +33 -0
- package/src/alert-service/alert-configuration.ts +11 -0
- package/src/alert-service/alert-modal/alert-modal.html +12 -0
- package/src/alert-service/alert-modal/alert-modal.ts +19 -0
- package/src/alert-service/alert-modal/i-alert-modal-payload.ts +14 -0
- package/src/alert-service/alert-service.ts +116 -0
- package/src/alert-service/decorators/confirm-action.ts +18 -0
- package/src/alert-service/decorators/using-progress.ts +32 -0
- package/src/alert-service/exceptions-tracker.ts +3 -0
- package/src/alert-service/prompt-dialog/prompt-dialog.html +13 -0
- package/src/alert-service/prompt-dialog/prompt-dialog.ts +37 -0
- package/src/badge/ui-badge.html +6 -0
- package/src/badge/ui-badge.ts +17 -0
- package/src/base/boolean-attr.ts +3 -0
- package/src/base/i-validated-element.ts +11 -0
- package/src/base/keys.ts +12 -0
- package/src/breadcrumbs/ui-breadcrumbs.html +10 -0
- package/src/breadcrumbs/ui-breadcrumbs.ts +14 -0
- package/src/button/enhance-ui-button.ts +9 -0
- package/src/button/ui-button.html +20 -0
- package/src/button/ui-button.ts +60 -0
- package/src/button/ui-icon-button.html +20 -0
- package/src/button/ui-icon-button.ts +62 -0
- package/src/checkbox/ui-checkbox.html +32 -0
- package/src/checkbox/ui-checkbox.ts +188 -0
- package/src/chip/ui-chip.html +32 -0
- package/src/chip/ui-chip.ts +118 -0
- package/src/combobox/enhance-ui-combobox.ts +10 -0
- package/src/combobox/ui-combobox.html +76 -0
- package/src/combobox/ui-combobox.ts +450 -0
- package/src/disclosure/ui-disclosure.html +28 -0
- package/src/disclosure/ui-disclosure.ts +68 -0
- package/src/drawer/ui-drawer.html +35 -0
- package/src/drawer/ui-drawer.ts +219 -0
- package/src/index.ts +152 -0
- package/src/input/enhance-ui-input.ts +10 -0
- package/src/input/ui-input.html +56 -0
- package/src/input/ui-input.ts +225 -0
- package/src/list/ui-list-item.html +22 -0
- package/src/list/ui-list-item.ts +25 -0
- package/src/list/ui-list.html +10 -0
- package/src/list/ui-list.ts +330 -0
- package/src/menu/ui-menu.html +20 -0
- package/src/menu/ui-menu.ts +103 -0
- package/src/popup/ui-popup.html +16 -0
- package/src/popup/ui-popup.ts +391 -0
- package/src/progress/ui-progress.html +17 -0
- package/src/progress/ui-progress.ts +51 -0
- package/src/radio/ui-radio-group.html +27 -0
- package/src/radio/ui-radio-group.ts +250 -0
- package/src/radio/ui-radio.html +11 -0
- package/src/radio/ui-radio.ts +35 -0
- package/src/resource.d.ts +4 -0
- package/src/segmented-control/ui-segment.html +10 -0
- package/src/segmented-control/ui-segment.ts +20 -0
- package/src/segmented-control/ui-segmented-control.html +9 -0
- package/src/segmented-control/ui-segmented-control.ts +119 -0
- package/src/select/enhance-ui-select.ts +10 -0
- package/src/select/ui-select.html +70 -0
- package/src/select/ui-select.ts +294 -0
- package/src/slider/ui-slider.html +69 -0
- package/src/slider/ui-slider.ts +329 -0
- package/src/splitter/ui-splitter.html +14 -0
- package/src/splitter/ui-splitter.ts +249 -0
- package/src/switch/ui-switch.html +23 -0
- package/src/switch/ui-switch.ts +121 -0
- package/src/table/enhance-ui-table.ts +9 -0
- package/src/table/ui-table-column.html +17 -0
- package/src/table/ui-table-column.ts +108 -0
- package/src/table/ui-table.html +56 -0
- package/src/table/ui-table.ts +209 -0
- package/src/tabs/ui-tab.html +10 -0
- package/src/tabs/ui-tab.ts +30 -0
- package/src/tabs/ui-tabs.html +3 -0
- package/src/tabs/ui-tabs.ts +105 -0
- package/src/toast/ui-toast-region.html +11 -0
- package/src/toast/ui-toast-region.ts +18 -0
- package/src/toast/ui-toast-service.ts +100 -0
- package/src/tooltip/ui-tooltip-service.ts +84 -0
- package/src/tooltip/ui-tooltip.ts +200 -0
- package/src/top-app-bar/ui-top-app-bar.html +24 -0
- package/src/top-app-bar/ui-top-app-bar.ts +27 -0
- package/src/tree/ui-tree.html +38 -0
- package/src/tree/ui-tree.ts +363 -0
- package/src/validation/ui-validation-controller-factory.ts +20 -0
- package/src/validation/ui-validation-result-presenter.ts +26 -0
- 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 @@
|
|
|
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 @@
|
|
|
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,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 @@
|
|
|
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 @@
|
|
|
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"]}
|