@acorex/components 7.17.22 → 7.17.23
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/check-box/lib/check-box.component.d.ts +3 -3
- package/common/lib/classes/components.class.d.ts +11 -0
- package/common/lib/components/value-component.class.d.ts +10 -4
- package/esm2022/calendar/lib/calendar-range.component.mjs +1 -2
- package/esm2022/calendar/lib/calendar.component.mjs +10 -2
- package/esm2022/check-box/lib/check-box.component.mjs +9 -4
- package/esm2022/color-palette/lib/color-palette.component.mjs +4 -2
- package/esm2022/common/lib/classes/components.class.mjs +1 -1
- package/esm2022/common/lib/components/value-component.class.mjs +38 -65
- package/esm2022/data-pager/lib/data-pager.component.mjs +1 -2
- package/esm2022/form/index.mjs +2 -3
- package/esm2022/form/lib/form-field.component.mjs +34 -6
- package/esm2022/form/lib/form.component.mjs +44 -86
- package/esm2022/form/lib/form.config.mjs +3 -23
- package/esm2022/form/lib/form.module.mjs +9 -8
- package/esm2022/form/lib/validation-rule.directive.mjs +33 -0
- package/esm2022/form/lib/validation-summary.component.mjs +19 -13
- package/esm2022/label/lib/label.component.mjs +21 -10
- package/esm2022/number-box/lib/number-box.component.mjs +8 -3
- package/esm2022/otp/lib/otp.component.mjs +1 -1
- package/esm2022/password-box/lib/password-box.component.mjs +4 -2
- package/esm2022/radio/lib/radio.component.mjs +2 -2
- package/esm2022/select-box/lib/select-box.component.mjs +1 -2
- package/esm2022/selection-list/lib/selection-list.component.mjs +8 -8
- package/fesm2022/acorex-components-calendar.mjs +9 -2
- package/fesm2022/acorex-components-calendar.mjs.map +1 -1
- package/fesm2022/acorex-components-check-box.mjs +8 -3
- package/fesm2022/acorex-components-check-box.mjs.map +1 -1
- package/fesm2022/acorex-components-color-palette.mjs +3 -1
- package/fesm2022/acorex-components-color-palette.mjs.map +1 -1
- package/fesm2022/acorex-components-common.mjs +36 -63
- package/fesm2022/acorex-components-common.mjs.map +1 -1
- package/fesm2022/acorex-components-data-pager.mjs +0 -1
- package/fesm2022/acorex-components-data-pager.mjs.map +1 -1
- package/fesm2022/acorex-components-form.mjs +135 -250
- package/fesm2022/acorex-components-form.mjs.map +1 -1
- package/fesm2022/acorex-components-label.mjs +19 -8
- package/fesm2022/acorex-components-label.mjs.map +1 -1
- package/fesm2022/acorex-components-number-box.mjs +7 -2
- package/fesm2022/acorex-components-number-box.mjs.map +1 -1
- package/fesm2022/acorex-components-otp.mjs.map +1 -1
- package/fesm2022/acorex-components-password-box.mjs +3 -1
- package/fesm2022/acorex-components-password-box.mjs.map +1 -1
- package/fesm2022/acorex-components-radio.mjs +1 -1
- package/fesm2022/acorex-components-radio.mjs.map +1 -1
- package/fesm2022/acorex-components-select-box.mjs +0 -1
- package/fesm2022/acorex-components-select-box.mjs.map +1 -1
- package/fesm2022/acorex-components-selection-list.mjs +6 -6
- package/fesm2022/acorex-components-selection-list.mjs.map +1 -1
- package/form/index.d.ts +1 -2
- package/form/lib/form-field.component.d.ts +8 -2
- package/form/lib/form.component.d.ts +9 -13
- package/form/lib/form.config.d.ts +0 -10
- package/form/lib/form.module.d.ts +3 -2
- package/form/lib/validation-rule.directive.d.ts +16 -0
- package/form/lib/validation-summary.component.d.ts +8 -5
- package/label/lib/label.component.d.ts +6 -6
- package/package.json +7 -7
- package/selection-list/lib/selection-list.component.d.ts +2 -2
- package/esm2022/form/lib/validation-rule.widget.mjs +0 -124
- package/esm2022/form/lib/validation.class.mjs +0 -2
- package/form/lib/validation-rule.widget.d.ts +0 -23
- package/form/lib/validation.class.d.ts +0 -18
@@ -1,5 +1,5 @@
|
|
1
|
-
import { AXEvent, MXBaseComponent } from '@acorex/components/common';
|
2
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation, } from '@angular/core';
|
1
|
+
import { AXEvent, AXValuableComponent, MXBaseComponent } from '@acorex/components/common';
|
2
|
+
import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, Output, QueryList, ViewEncapsulation, } from '@angular/core';
|
3
3
|
import * as i0 from "@angular/core";
|
4
4
|
/**
|
5
5
|
* Contains native event
|
@@ -8,7 +8,7 @@ import * as i0 from "@angular/core";
|
|
8
8
|
export class AXFormValidationEvent extends AXEvent {
|
9
9
|
}
|
10
10
|
/**
|
11
|
-
* The
|
11
|
+
* The AXForm is a component which detects user interaction and triggers a corresponding event
|
12
12
|
*
|
13
13
|
* @category Components
|
14
14
|
*/
|
@@ -19,7 +19,6 @@ export class AXFormComponent extends MXBaseComponent {
|
|
19
19
|
this.onValidate = new EventEmitter();
|
20
20
|
this.updateOnChange = new EventEmitter();
|
21
21
|
this._updateOn = 'blur';
|
22
|
-
this.validateInitValues = false;
|
23
22
|
this._subs = [];
|
24
23
|
}
|
25
24
|
get updateOn() {
|
@@ -30,92 +29,55 @@ export class AXFormComponent extends MXBaseComponent {
|
|
30
29
|
name: 'updateOn',
|
31
30
|
value: v,
|
32
31
|
afterCallback: () => {
|
33
|
-
this._bindEvents();
|
32
|
+
//this._bindEvents();
|
34
33
|
},
|
35
34
|
});
|
36
35
|
}
|
37
|
-
_handleSubmit(e) {
|
36
|
+
async _handleSubmit(e) {
|
38
37
|
e.preventDefault();
|
39
|
-
this.validate();
|
38
|
+
await this.validate();
|
40
39
|
}
|
41
40
|
_handleReset() {
|
42
41
|
this.clear();
|
43
42
|
}
|
44
|
-
_getComponenets() {
|
45
|
-
return Array.from(this.getHostElement().querySelectorAll('[ax-form-input="true"]'))
|
46
|
-
.map((c) => c.__axContext__)
|
47
|
-
.filter((c) => c != null);
|
48
|
-
}
|
49
43
|
ngAfterViewInit() {
|
50
|
-
|
51
|
-
this._validateInitValues();
|
52
|
-
}
|
53
|
-
this._bindEvents();
|
54
|
-
// const config = { attributes: false, childList: true, subtree: true };
|
55
|
-
// const callback = (mutationList, observer) => {
|
56
|
-
// this._bindEvents();
|
57
|
-
// };
|
58
|
-
// // Create an observer instance linked to the callback function
|
59
|
-
// if (typeof MutationObserver !== 'undefined') {
|
60
|
-
// this._observer = new MutationObserver(callback);
|
61
|
-
// }
|
62
|
-
// this._observer.observe(this.getHostElement(), config);
|
63
|
-
}
|
64
|
-
_bindEvents() {
|
65
|
-
this._clearSubs();
|
66
|
-
const widgets = this._getComponenets();
|
67
|
-
//
|
68
|
-
widgets.forEach((w) => {
|
69
|
-
if (this.updateOn == 'change') {
|
70
|
-
this._subs.push(w.onValueChanged?.subscribe((v) => {
|
71
|
-
if (v.isUserInteraction)
|
72
|
-
w.validate();
|
73
|
-
}));
|
74
|
-
}
|
75
|
-
else if (this.updateOn == 'blur') {
|
76
|
-
this._subs.push(w.onBlur?.subscribe((v) => {
|
77
|
-
w.validate();
|
78
|
-
}));
|
79
|
-
}
|
80
|
-
});
|
44
|
+
//this._bindEvents();
|
81
45
|
}
|
46
|
+
// private _bindEvents() {
|
47
|
+
// this._clearSubs();
|
48
|
+
// const widgets = this._getComponenets();
|
49
|
+
// //
|
50
|
+
// widgets.forEach((w) => {
|
51
|
+
// if (this.updateOn == 'change') {
|
52
|
+
// this._subs.push(
|
53
|
+
// w.onValueChanged?.subscribe((v: AXValueChangedEvent) => {
|
54
|
+
// if (v.isUserInteraction) w.validate();
|
55
|
+
// }),
|
56
|
+
// );
|
57
|
+
// } else if (this.updateOn == 'blur') {
|
58
|
+
// this._subs.push(
|
59
|
+
// w.onBlur?.subscribe((v) => {
|
60
|
+
// w.validate();
|
61
|
+
// }),
|
62
|
+
// );
|
63
|
+
// }
|
64
|
+
// });
|
65
|
+
// }
|
82
66
|
_clearSubs() {
|
83
67
|
this._subs.forEach((c) => c?.unsubscribe());
|
84
68
|
this._subs = [];
|
85
69
|
}
|
86
|
-
|
87
|
-
this.
|
88
|
-
.filter((c) => c
|
89
|
-
.
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
//
|
98
|
-
return new Promise((resolve) => {
|
99
|
-
Promise.all(widgets
|
100
|
-
.filter((c) => args == null || args.length == 0 || args.includes(c.name))
|
101
|
-
.map((c) => c.validate())).then((rules) => {
|
102
|
-
const failed = rules.filter((c) => !c.result);
|
103
|
-
if (failed.length) {
|
104
|
-
this._emitOnValidateEvent({
|
105
|
-
result: false,
|
106
|
-
items: failed,
|
107
|
-
});
|
108
|
-
resolve({
|
109
|
-
result: false,
|
110
|
-
items: failed,
|
111
|
-
});
|
112
|
-
}
|
113
|
-
else {
|
114
|
-
this._emitOnValidateEvent({ result: true });
|
115
|
-
resolve({ result: true });
|
116
|
-
}
|
117
|
-
});
|
118
|
-
});
|
70
|
+
async validate(...names) {
|
71
|
+
const results = await Promise.all(this.fields
|
72
|
+
.filter((c) => names == null || names.length == 0 || names.includes(c.name))
|
73
|
+
.map(field => field.validate()));
|
74
|
+
// Merge all validation summaries into one
|
75
|
+
const mergedSummary = {
|
76
|
+
result: results.every(res => res.result),
|
77
|
+
rules: results.flatMap(res => res.rules)
|
78
|
+
};
|
79
|
+
this._emitOnValidateEvent(mergedSummary);
|
80
|
+
return mergedSummary;
|
119
81
|
}
|
120
82
|
_emitOnValidateEvent(e) {
|
121
83
|
this.onValidate.emit({
|
@@ -125,18 +87,13 @@ export class AXFormComponent extends MXBaseComponent {
|
|
125
87
|
});
|
126
88
|
}
|
127
89
|
clear() {
|
128
|
-
|
129
|
-
widgets.forEach((w) => {
|
130
|
-
if (typeof w?.clear === 'function')
|
131
|
-
w.clear(false);
|
132
|
-
});
|
90
|
+
this.fields.forEach(c => c.clear(false));
|
133
91
|
}
|
134
92
|
ngOnDestroy() {
|
135
|
-
this._observer?.disconnect();
|
136
93
|
this._clearSubs();
|
137
94
|
}
|
138
95
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AXFormComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
139
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: AXFormComponent, selector: "ax-form", inputs: { messageStyle: "messageStyle", updateOn: "updateOn"
|
96
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: AXFormComponent, selector: "ax-form", inputs: { messageStyle: "messageStyle", updateOn: "updateOn" }, outputs: { onValidate: "onValidate", updateOnChange: "updateOnChange" }, queries: [{ propertyName: "fields", predicate: AXValuableComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: `<form
|
140
97
|
(submit)="_handleSubmit($event)"
|
141
98
|
(reset)="_handleReset()"
|
142
99
|
class="ax-{{ messageStyle }}-error"
|
@@ -166,7 +123,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
166
123
|
type: Output
|
167
124
|
}], updateOn: [{
|
168
125
|
type: Input
|
169
|
-
}],
|
170
|
-
type:
|
126
|
+
}], fields: [{
|
127
|
+
type: ContentChildren,
|
128
|
+
args: [AXValuableComponent, { descendants: true }]
|
171
129
|
}] } });
|
172
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../libs/components/form/src/lib/form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXEvent, AXValueChangedEvent, MXBaseComponent } from '@acorex/components/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { AXFormValidationResult } from './validation.class';\n\n/**\n *  Contains native event\n * @category Events\n */\nexport class AXFormValidationEvent extends AXEvent {\n  result: AXFormValidationResult;\n}\n\n/**\n *  Contains native event\n * @category Events\n */\nexport type AXFormUpdateOn = 'change' | 'blur' | 'submit';\nexport type AXFormMessageStyle = 'bottom' | 'float';\n\n/**\n * The Button is a component which detects user interaction and triggers a corresponding event\n *\n * @category Components\n */\n@Component({\n  selector: 'ax-form',\n  template: `<form\n    (submit)=\"_handleSubmit($event)\"\n    (reset)=\"_handleReset()\"\n    class=\"ax-{{ messageStyle }}-error\"\n  >\n    <ng-content></ng-content>\n  </form>`,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AXFormComponent extends MXBaseComponent implements AfterViewInit, OnDestroy {\n  @Input()\n  messageStyle: AXFormMessageStyle = 'bottom';\n\n  @Output()\n  onValidate: EventEmitter<AXFormValidationEvent> = new EventEmitter<AXFormValidationEvent>();\n\n  @Output()\n  updateOnChange: EventEmitter<AXFormUpdateOn> = new EventEmitter<AXFormUpdateOn>();\n\n  private _updateOn: AXFormUpdateOn = 'blur';\n  @Input()\n  public get updateOn(): AXFormUpdateOn {\n    return this._updateOn;\n  }\n  public set updateOn(v: AXFormUpdateOn) {\n    this.setOption({\n      name: 'updateOn',\n      value: v,\n      afterCallback: () => {\n        this._bindEvents();\n      },\n    });\n  }\n\n  @Input()\n  validateInitValues = false;\n\n  private _observer?: MutationObserver;\n  private _subs: Subscription[] = [];\n\n  protected _handleSubmit(e: SubmitEvent) {\n    e.preventDefault();\n    this.validate();\n  }\n\n  protected _handleReset() {\n    this.clear();\n  }\n\n  private _getComponenets() {\n    return Array.from(this.getHostElement().querySelectorAll('[ax-form-input=\"true\"]'))\n      .map((c) => (c as any).__axContext__)\n      .filter((c) => c != null);\n  }\n\n  ngAfterViewInit(): void {\n    if (this.validateInitValues) {\n      this._validateInitValues();\n    }\n    this._bindEvents();\n\n    // const config = { attributes: false, childList: true, subtree: true };\n    // const callback = (mutationList, observer) => {\n    //   this._bindEvents();\n    // };\n\n    // // Create an observer instance linked to the callback function\n    // if (typeof MutationObserver !== 'undefined') {\n    //   this._observer = new MutationObserver(callback);\n    // }\n\n    // this._observer.observe(this.getHostElement(), config);\n  }\n\n  private _bindEvents() {\n    this._clearSubs();\n    const widgets = this._getComponenets();\n    //\n    widgets.forEach((w) => {\n      if (this.updateOn == 'change') {\n        this._subs.push(\n          w.onValueChanged?.subscribe((v: AXValueChangedEvent) => {\n            if (v.isUserInteraction) w.validate();\n          }),\n        );\n      } else if (this.updateOn == 'blur') {\n        this._subs.push(\n          w.onBlur?.subscribe((v) => {\n            w.validate();\n          }),\n        );\n      }\n    });\n  }\n\n  private _clearSubs() {\n    this._subs.forEach((c) => c?.unsubscribe());\n    this._subs = [];\n  }\n\n  private _validateInitValues() {\n    this._getComponenets()\n      .filter((c) => c['value'])\n      .forEach((c) => c.validate());\n  }\n\n  validate(...args: string[]): Promise<AXFormValidationResult> {\n    const widgets = this._getComponenets();\n    if (widgets.length === 0) {\n      this._emitOnValidateEvent({ result: true });\n      return Promise.resolve({ result: true });\n    }\n    //\n    return new Promise<AXFormValidationResult>((resolve) => {\n      Promise.all(\n        widgets\n          .filter((c) => args == null || args.length == 0 || args.includes(c.name))\n          .map((c) => c.validate()),\n      ).then((rules: any) => {\n        const failed = rules.filter((c: any) => !c.result);\n        if (failed.length) {\n          this._emitOnValidateEvent({\n            result: false,\n            items: failed,\n          });\n          resolve({\n            result: false,\n            items: failed,\n          });\n        } else {\n          this._emitOnValidateEvent({ result: true });\n          resolve({ result: true });\n        }\n      });\n    });\n  }\n\n  private _emitOnValidateEvent(e: AXFormValidationResult) {\n    this.onValidate.emit({\n      component: this,\n      result: e,\n      htmlElement: this.getHostElement(),\n    });\n  }\n\n  clear() {\n    const widgets = this._getComponenets();\n    widgets.forEach((w) => {\n      if (typeof w?.clear === 'function') w.clear(false);\n    });\n  }\n\n  ngOnDestroy(): void {\n    this._observer?.disconnect();\n    this._clearSubs();\n  }\n}\n"]}
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../libs/components/form/src/lib/form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXEvent, AXValuableComponent, MXBaseComponent } from '@acorex/components/common';\nimport { AXValidationSummary } from '@acorex/core/validation';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  QueryList,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\n\n/**\n *  Contains native event\n * @category Events\n */\nexport class AXFormValidationEvent extends AXEvent {\n  result: AXValidationSummary;\n}\n\n/**\n *  Contains native event\n * @category Events\n */\nexport type AXFormUpdateOn = 'change' | 'blur' | 'submit';\nexport type AXFormMessageStyle = 'bottom' | 'float';\n\n/**\n * The AXForm is a component which detects user interaction and triggers a corresponding event\n *\n * @category Components\n */\n@Component({\n  selector: 'ax-form',\n  template: `<form\n    (submit)=\"_handleSubmit($event)\"\n    (reset)=\"_handleReset()\"\n    class=\"ax-{{ messageStyle }}-error\"\n  >\n    <ng-content></ng-content>\n  </form>`,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AXFormComponent extends MXBaseComponent implements AfterViewInit, OnDestroy {\n  @Input()\n  messageStyle: AXFormMessageStyle = 'bottom';\n\n  @Output()\n  onValidate: EventEmitter<AXFormValidationEvent> = new EventEmitter<AXFormValidationEvent>();\n\n  @Output()\n  updateOnChange: EventEmitter<AXFormUpdateOn> = new EventEmitter<AXFormUpdateOn>();\n\n  private _updateOn: AXFormUpdateOn = 'blur';\n  @Input()\n  public get updateOn(): AXFormUpdateOn {\n    return this._updateOn;\n  }\n  public set updateOn(v: AXFormUpdateOn) {\n    this.setOption({\n      name: 'updateOn',\n      value: v,\n      afterCallback: () => {\n        //this._bindEvents();\n      },\n    });\n  }\n\n  private _subs: Subscription[] = [];\n\n  protected async _handleSubmit(e: SubmitEvent) {\n    e.preventDefault();\n    await this.validate();\n  }\n\n  protected _handleReset() {\n    this.clear();\n  }\n\n  ngAfterViewInit(): void {\n    //this._bindEvents();\n  }\n\n  // private _bindEvents() {\n  //   this._clearSubs();\n  //   const widgets = this._getComponenets();\n  //   //\n  //   widgets.forEach((w) => {\n  //     if (this.updateOn == 'change') {\n  //       this._subs.push(\n  //         w.onValueChanged?.subscribe((v: AXValueChangedEvent) => {\n  //           if (v.isUserInteraction) w.validate();\n  //         }),\n  //       );\n  //     } else if (this.updateOn == 'blur') {\n  //       this._subs.push(\n  //         w.onBlur?.subscribe((v) => {\n  //           w.validate();\n  //         }),\n  //       );\n  //     }\n  //   });\n  // }\n\n  private _clearSubs() {\n    this._subs.forEach((c) => c?.unsubscribe());\n    this._subs = [];\n  }\n\n  @ContentChildren(AXValuableComponent, { descendants: true }) fields: QueryList<AXValuableComponent>;\n\n  async validate(...names: string[]): Promise<AXValidationSummary> {\n    const results = await Promise.all(\n      this.fields\n        .filter((c) => names == null || names.length == 0 || names.includes(c.name))\n        .map(field => field.validate()\n        ));\n    // Merge all validation summaries into one\n    const mergedSummary: AXValidationSummary = {\n      result: results.every(res => res.result),\n      rules: results.flatMap(res => res.rules)\n    };\n    this._emitOnValidateEvent(mergedSummary);\n    return mergedSummary;\n  }\n\n  private _emitOnValidateEvent(e: AXValidationSummary) {\n    this.onValidate.emit({\n      component: this,\n      result: e,\n      htmlElement: this.getHostElement(),\n    });\n  }\n\n  clear() {\n    this.fields.forEach(c => c.clear(false));\n  }\n\n  ngOnDestroy(): void {\n    this._clearSubs();\n  }\n}\n"]}
|
@@ -1,31 +1,11 @@
|
|
1
|
-
import {
|
2
|
-
import { AXTranslator } from '@acorex/core/translation';
|
3
|
-
import { InjectionToken, inject } from '@angular/core';
|
4
|
-
import { set } from 'lodash-es';
|
1
|
+
import { InjectionToken } from '@angular/core';
|
5
2
|
export const AX_FORM_CONFIG = new InjectionToken('AX_FORM_CONFIG', {
|
6
3
|
providedIn: 'root',
|
7
4
|
factory: () => {
|
8
|
-
const global = inject(AX_GLOBAL_CONFIG);
|
9
|
-
set(global, 'form', AX_FORM_CONFIG);
|
10
5
|
return AXFormDefaultConfig;
|
11
6
|
},
|
12
7
|
});
|
13
|
-
export const AXFormDefaultConfig = {
|
14
|
-
validation: {
|
15
|
-
rules: {
|
16
|
-
email: {
|
17
|
-
rule: 'regex',
|
18
|
-
value: /^(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/,
|
19
|
-
message: AXTranslator.get('validation.messages.email'),
|
20
|
-
},
|
21
|
-
phone: {
|
22
|
-
rule: 'regex',
|
23
|
-
value: /^[+]*[(]{0,1}[0-9]{1,4}[)]{0,1}[-\s\./0-9]*$/,
|
24
|
-
message: AXTranslator.get('validation.messages.phone'),
|
25
|
-
},
|
26
|
-
},
|
27
|
-
},
|
28
|
-
};
|
8
|
+
export const AXFormDefaultConfig = {};
|
29
9
|
export function formConfig(config = {}) {
|
30
10
|
const result = {
|
31
11
|
...AXFormDefaultConfig,
|
@@ -33,4 +13,4 @@ export function formConfig(config = {}) {
|
|
33
13
|
};
|
34
14
|
return result;
|
35
15
|
}
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZm9ybS9zcmMvbGliL2Zvcm0uY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFNL0MsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLElBQUksY0FBYyxDQUFlLGdCQUFnQixFQUFFO0lBQy9FLFVBQVUsRUFBRSxNQUFNO0lBQ2xCLE9BQU8sRUFBRSxHQUFHLEVBQUU7UUFDWixPQUFPLG1CQUFtQixDQUFDO0lBQzdCLENBQUM7Q0FDRixDQUFDLENBQUM7QUFFSCxNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBaUIsRUFFaEQsQ0FBQztBQUlGLE1BQU0sVUFBVSxVQUFVLENBQUMsU0FBNEIsRUFBRTtJQUN2RCxNQUFNLE1BQU0sR0FBRztRQUNiLEdBQUcsbUJBQW1CO1FBQ3RCLEdBQUcsTUFBTTtLQUNWLENBQUM7SUFDRixPQUFPLE1BQU0sQ0FBQztBQUNoQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGludGVyZmFjZSBBWEZvcm1Db25maWcge1xuXG59XG5cbmV4cG9ydCBjb25zdCBBWF9GT1JNX0NPTkZJRyA9IG5ldyBJbmplY3Rpb25Ub2tlbjxBWEZvcm1Db25maWc+KCdBWF9GT1JNX0NPTkZJRycsIHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxuICBmYWN0b3J5OiAoKSA9PiB7XG4gICAgcmV0dXJuIEFYRm9ybURlZmF1bHRDb25maWc7XG4gIH0sXG59KTtcblxuZXhwb3J0IGNvbnN0IEFYRm9ybURlZmF1bHRDb25maWc6IEFYRm9ybUNvbmZpZyA9IHtcblxufTtcblxuZXhwb3J0IHR5cGUgUGFydGlhbEZvcm1Db25maWcgPSBQYXJ0aWFsPEFYRm9ybUNvbmZpZz47XG5cbmV4cG9ydCBmdW5jdGlvbiBmb3JtQ29uZmlnKGNvbmZpZzogUGFydGlhbEZvcm1Db25maWcgPSB7fSk6IEFYRm9ybUNvbmZpZyB7XG4gIGNvbnN0IHJlc3VsdCA9IHtcbiAgICAuLi5BWEZvcm1EZWZhdWx0Q29uZmlnLFxuICAgIC4uLmNvbmZpZyxcbiAgfTtcbiAgcmV0dXJuIHJlc3VsdDtcbn1cbiJdfQ==
|
@@ -5,16 +5,17 @@ import { CommonModule } from '@angular/common';
|
|
5
5
|
import { NgModule } from '@angular/core';
|
6
6
|
import { AXFormFieldComponent } from './form-field.component';
|
7
7
|
import { AXFormComponent } from './form.component';
|
8
|
-
import { AXValidationRuleComponent } from './validation-rule.widget';
|
9
8
|
import { AXValidationSummaryComponent } from './validation-summary.component';
|
9
|
+
import { AXValidationRuleDirective } from './validation-rule.directive';
|
10
|
+
import { AXValidationModule } from '@acorex/core/validation';
|
10
11
|
import * as i0 from "@angular/core";
|
11
12
|
export class AXFormModule {
|
12
13
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AXFormModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
13
14
|
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.0.8", ngImport: i0, type: AXFormModule, declarations: [AXFormFieldComponent,
|
14
15
|
AXFormComponent,
|
15
|
-
|
16
|
-
AXValidationSummaryComponent], imports: [CommonModule, AXDecoratorModule, AXAlertModule, AXButtonModule], exports: [AXFormFieldComponent, AXFormComponent,
|
17
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AXFormModule, imports: [CommonModule, AXDecoratorModule, AXAlertModule, AXButtonModule] }); }
|
16
|
+
AXValidationRuleDirective,
|
17
|
+
AXValidationSummaryComponent], imports: [CommonModule, AXDecoratorModule, AXAlertModule, AXButtonModule, AXValidationModule], exports: [AXFormFieldComponent, AXFormComponent, AXValidationRuleDirective, AXValidationSummaryComponent] }); }
|
18
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AXFormModule, imports: [CommonModule, AXDecoratorModule, AXAlertModule, AXButtonModule, AXValidationModule] }); }
|
18
19
|
}
|
19
20
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AXFormModule, decorators: [{
|
20
21
|
type: NgModule,
|
@@ -22,12 +23,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
22
23
|
declarations: [
|
23
24
|
AXFormFieldComponent,
|
24
25
|
AXFormComponent,
|
25
|
-
|
26
|
+
AXValidationRuleDirective,
|
26
27
|
AXValidationSummaryComponent,
|
27
28
|
],
|
28
|
-
imports: [CommonModule, AXDecoratorModule, AXAlertModule, AXButtonModule],
|
29
|
-
exports: [AXFormFieldComponent, AXFormComponent,
|
29
|
+
imports: [CommonModule, AXDecoratorModule, AXAlertModule, AXButtonModule, AXValidationModule],
|
30
|
+
exports: [AXFormFieldComponent, AXFormComponent, AXValidationRuleDirective, AXValidationSummaryComponent],
|
30
31
|
providers: [],
|
31
32
|
}]
|
32
33
|
}] });
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZm9ybS9zcmMvbGliL2Zvcm0ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDbEUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDOUQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ25ELE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQzlFLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ3hFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDOztBQWE3RCxNQUFNLE9BQU8sWUFBWTs4R0FBWixZQUFZOytHQUFaLFlBQVksaUJBVHJCLG9CQUFvQjtZQUNwQixlQUFlO1lBQ2YseUJBQXlCO1lBQ3pCLDRCQUE0QixhQUVwQixZQUFZLEVBQUUsaUJBQWlCLEVBQUUsYUFBYSxFQUFFLGNBQWMsRUFBRSxrQkFBa0IsYUFDbEYsb0JBQW9CLEVBQUUsZUFBZSxFQUFFLHlCQUF5QixFQUFFLDRCQUE0QjsrR0FHN0YsWUFBWSxZQUpiLFlBQVksRUFBRSxpQkFBaUIsRUFBRSxhQUFhLEVBQUUsY0FBYyxFQUFFLGtCQUFrQjs7MkZBSWpGLFlBQVk7a0JBWHhCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLG9CQUFvQjt3QkFDcEIsZUFBZTt3QkFDZix5QkFBeUI7d0JBQ3pCLDRCQUE0QjtxQkFDN0I7b0JBQ0QsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLGlCQUFpQixFQUFFLGFBQWEsRUFBRSxjQUFjLEVBQUUsa0JBQWtCLENBQUM7b0JBQzdGLE9BQU8sRUFBRSxDQUFDLG9CQUFvQixFQUFFLGVBQWUsRUFBRSx5QkFBeUIsRUFBRSw0QkFBNEIsQ0FBQztvQkFDekcsU0FBUyxFQUFFLEVBQUU7aUJBQ2QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBWEFsZXJ0TW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2FsZXJ0JztcbmltcG9ydCB7IEFYQnV0dG9uTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2J1dHRvbic7XG5pbXBvcnQgeyBBWERlY29yYXRvck1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9kZWNvcmF0b3JzJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQVhGb3JtRmllbGRDb21wb25lbnQgfSBmcm9tICcuL2Zvcm0tZmllbGQuY29tcG9uZW50JztcbmltcG9ydCB7IEFYRm9ybUNvbXBvbmVudCB9IGZyb20gJy4vZm9ybS5jb21wb25lbnQnO1xuaW1wb3J0IHsgQVhWYWxpZGF0aW9uU3VtbWFyeUNvbXBvbmVudCB9IGZyb20gJy4vdmFsaWRhdGlvbi1zdW1tYXJ5LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBBWFZhbGlkYXRpb25SdWxlRGlyZWN0aXZlIH0gZnJvbSAnLi92YWxpZGF0aW9uLXJ1bGUuZGlyZWN0aXZlJztcbmltcG9ydCB7IEFYVmFsaWRhdGlvbk1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29yZS92YWxpZGF0aW9uJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgQVhGb3JtRmllbGRDb21wb25lbnQsXG4gICAgQVhGb3JtQ29tcG9uZW50LFxuICAgIEFYVmFsaWRhdGlvblJ1bGVEaXJlY3RpdmUsXG4gICAgQVhWYWxpZGF0aW9uU3VtbWFyeUNvbXBvbmVudCxcbiAgXSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgQVhEZWNvcmF0b3JNb2R1bGUsIEFYQWxlcnRNb2R1bGUsIEFYQnV0dG9uTW9kdWxlLCBBWFZhbGlkYXRpb25Nb2R1bGVdLFxuICBleHBvcnRzOiBbQVhGb3JtRmllbGRDb21wb25lbnQsIEFYRm9ybUNvbXBvbmVudCwgQVhWYWxpZGF0aW9uUnVsZURpcmVjdGl2ZSwgQVhWYWxpZGF0aW9uU3VtbWFyeUNvbXBvbmVudF0sXG4gIHByb3ZpZGVyczogW10sXG59KVxuZXhwb3J0IGNsYXNzIEFYRm9ybU1vZHVsZSB7IH1cbiJdfQ==
|
@@ -0,0 +1,33 @@
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
2
|
+
import { AXValuableComponent } from '@acorex/components/common';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
import * as i1 from "@acorex/components/common";
|
5
|
+
export class AXValidationRuleDirective {
|
6
|
+
constructor(host) {
|
7
|
+
this.host = host;
|
8
|
+
}
|
9
|
+
ngOnInit() {
|
10
|
+
this.host.addValidationRule({ rule: this.rule, options: this.ruleOptions });
|
11
|
+
}
|
12
|
+
ngOnDestroy() {
|
13
|
+
this.host.removeValidationRule({ rule: this.rule, options: this.ruleOptions });
|
14
|
+
}
|
15
|
+
get ruleOptions() {
|
16
|
+
return Object.assign({ message: this.message, name: this.host.name }, this.options);
|
17
|
+
}
|
18
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AXValidationRuleDirective, deps: [{ token: i1.AXValuableComponent }], target: i0.ɵɵFactoryTarget.Directive }); }
|
19
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.8", type: AXValidationRuleDirective, selector: "ax-validation-rule", inputs: { rule: "rule", options: "options", message: "message" }, ngImport: i0 }); }
|
20
|
+
}
|
21
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AXValidationRuleDirective, decorators: [{
|
22
|
+
type: Directive,
|
23
|
+
args: [{
|
24
|
+
selector: 'ax-validation-rule'
|
25
|
+
}]
|
26
|
+
}], ctorParameters: () => [{ type: i1.AXValuableComponent }], propDecorators: { rule: [{
|
27
|
+
type: Input
|
28
|
+
}], options: [{
|
29
|
+
type: Input
|
30
|
+
}], message: [{
|
31
|
+
type: Input
|
32
|
+
}] } });
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1ydWxlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9mb3JtL3NyYy9saWIvdmFsaWRhdGlvbi1ydWxlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFDcEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sMkJBQTJCLENBQUE7OztBQU0vRCxNQUFNLE9BQU8seUJBQXlCO0lBTXBDLFlBQW9CLElBQXlCO1FBQXpCLFNBQUksR0FBSixJQUFJLENBQXFCO0lBQUksQ0FBQztJQUVsRCxRQUFRO1FBQ04sSUFBSSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztJQUM5RSxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxJQUFJLENBQUMsb0JBQW9CLENBQUMsRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUksRUFBRSxPQUFPLEVBQUUsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLENBQUM7SUFDakYsQ0FBQztJQUVELElBQVksV0FBVztRQUNyQixPQUFPLE1BQU0sQ0FBQyxNQUFNLENBQUMsRUFBRSxPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDdEYsQ0FBQzs4R0FsQlUseUJBQXlCO2tHQUF6Qix5QkFBeUI7OzJGQUF6Qix5QkFBeUI7a0JBSHJDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG9CQUFvQjtpQkFDL0I7d0ZBR1UsSUFBSTtzQkFBWixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0LCBPbkRlc3Ryb3ksIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQVhWYWx1YWJsZUNvbXBvbmVudCB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9jb21tb24nXG5pbXBvcnQgeyBBWFZhbGlkYXRpb25SdWxlT3B0aW9ucyB9IGZyb20gJ0BhY29yZXgvY29yZS92YWxpZGF0aW9uJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnYXgtdmFsaWRhdGlvbi1ydWxlJ1xufSlcbmV4cG9ydCBjbGFzcyBBWFZhbGlkYXRpb25SdWxlRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuXG4gIEBJbnB1dCgpIHJ1bGU6IHN0cmluZztcbiAgQElucHV0KCkgb3B0aW9uczogT21pdDxBWFZhbGlkYXRpb25SdWxlT3B0aW9ucywgJ21lc3NhZ2UnPjtcbiAgQElucHV0KCkgbWVzc2FnZTogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgaG9zdDogQVhWYWx1YWJsZUNvbXBvbmVudCkgeyB9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5ob3N0LmFkZFZhbGlkYXRpb25SdWxlKHsgcnVsZTogdGhpcy5ydWxlLCBvcHRpb25zOiB0aGlzLnJ1bGVPcHRpb25zIH0pO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy5ob3N0LnJlbW92ZVZhbGlkYXRpb25SdWxlKHsgcnVsZTogdGhpcy5ydWxlLCBvcHRpb25zOiB0aGlzLnJ1bGVPcHRpb25zIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBnZXQgcnVsZU9wdGlvbnMoKTogQVhWYWxpZGF0aW9uUnVsZU9wdGlvbnMge1xuICAgIHJldHVybiBPYmplY3QuYXNzaWduKHsgbWVzc2FnZTogdGhpcy5tZXNzYWdlLCBuYW1lOiB0aGlzLmhvc3QubmFtZSB9LCB0aGlzLm9wdGlvbnMpO1xuICB9XG59XG4iXX0=
|
@@ -17,25 +17,28 @@ export class AXValidationSummaryComponent extends MXBaseComponent {
|
|
17
17
|
set title(v) {
|
18
18
|
this._title = v;
|
19
19
|
}
|
20
|
-
constructor(_tosatService,
|
20
|
+
constructor(_tosatService, host) {
|
21
21
|
super();
|
22
22
|
this._tosatService = _tosatService;
|
23
|
-
this.
|
24
|
-
this._content =
|
23
|
+
this.host = host;
|
24
|
+
this._content = null;
|
25
25
|
this._title = AXTranslator.get('validation.messages.title');
|
26
26
|
this.displayMode = 'toast';
|
27
27
|
this.autoHide = false;
|
28
28
|
//
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
29
|
+
this.sub = host.onValidate
|
30
|
+
.subscribe((e) => {
|
31
|
+
if (!e.result.result) {
|
32
|
+
const failedRules = e.result.rules.filter(c => !c.result && c.message);
|
33
|
+
this._content = `<ul>${failedRules.map((c) => `<li>${c.message}</li>`).join('')}</ul>`;
|
34
|
+
this._timeOut = this.autoHide ? (this.timeOut ?? Math.max(failedRules.length * 1000, 2000)) : 0;
|
33
35
|
//
|
34
36
|
if (this.displayMode == 'toast') {
|
35
37
|
this._tosatService.show({
|
36
38
|
color: 'danger',
|
37
39
|
closeButton: true,
|
38
40
|
timeOut: this._timeOut,
|
41
|
+
timeOutProgress: true,
|
39
42
|
content: this._content,
|
40
43
|
title: this.title,
|
41
44
|
location: 'bottom-center',
|
@@ -43,13 +46,16 @@ export class AXValidationSummaryComponent extends MXBaseComponent {
|
|
43
46
|
}
|
44
47
|
}
|
45
48
|
else {
|
46
|
-
this._content =
|
49
|
+
this._content = null;
|
47
50
|
}
|
48
51
|
this.cdr.markForCheck();
|
49
52
|
});
|
50
53
|
}
|
51
|
-
_handleOnDismissed(
|
52
|
-
this._content =
|
54
|
+
_handleOnDismissed() {
|
55
|
+
this._content = null;
|
56
|
+
}
|
57
|
+
ngOnDestroy() {
|
58
|
+
this.sub?.unsubscribe();
|
53
59
|
}
|
54
60
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AXValidationSummaryComponent, deps: [{ token: i1.AXToastService }, { token: AXFormComponent, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
55
61
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: AXValidationSummaryComponent, selector: "ax-validation-summary", inputs: { title: "title", displayMode: "displayMode", timeOut: "timeOut", autoHide: "autoHide" }, usesInheritance: true, ngImport: i0, template: `
|
@@ -58,7 +64,7 @@ export class AXValidationSummaryComponent extends MXBaseComponent {
|
|
58
64
|
*ngIf="displayMode === 'alert' && _content"
|
59
65
|
[timeOut]="_timeOut"
|
60
66
|
#a
|
61
|
-
(onClosed)="_handleOnDismissed(
|
67
|
+
(onClosed)="_handleOnDismissed()"
|
62
68
|
>
|
63
69
|
<ax-icon></ax-icon>
|
64
70
|
<ax-title>{{ title }}</ax-title>
|
@@ -83,7 +89,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
83
89
|
*ngIf="displayMode === 'alert' && _content"
|
84
90
|
[timeOut]="_timeOut"
|
85
91
|
#a
|
86
|
-
(onClosed)="_handleOnDismissed(
|
92
|
+
(onClosed)="_handleOnDismissed()"
|
87
93
|
>
|
88
94
|
<ax-icon></ax-icon>
|
89
95
|
<ax-title>{{ title }}</ax-title>
|
@@ -114,4 +120,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
114
120
|
}], autoHide: [{
|
115
121
|
type: Input
|
116
122
|
}] } });
|
117
|
-
//# sourceMappingURL=data:application/json;base64,
|
123
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1zdW1tYXJ5LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9mb3JtL3NyYy9saWIvdmFsaWRhdGlvbi1zdW1tYXJ5LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDNUQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzFELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUN4RCxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxNQUFNLEVBQ04sS0FBSyxFQUVMLFFBQVEsRUFDUixpQkFBaUIsR0FDbEIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGVBQWUsRUFBeUIsTUFBTSxrQkFBa0IsQ0FBQzs7Ozs7Ozs7QUE4QjFFLE1BQU0sT0FBTyw0QkFBNkIsU0FBUSxlQUFlO0lBSS9ELElBQ1csS0FBSztRQUNkLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUNyQixDQUFDO0lBQ0QsSUFBVyxLQUFLLENBQUMsQ0FBUztRQUN4QixJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQztJQUNsQixDQUFDO0lBZUQsWUFDVSxhQUE2QixFQUc3QixJQUFxQjtRQUU3QixLQUFLLEVBQUUsQ0FBQztRQUxBLGtCQUFhLEdBQWIsYUFBYSxDQUFnQjtRQUc3QixTQUFJLEdBQUosSUFBSSxDQUFpQjtRQTVCckIsYUFBUSxHQUFZLElBQUksQ0FBQztRQUMzQixXQUFNLEdBQVcsWUFBWSxDQUFDLEdBQUcsQ0FBQywyQkFBMkIsQ0FBQyxDQUFDO1FBV3ZFLGdCQUFXLEdBQW1DLE9BQU8sQ0FBQztRQU10RCxhQUFRLEdBQUcsS0FBSyxDQUFDO1FBYWYsRUFBRTtRQUNGLElBQUksQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLFVBQVU7YUFDdkIsU0FBUyxDQUFDLENBQUMsQ0FBd0IsRUFBRSxFQUFFO1lBQ3RDLElBQUksQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRTtnQkFDcEIsTUFBTSxXQUFXLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxJQUFJLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQztnQkFDdkUsSUFBSSxDQUFDLFFBQVEsR0FBRyxPQUFPLFdBQVcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDLE9BQU8sT0FBTyxDQUFDLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUM7Z0JBQ3ZGLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxJQUFJLElBQUksQ0FBQyxHQUFHLENBQUMsV0FBVyxDQUFDLE1BQU0sR0FBRyxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO2dCQUNoRyxFQUFFO2dCQUNGLElBQUksSUFBSSxDQUFDLFdBQVcsSUFBSSxPQUFPLEVBQUU7b0JBQy9CLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDO3dCQUN0QixLQUFLLEVBQUUsUUFBUTt3QkFDZixXQUFXLEVBQUUsSUFBSTt3QkFDakIsT0FBTyxFQUFFLElBQUksQ0FBQyxRQUFRO3dCQUN0QixlQUFlLEVBQUUsSUFBSTt3QkFDckIsT0FBTyxFQUFFLElBQUksQ0FBQyxRQUFRO3dCQUN0QixLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUs7d0JBQ2pCLFFBQVEsRUFBRSxlQUFlO3FCQUMxQixDQUFDLENBQUM7aUJBQ0o7YUFDRjtpQkFBTTtnQkFDTCxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQzthQUN0QjtZQUNELElBQUksQ0FBQyxHQUFHLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDMUIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRVMsa0JBQWtCO1FBQzFCLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO0lBQ3ZCLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLEdBQUcsRUFBRSxXQUFXLEVBQUUsQ0FBQztJQUMxQixDQUFDOzhHQWhFVSw0QkFBNEIsZ0RBNEI3QixlQUFlO2tHQTVCZCw0QkFBNEIsc0xBdkI3Qjs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW1CVDs7MkZBSVUsNEJBQTRCO2tCQXpCeEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsdUJBQXVCO29CQUNqQyxRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FtQlQ7b0JBQ0QsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO2lCQUN0Qzs7MEJBNEJJLFFBQVE7OzBCQUNSLE1BQU07MkJBQUMsZUFBZTt5Q0F2QmQsS0FBSztzQkFEZixLQUFLO2dCQVNOLFdBQVc7c0JBRFYsS0FBSztnQkFJTixPQUFPO3NCQUROLEtBQUs7Z0JBSU4sUUFBUTtzQkFEUCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTVhCYXNlQ29tcG9uZW50IH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2NvbW1vbic7XG5pbXBvcnQgeyBBWFRvYXN0U2VydmljZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy90b2FzdCc7XG5pbXBvcnQgeyBBWFRyYW5zbGF0b3IgfSBmcm9tICdAYWNvcmV4L2NvcmUvdHJhbnNsYXRpb24nO1xuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgSW5qZWN0LFxuICBJbnB1dCxcbiAgT25EZXN0cm95LFxuICBPcHRpb25hbCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQVhGb3JtQ29tcG9uZW50LCBBWEZvcm1WYWxpZGF0aW9uRXZlbnQgfSBmcm9tICcuL2Zvcm0uY29tcG9uZW50JztcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gJ3J4anMnO1xuXG5leHBvcnQgdHlwZSBBWFZhbGlkYXRpb25TdW1tYXJ5RGlzcGxheU1vZGUgPSAndG9hc3QnIHwgJ2FsZXJ0JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXgtdmFsaWRhdGlvbi1zdW1tYXJ5JyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8YXgtYWxlcnRcbiAgICAgIGNvbG9yPVwiZGFuZ2VyXCJcbiAgICAgICpuZ0lmPVwiZGlzcGxheU1vZGUgPT09ICdhbGVydCcgJiYgX2NvbnRlbnRcIlxuICAgICAgW3RpbWVPdXRdPVwiX3RpbWVPdXRcIlxuICAgICAgI2FcbiAgICAgIChvbkNsb3NlZCk9XCJfaGFuZGxlT25EaXNtaXNzZWQoKVwiXG4gICAgPlxuICAgICAgPGF4LWljb24+PC9heC1pY29uPlxuICAgICAgPGF4LXRpdGxlPnt7IHRpdGxlIH19PC9heC10aXRsZT5cbiAgICAgIDxheC1jb250ZW50PlxuICAgICAgICA8ZGl2IFtpbm5lckhUTUxdPVwiX2NvbnRlbnRcIj48L2Rpdj5cbiAgICAgIDwvYXgtY29udGVudD5cbiAgICAgIDxheC1mb290ZXI+XG4gICAgICAgIDxheC1zdWZmaXg+XG4gICAgICAgICAgPGF4LWJ1dHRvbiB0ZXh0PVwiRGlzbWlzc1wiIChvbkNsaWNrKT1cImEuY2xvc2UoKVwiPjwvYXgtYnV0dG9uPlxuICAgICAgICA8L2F4LXN1ZmZpeD5cbiAgICAgIDwvYXgtZm9vdGVyPlxuICAgIDwvYXgtYWxlcnQ+XG4gIGAsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxufSlcbmV4cG9ydCBjbGFzcyBBWFZhbGlkYXRpb25TdW1tYXJ5Q29tcG9uZW50IGV4dGVuZHMgTVhCYXNlQ29tcG9uZW50IGltcGxlbWVudHMgT25EZXN0cm95IHtcbiAgcHJvdGVjdGVkIF9jb250ZW50Pzogc3RyaW5nID0gbnVsbDtcbiAgcHJpdmF0ZSBfdGl0bGU6IHN0cmluZyA9IEFYVHJhbnNsYXRvci5nZXQoJ3ZhbGlkYXRpb24ubWVzc2FnZXMudGl0bGUnKTtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgZ2V0IHRpdGxlKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX3RpdGxlO1xuICB9XG4gIHB1YmxpYyBzZXQgdGl0bGUodjogc3RyaW5nKSB7XG4gICAgdGhpcy5fdGl0bGUgPSB2O1xuICB9XG5cbiAgQElucHV0KClcbiAgZGlzcGxheU1vZGU6IEFYVmFsaWRhdGlvblN1bW1hcnlEaXNwbGF5TW9kZSA9ICd0b2FzdCc7XG5cbiAgQElucHV0KClcbiAgdGltZU91dD86IG51bWJlcjtcblxuICBASW5wdXQoKVxuICBhdXRvSGlkZSA9IGZhbHNlO1xuXG4gIHByb3RlY3RlZCBfdGltZU91dDogbnVtYmVyO1xuXG4gIHByaXZhdGUgc3ViOiBTdWJzY3JpcHRpb247XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBfdG9zYXRTZXJ2aWNlOiBBWFRvYXN0U2VydmljZSxcbiAgICBAT3B0aW9uYWwoKVxuICAgIEBJbmplY3QoQVhGb3JtQ29tcG9uZW50KVxuICAgIHByaXZhdGUgaG9zdDogQVhGb3JtQ29tcG9uZW50LFxuICApIHtcbiAgICBzdXBlcigpO1xuICAgIC8vXG4gICAgdGhpcy5zdWIgPSBob3N0Lm9uVmFsaWRhdGVcbiAgICAgIC5zdWJzY3JpYmUoKGU6IEFYRm9ybVZhbGlkYXRpb25FdmVudCkgPT4ge1xuICAgICAgICBpZiAoIWUucmVzdWx0LnJlc3VsdCkge1xuICAgICAgICAgIGNvbnN0IGZhaWxlZFJ1bGVzID0gZS5yZXN1bHQucnVsZXMuZmlsdGVyKGMgPT4gIWMucmVzdWx0ICYmIGMubWVzc2FnZSk7XG4gICAgICAgICAgdGhpcy5fY29udGVudCA9IGA8dWw+JHtmYWlsZWRSdWxlcy5tYXAoKGMpID0+IGA8bGk+JHtjLm1lc3NhZ2V9PC9saT5gKS5qb2luKCcnKX08L3VsPmA7XG4gICAgICAgICAgdGhpcy5fdGltZU91dCA9IHRoaXMuYXV0b0hpZGUgPyAodGhpcy50aW1lT3V0ID8/IE1hdGgubWF4KGZhaWxlZFJ1bGVzLmxlbmd0aCAqIDEwMDAsIDIwMDApKSA6IDA7XG4gICAgICAgICAgLy9cbiAgICAgICAgICBpZiAodGhpcy5kaXNwbGF5TW9kZSA9PSAndG9hc3QnKSB7XG4gICAgICAgICAgICB0aGlzLl90b3NhdFNlcnZpY2Uuc2hvdyh7XG4gICAgICAgICAgICAgIGNvbG9yOiAnZGFuZ2VyJyxcbiAgICAgICAgICAgICAgY2xvc2VCdXR0b246IHRydWUsXG4gICAgICAgICAgICAgIHRpbWVPdXQ6IHRoaXMuX3RpbWVPdXQsXG4gICAgICAgICAgICAgIHRpbWVPdXRQcm9ncmVzczogdHJ1ZSxcbiAgICAgICAgICAgICAgY29udGVudDogdGhpcy5fY29udGVudCxcbiAgICAgICAgICAgICAgdGl0bGU6IHRoaXMudGl0bGUsXG4gICAgICAgICAgICAgIGxvY2F0aW9uOiAnYm90dG9tLWNlbnRlcicsXG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICB9XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgdGhpcy5fY29udGVudCA9IG51bGw7XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy5jZHIubWFya0ZvckNoZWNrKCk7XG4gICAgICB9KTtcbiAgfVxuXG4gIHByb3RlY3RlZCBfaGFuZGxlT25EaXNtaXNzZWQoKSB7XG4gICAgdGhpcy5fY29udGVudCA9IG51bGw7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICB0aGlzLnN1Yj8udW5zdWJzY3JpYmUoKTtcbiAgfVxufVxuIl19
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import { MXBaseComponent } from '@acorex/components/common';
|
1
|
+
import { MXBaseComponent, MXValueComponent } from '@acorex/components/common';
|
2
2
|
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation, } from '@angular/core';
|
3
3
|
import * as i0 from "@angular/core";
|
4
4
|
import * as i1 from "@angular/common";
|
@@ -6,7 +6,7 @@ export class AXLabelComponent extends MXBaseComponent {
|
|
6
6
|
constructor() {
|
7
7
|
super(...arguments);
|
8
8
|
this.requiredChange = new EventEmitter();
|
9
|
-
this._required =
|
9
|
+
this._required = null;
|
10
10
|
}
|
11
11
|
get required() {
|
12
12
|
return this._required;
|
@@ -20,22 +20,33 @@ export class AXLabelComponent extends MXBaseComponent {
|
|
20
20
|
},
|
21
21
|
});
|
22
22
|
}
|
23
|
-
get
|
24
|
-
return this.
|
23
|
+
get for() {
|
24
|
+
return this._for;
|
25
25
|
}
|
26
|
-
set
|
27
|
-
this.
|
28
|
-
|
26
|
+
set for(v) {
|
27
|
+
this.setOption({
|
28
|
+
name: 'for',
|
29
|
+
value: v,
|
30
|
+
afterCallback: () => {
|
31
|
+
this.cdr.markForCheck();
|
32
|
+
},
|
33
|
+
});
|
29
34
|
}
|
30
35
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AXLabelComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
31
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: AXLabelComponent, selector: "ax-label", inputs: { required: "required"
|
36
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: AXLabelComponent, selector: "ax-label", inputs: { required: "required", for: "for" }, outputs: { requiredChange: "requiredChange" }, providers: [
|
37
|
+
{ provide: MXBaseComponent, useExisting: AXLabelComponent }
|
38
|
+
], usesInheritance: true, ngImport: i0, template: "<label (click)=\"for?.focus()\" [class.ax-cursor-pointer]=\"for\" [attr.for]=\"for?.getHostElement().id\">\n <ng-content></ng-content>\n <span class=\"ax-state-required\" *ngIf=\"required || for?.isRequired\"> *</span>\n</label>", styles: ["ax-label{color:rgb(var(--ax-color-text-default))}ax-label label{margin-bottom:.5rem;display:block;cursor:inherit;font-size:.875rem;line-height:1.25rem;font-weight:500}ax-label label .ax-state-required{color:rgba(var(--ax-color-danger-500))}ax-label.ax-state-error{color:rgba(var(--ax-color-danger-500))}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
32
39
|
}
|
33
40
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AXLabelComponent, decorators: [{
|
34
41
|
type: Component,
|
35
|
-
args: [{ selector: 'ax-label', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, providers: [
|
42
|
+
args: [{ selector: 'ax-label', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, providers: [
|
43
|
+
{ provide: MXBaseComponent, useExisting: AXLabelComponent }
|
44
|
+
], template: "<label (click)=\"for?.focus()\" [class.ax-cursor-pointer]=\"for\" [attr.for]=\"for?.getHostElement().id\">\n <ng-content></ng-content>\n <span class=\"ax-state-required\" *ngIf=\"required || for?.isRequired\"> *</span>\n</label>", styles: ["ax-label{color:rgb(var(--ax-color-text-default))}ax-label label{margin-bottom:.5rem;display:block;cursor:inherit;font-size:.875rem;line-height:1.25rem;font-weight:500}ax-label label .ax-state-required{color:rgba(var(--ax-color-danger-500))}ax-label.ax-state-error{color:rgba(var(--ax-color-danger-500))}\n"] }]
|
36
45
|
}], propDecorators: { requiredChange: [{
|
37
46
|
type: Output
|
38
47
|
}], required: [{
|
39
48
|
type: Input
|
49
|
+
}], for: [{
|
50
|
+
type: Input
|
40
51
|
}] } });
|
41
|
-
//# sourceMappingURL=data:application/json;base64,
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFiZWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xhYmVsL3NyYy9saWIvbGFiZWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xhYmVsL3NyYy9saWIvbGFiZWwuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGVBQWUsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQzlFLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBQ0wsTUFBTSxFQUNOLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQzs7O0FBWXZCLE1BQU0sT0FBTyxnQkFBaUIsU0FBUSxlQUFlO0lBVnJEOztRQVlFLG1CQUFjLEdBQUcsSUFBSSxZQUFZLEVBQVcsQ0FBQztRQUVyQyxjQUFTLEdBQW9CLElBQUksQ0FBQztLQTZCM0M7SUE1QkMsSUFDVyxRQUFRO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN4QixDQUFDO0lBQ0QsSUFBVyxRQUFRLENBQUMsQ0FBVTtRQUM1QixJQUFJLENBQUMsU0FBUyxDQUFDO1lBQ2IsSUFBSSxFQUFFLFVBQVU7WUFDaEIsS0FBSyxFQUFFLENBQUM7WUFDUixhQUFhLEVBQUUsR0FBRyxFQUFFO2dCQUNsQixJQUFJLENBQUMsR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQzFCLENBQUM7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0lBR0QsSUFDVyxHQUFHO1FBQ1osT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDO0lBQ25CLENBQUM7SUFDRCxJQUFXLEdBQUcsQ0FBQyxDQUFtQjtRQUNoQyxJQUFJLENBQUMsU0FBUyxDQUFDO1lBQ2IsSUFBSSxFQUFFLEtBQUs7WUFDWCxLQUFLLEVBQUUsQ0FBQztZQUNSLGFBQWEsRUFBRSxHQUFHLEVBQUU7Z0JBQ2xCLElBQUksQ0FBQyxHQUFHLENBQUMsWUFBWSxFQUFFLENBQUM7WUFDMUIsQ0FBQztTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7OEdBaENVLGdCQUFnQjtrR0FBaEIsZ0JBQWdCLGdJQUpoQjtZQUNULEVBQUUsT0FBTyxFQUFFLGVBQWUsRUFBRSxXQUFXLEVBQUUsZ0JBQWdCLEVBQUU7U0FDNUQsaURDbEJILDZPQUdROzsyRkRpQkssZ0JBQWdCO2tCQVY1QixTQUFTOytCQUNFLFVBQVUsbUJBR0gsdUJBQXVCLENBQUMsTUFBTSxpQkFDaEMsaUJBQWlCLENBQUMsSUFBSSxhQUMxQjt3QkFDVCxFQUFFLE9BQU8sRUFBRSxlQUFlLEVBQUUsV0FBVyxrQkFBa0IsRUFBRTtxQkFDNUQ7OEJBSUQsY0FBYztzQkFEYixNQUFNO2dCQUtJLFFBQVE7c0JBRGxCLEtBQUs7Z0JBZ0JLLEdBQUc7c0JBRGIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1YQmFzZUNvbXBvbmVudCwgTVhWYWx1ZUNvbXBvbmVudCB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9jb21tb24nO1xuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgT3V0cHV0LFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2F4LWxhYmVsJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2xhYmVsLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vbGFiZWwuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIHByb3ZpZGVyczogW1xuICAgIHsgcHJvdmlkZTogTVhCYXNlQ29tcG9uZW50LCB1c2VFeGlzdGluZzogQVhMYWJlbENvbXBvbmVudCB9XG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEFYTGFiZWxDb21wb25lbnQgZXh0ZW5kcyBNWEJhc2VDb21wb25lbnQge1xuICBAT3V0cHV0KClcbiAgcmVxdWlyZWRDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPGJvb2xlYW4+KCk7XG5cbiAgcHJpdmF0ZSBfcmVxdWlyZWQ/OiBib29sZWFuIHwgbnVsbCA9IG51bGw7XG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBnZXQgcmVxdWlyZWQoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMuX3JlcXVpcmVkO1xuICB9XG4gIHB1YmxpYyBzZXQgcmVxdWlyZWQodjogYm9vbGVhbikge1xuICAgIHRoaXMuc2V0T3B0aW9uKHtcbiAgICAgIG5hbWU6ICdyZXF1aXJlZCcsXG4gICAgICB2YWx1ZTogdixcbiAgICAgIGFmdGVyQ2FsbGJhY2s6ICgpID0+IHtcbiAgICAgICAgdGhpcy5jZHIubWFya0ZvckNoZWNrKCk7XG4gICAgICB9LFxuICAgIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBfZm9yOiBNWFZhbHVlQ29tcG9uZW50O1xuICBASW5wdXQoKVxuICBwdWJsaWMgZ2V0IGZvcigpOiBNWFZhbHVlQ29tcG9uZW50IHtcbiAgICByZXR1cm4gdGhpcy5fZm9yO1xuICB9XG4gIHB1YmxpYyBzZXQgZm9yKHY6IE1YVmFsdWVDb21wb25lbnQpIHtcbiAgICB0aGlzLnNldE9wdGlvbih7XG4gICAgICBuYW1lOiAnZm9yJyxcbiAgICAgIHZhbHVlOiB2LFxuICAgICAgYWZ0ZXJDYWxsYmFjazogKCkgPT4ge1xuICAgICAgICB0aGlzLmNkci5tYXJrRm9yQ2hlY2soKTtcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cbn1cbiIsIjxsYWJlbCAoY2xpY2spPVwiZm9yPy5mb2N1cygpXCIgW2NsYXNzLmF4LWN1cnNvci1wb2ludGVyXT1cImZvclwiIFthdHRyLmZvcl09XCJmb3I/LmdldEhvc3RFbGVtZW50KCkuaWRcIj5cbiAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICA8c3BhbiBjbGFzcz1cImF4LXN0YXRlLXJlcXVpcmVkXCIgKm5nSWY9XCJyZXF1aXJlZCB8fCBmb3I/LmlzUmVxdWlyZWRcIj4mbmJzcDsqPC9zcGFuPlxuPC9sYWJlbD4iXX0=
|