@firestitch/form 12.0.2 → 12.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (97) hide show
  1. package/app/components/form-dialog-actions/form-dialog-actions.component.d.ts +21 -21
  2. package/app/consts/error-messages.const.d.ts +19 -19
  3. package/app/directives/form/form.directive.d.ts +108 -105
  4. package/app/directives/form-dialog-close.directive.d.ts +12 -12
  5. package/app/directives/submit-button.directive.d.ts +31 -31
  6. package/app/directives/validators/compare.directive.d.ts +15 -15
  7. package/app/directives/validators/control.directive.d.ts +48 -48
  8. package/app/directives/validators/daterange.directive.d.ts +13 -13
  9. package/app/directives/validators/email.directive.d.ts +13 -13
  10. package/app/directives/validators/emails.directive.d.ts +13 -13
  11. package/app/directives/validators/function.directive.d.ts +14 -14
  12. package/app/directives/validators/greater.directive.d.ts +13 -13
  13. package/app/directives/validators/integer.directive.d.ts +13 -13
  14. package/app/directives/validators/lesser.directive.d.ts +13 -13
  15. package/app/directives/validators/max.directive.d.ts +13 -13
  16. package/app/directives/validators/maxlength.directive.d.ts +13 -13
  17. package/app/directives/validators/min.directive.d.ts +13 -13
  18. package/app/directives/validators/minlength.directive.d.ts +13 -13
  19. package/app/directives/validators/numeric.directive.d.ts +13 -13
  20. package/app/directives/validators/pattern.directive.d.ts +13 -13
  21. package/app/directives/validators/phone.directive.d.ts +13 -13
  22. package/app/directives/validators/required.directive.d.ts +16 -16
  23. package/app/directives/validators/url.directive.d.ts +14 -14
  24. package/app/directives/validators/validate.directive.d.ts +14 -14
  25. package/app/enums/confirm-result.d.ts +7 -7
  26. package/app/enums/form-status.d.ts +9 -9
  27. package/app/fs-form.module.d.ts +35 -35
  28. package/app/guards/form-deactivate.guard.d.ts +12 -12
  29. package/app/helpers/confirm-result-continue.d.ts +1 -1
  30. package/app/helpers/confirm-unsaved.d.ts +5 -5
  31. package/app/helpers/get-form-errors.d.ts +2 -2
  32. package/app/helpers/index.d.ts +2 -2
  33. package/app/helpers/is-enabled.d.ts +1 -1
  34. package/app/interfaces/async-validator.d.ts +14 -14
  35. package/app/interfaces/confirm-config.d.ts +7 -7
  36. package/app/interfaces/confirm-tab-group.d.ts +10 -10
  37. package/app/interfaces/form-deactivate.d.ts +4 -4
  38. package/app/interfaces/index.d.ts +4 -4
  39. package/app/interfaces/submit-event.d.ts +5 -5
  40. package/app/interfaces/submitted-event.d.ts +6 -6
  41. package/app/interfaces/validator.d.ts +13 -13
  42. package/app/providers/validate-messages.provider.d.ts +25 -25
  43. package/app/services/fsform.service.d.ts +10 -10
  44. package/app/validators/validators.d.ts +12 -12
  45. package/bundles/firestitch-form.umd.js +2623 -2613
  46. package/bundles/firestitch-form.umd.js.map +1 -1
  47. package/esm2015/app/components/form-dialog-actions/form-dialog-actions.component.js +85 -85
  48. package/esm2015/app/consts/error-messages.const.js +19 -19
  49. package/esm2015/app/directives/form/form.directive.js +622 -619
  50. package/esm2015/app/directives/form-dialog-close.directive.js +30 -30
  51. package/esm2015/app/directives/submit-button.directive.js +132 -131
  52. package/esm2015/app/directives/validators/compare.directive.js +48 -48
  53. package/esm2015/app/directives/validators/control.directive.js +256 -256
  54. package/esm2015/app/directives/validators/daterange.directive.js +40 -40
  55. package/esm2015/app/directives/validators/email.directive.js +40 -40
  56. package/esm2015/app/directives/validators/emails.directive.js +40 -40
  57. package/esm2015/app/directives/validators/function.directive.js +30 -30
  58. package/esm2015/app/directives/validators/greater.directive.js +39 -39
  59. package/esm2015/app/directives/validators/integer.directive.js +40 -40
  60. package/esm2015/app/directives/validators/lesser.directive.js +39 -39
  61. package/esm2015/app/directives/validators/max.directive.js +35 -35
  62. package/esm2015/app/directives/validators/maxlength.directive.js +34 -34
  63. package/esm2015/app/directives/validators/min.directive.js +35 -35
  64. package/esm2015/app/directives/validators/minlength.directive.js +34 -34
  65. package/esm2015/app/directives/validators/numeric.directive.js +40 -40
  66. package/esm2015/app/directives/validators/pattern.directive.js +34 -34
  67. package/esm2015/app/directives/validators/phone.directive.js +40 -40
  68. package/esm2015/app/directives/validators/required.directive.js +70 -70
  69. package/esm2015/app/directives/validators/url.directive.js +46 -46
  70. package/esm2015/app/directives/validators/validate.directive.js +32 -32
  71. package/esm2015/app/enums/confirm-result.js +8 -8
  72. package/esm2015/app/enums/form-status.js +10 -10
  73. package/esm2015/app/fs-form.module.js +171 -165
  74. package/esm2015/app/guards/form-deactivate.guard.js +39 -39
  75. package/esm2015/app/helpers/confirm-result-continue.js +4 -4
  76. package/esm2015/app/helpers/confirm-unsaved.js +69 -69
  77. package/esm2015/app/helpers/get-form-errors.js +24 -24
  78. package/esm2015/app/helpers/index.js +2 -2
  79. package/esm2015/app/helpers/is-enabled.js +3 -3
  80. package/esm2015/app/interfaces/async-validator.js +1 -1
  81. package/esm2015/app/interfaces/confirm-config.js +1 -1
  82. package/esm2015/app/interfaces/confirm-tab-group.js +1 -1
  83. package/esm2015/app/interfaces/form-deactivate.js +1 -1
  84. package/esm2015/app/interfaces/index.js +4 -4
  85. package/esm2015/app/interfaces/submit-event.js +1 -1
  86. package/esm2015/app/interfaces/submitted-event.js +1 -1
  87. package/esm2015/app/interfaces/validator.js +1 -1
  88. package/esm2015/app/providers/validate-messages.provider.js +10 -10
  89. package/esm2015/app/services/fsform.service.js +24 -24
  90. package/esm2015/app/validators/validators.js +96 -96
  91. package/esm2015/firestitch-form.js +4 -4
  92. package/esm2015/public_api.js +34 -34
  93. package/fesm2015/firestitch-form.js +2071 -2061
  94. package/fesm2015/firestitch-form.js.map +1 -1
  95. package/firestitch-form.d.ts +5 -5
  96. package/package.json +1 -1
  97. package/public_api.d.ts +33 -33
@@ -1,257 +1,257 @@
1
- import { Input, ElementRef, Renderer2, Directive, Injector, Optional, Inject, Self, } from '@angular/core';
2
- import { NgControl } from '@angular/forms';
3
- import { Subject } from 'rxjs';
4
- import { takeUntil } from 'rxjs/operators';
5
- import { values, keys } from 'lodash-es';
6
- import { FsFormDirective } from '../form/form.directive';
7
- import { VALIDATE_MESSAGE_PROVIDER, VALIDATE_MESSAGES } from '../../providers/validate-messages.provider';
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "@angular/forms";
10
- import * as i2 from "../form/form.directive";
11
- export class FsControlDirective {
12
- constructor(elementRef, renderer2, injector, _validateMessages, ngControl, formDirective) {
13
- this.elementRef = elementRef;
14
- this.renderer2 = renderer2;
15
- this.injector = injector;
16
- this._validateMessages = _validateMessages;
17
- this.ngControl = ngControl;
18
- this.formDirective = formDirective;
19
- this.appendMessageClass = 'fs-form-message';
20
- this.appendLabelClass = 'fs-form-label';
21
- this.appendErrorClass = 'fs-form-error';
22
- this.appendHintClass = 'fs-form-hint';
23
- this.errors = [];
24
- // protected _validateMessages = { ...ERROR_MESSAGES };
25
- this._destroy$ = new Subject();
26
- if (ngControl) {
27
- this._control = ngControl.control;
28
- }
29
- else {
30
- console.error('The element does not have a valid ngModel', this.elementRef.nativeElement);
31
- }
32
- }
33
- set validateMessages(messages) {
34
- this._validateMessages = Object.assign(Object.assign({}, this._validateMessages), messages);
35
- }
36
- ngOnInit() {
37
- this._setupValidators();
38
- }
39
- ngOnDestroy() {
40
- this._destroy$.next();
41
- this._destroy$.complete();
42
- }
43
- ngAfterContentInit() {
44
- if (this._control) {
45
- /*
46
- Ensure that statusChanges has one subscription per control. Multiple can happen
47
- when multiple fsForm validation directives are applied to the same element
48
- */
49
- if (!this._control.statusChangesSubscribe) {
50
- this._control.statusChanges
51
- .pipe(takeUntil(this._destroy$))
52
- .subscribe(this.render.bind(this));
53
- this._control.statusChangesSubscribe = true;
54
- }
55
- }
56
- }
57
- getMessageSelector() {
58
- if (this.messageSelector === false) {
59
- return '';
60
- }
61
- if (this.messageSelector) {
62
- return this.messageSelector;
63
- }
64
- else if (this.formDirective && this.formDirective.messageSelector) {
65
- return this.formDirective.messageSelector;
66
- }
67
- }
68
- getHintWrapperSelector() {
69
- if (this.hintSelector === false) {
70
- return '';
71
- }
72
- if (this.hintSelector) {
73
- return this.hintSelector;
74
- }
75
- else if (this.formDirective && this.formDirective.hintSelector) {
76
- return this.formDirective.hintSelector;
77
- }
78
- }
79
- getWrapperSelector() {
80
- if (this.wrapperSelector === false) {
81
- return '';
82
- }
83
- if (this.wrapperSelector) {
84
- return this.wrapperSelector;
85
- }
86
- else if (this.formDirective && this.formDirective.wrapperSelector) {
87
- return this.formDirective.wrapperSelector;
88
- }
89
- }
90
- getlabelSelector() {
91
- if (this.labelSelector === false) {
92
- return '';
93
- }
94
- if (this.labelSelector) {
95
- return this.labelSelector;
96
- }
97
- else if (this.formDirective && this.formDirective.labelSelector) {
98
- return this.formDirective.labelSelector;
99
- }
100
- }
101
- getWrapperElement() {
102
- const wrapper = this.getWrapper(this.elementRef.nativeElement);
103
- if (wrapper) {
104
- return wrapper;
105
- }
106
- return this.elementRef.nativeElement;
107
- }
108
- /*
109
- <mat-form-field class="mat-form-field"> <-- Field Wrapper Class. Look for parents from the native element with the matching wrapperSelector. If not found defaults to native element.
110
- <input>
111
- <div class="fs-form-message"> <-- Message Selector. Look for the element with class .fs-form-message or messageSelector
112
- <div class="fs-form-message"></div>
113
- <div class="fs-form-hint"></div> <-- Hint Selector. Look for the element with class .fs-form-hint or hintSelector
114
- </div>
115
- </mat-form-field>
116
- */
117
- render() {
118
- var _a;
119
- if (this.ngControl) {
120
- const renderer = this.renderer2;
121
- const wrapper = this.getWrapperElement();
122
- const error = this.ngControl.dirty ? this.getError(this.ngControl) : null;
123
- if (!this.getMessageSelector()) {
124
- return;
125
- }
126
- const messageWrapper = wrapper.querySelector(this.getMessageSelector());
127
- if (!messageWrapper) {
128
- return console.warn('Failed to locate ' + this.getMessageSelector(), this.elementRef.nativeElement);
129
- }
130
- if (this.getlabelSelector()) {
131
- const labelWrapper = wrapper.querySelector(this.getlabelSelector());
132
- if (labelWrapper) {
133
- if (this.appendLabelClass) {
134
- this.renderer2.addClass(labelWrapper, this.appendLabelClass);
135
- }
136
- }
137
- }
138
- if (this.appendMessageClass) {
139
- renderer.addClass(messageWrapper, this.appendMessageClass);
140
- }
141
- if (this.getHintWrapperSelector()) {
142
- const hint = messageWrapper.querySelector(this.getHintWrapperSelector());
143
- if (hint) {
144
- renderer.setStyle(hint, 'display', error ? 'none' : 'block');
145
- if (this.appendHintClass) {
146
- renderer.addClass(hint, this.appendHintClass);
147
- }
148
- }
149
- }
150
- let errorWrapper = wrapper.querySelector('.fs-form-error-target');
151
- if (errorWrapper) {
152
- errorWrapper.remove();
153
- }
154
- wrapper.classList.remove('ng-invalid');
155
- const shouldErrorBeRendered = this.ngControl.invalid
156
- && (this.ngControl.dirty || ((_a = this.formDirective.ngForm) === null || _a === void 0 ? void 0 : _a.submitted));
157
- if (!shouldErrorBeRendered || !error) {
158
- return;
159
- }
160
- wrapper.classList.add('ng-invalid');
161
- errorWrapper = renderer.createElement('div');
162
- renderer.addClass(errorWrapper, 'fs-form-error-target');
163
- renderer.addClass(errorWrapper, this.appendErrorClass);
164
- renderer.addClass(errorWrapper, this.appendErrorClass + '-' + error.name);
165
- const errorText = renderer.createText(error.message);
166
- renderer.appendChild(errorWrapper, errorText);
167
- messageWrapper.appendChild(errorWrapper);
168
- }
169
- }
170
- getWrapper(node, count = 0) {
171
- if (!node || count > 10) {
172
- return null;
173
- }
174
- if (node.parentNode && node.parentNode.querySelector(this.getWrapperSelector())) {
175
- return node;
176
- }
177
- return this.getWrapper(node.parentNode, ++count);
178
- }
179
- parseErrorMessage(message, args) {
180
- values(args)
181
- .forEach((name) => {
182
- message = message.replace(/\$\(\d\)/, name);
183
- });
184
- return message;
185
- }
186
- getError(controlRef) {
187
- const name = keys(controlRef.control.errors)[0];
188
- if (!name) {
189
- return null;
190
- }
191
- let message = controlRef.control.errors[name];
192
- if (this._validateMessages[name]) {
193
- message = this.parseErrorMessage(this._validateMessages[name], message);
194
- }
195
- return { name: name, message: message };
196
- }
197
- _setupValidators() {
198
- const control = this._control;
199
- if (this.validate) {
200
- const validators = control.validator
201
- ? [control.validator, this.validate.bind(this)]
202
- : this.validate.bind(this);
203
- control.setValidators(validators);
204
- }
205
- if (this.validateAsync) {
206
- const asyncValidators = control.asyncValidator
207
- ? [control.asyncValidator, this.validateAsync.bind(this)]
208
- : this.validateAsync.bind(this);
209
- control.setAsyncValidators(asyncValidators);
210
- }
211
- control.updateValueAndValidity();
212
- }
213
- }
214
- FsControlDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsControlDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.Injector }, { token: VALIDATE_MESSAGES, self: true }, { token: i1.NgControl, optional: true }, { token: FsFormDirective, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
215
- FsControlDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.16", type: FsControlDirective, selector: "[fsFormControl]", inputs: { wrapperSelector: "wrapperSelector", messageSelector: "messageSelector", hintSelector: "hintSelector", labelSelector: "labelSelector", appendMessageClass: "appendMessageClass", appendLabelClass: "appendLabelClass", appendErrorClass: "appendErrorClass", appendHintClass: "appendHintClass", validateMessages: "validateMessages" }, providers: [
216
- VALIDATE_MESSAGE_PROVIDER
217
- ], ngImport: i0 });
218
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsControlDirective, decorators: [{
219
- type: Directive,
220
- args: [{
221
- selector: '[fsFormControl]',
222
- providers: [
223
- VALIDATE_MESSAGE_PROVIDER
224
- ],
225
- }]
226
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.Injector }, { type: undefined, decorators: [{
227
- type: Self
228
- }, {
229
- type: Inject,
230
- args: [VALIDATE_MESSAGES]
231
- }] }, { type: i1.NgControl, decorators: [{
232
- type: Optional
233
- }] }, { type: i2.FsFormDirective, decorators: [{
234
- type: Optional
235
- }, {
236
- type: Inject,
237
- args: [FsFormDirective]
238
- }] }]; }, propDecorators: { wrapperSelector: [{
239
- type: Input
240
- }], messageSelector: [{
241
- type: Input
242
- }], hintSelector: [{
243
- type: Input
244
- }], labelSelector: [{
245
- type: Input
246
- }], appendMessageClass: [{
247
- type: Input
248
- }], appendLabelClass: [{
249
- type: Input
250
- }], appendErrorClass: [{
251
- type: Input
252
- }], appendHintClass: [{
253
- type: Input
254
- }], validateMessages: [{
255
- type: Input
256
- }] } });
1
+ import { Input, ElementRef, Renderer2, Directive, Injector, Optional, Inject, Self, } from '@angular/core';
2
+ import { NgControl } from '@angular/forms';
3
+ import { Subject } from 'rxjs';
4
+ import { takeUntil } from 'rxjs/operators';
5
+ import { values, keys } from 'lodash-es';
6
+ import { FsFormDirective } from '../form/form.directive';
7
+ import { VALIDATE_MESSAGE_PROVIDER, VALIDATE_MESSAGES } from '../../providers/validate-messages.provider';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@angular/forms";
10
+ import * as i2 from "../form/form.directive";
11
+ export class FsControlDirective {
12
+ constructor(elementRef, renderer2, injector, _validateMessages, ngControl, formDirective) {
13
+ this.elementRef = elementRef;
14
+ this.renderer2 = renderer2;
15
+ this.injector = injector;
16
+ this._validateMessages = _validateMessages;
17
+ this.ngControl = ngControl;
18
+ this.formDirective = formDirective;
19
+ this.appendMessageClass = 'fs-form-message';
20
+ this.appendLabelClass = 'fs-form-label';
21
+ this.appendErrorClass = 'fs-form-error';
22
+ this.appendHintClass = 'fs-form-hint';
23
+ this.errors = [];
24
+ // protected _validateMessages = { ...ERROR_MESSAGES };
25
+ this._destroy$ = new Subject();
26
+ if (ngControl) {
27
+ this._control = ngControl.control;
28
+ }
29
+ else {
30
+ console.error('The element does not have a valid ngModel', this.elementRef.nativeElement);
31
+ }
32
+ }
33
+ set validateMessages(messages) {
34
+ this._validateMessages = Object.assign(Object.assign({}, this._validateMessages), messages);
35
+ }
36
+ ngOnInit() {
37
+ this._setupValidators();
38
+ }
39
+ ngOnDestroy() {
40
+ this._destroy$.next();
41
+ this._destroy$.complete();
42
+ }
43
+ ngAfterContentInit() {
44
+ if (this._control) {
45
+ /*
46
+ Ensure that statusChanges has one subscription per control. Multiple can happen
47
+ when multiple fsForm validation directives are applied to the same element
48
+ */
49
+ if (!this._control.statusChangesSubscribe) {
50
+ this._control.statusChanges
51
+ .pipe(takeUntil(this._destroy$))
52
+ .subscribe(this.render.bind(this));
53
+ this._control.statusChangesSubscribe = true;
54
+ }
55
+ }
56
+ }
57
+ getMessageSelector() {
58
+ if (this.messageSelector === false) {
59
+ return '';
60
+ }
61
+ if (this.messageSelector) {
62
+ return this.messageSelector;
63
+ }
64
+ else if (this.formDirective && this.formDirective.messageSelector) {
65
+ return this.formDirective.messageSelector;
66
+ }
67
+ }
68
+ getHintWrapperSelector() {
69
+ if (this.hintSelector === false) {
70
+ return '';
71
+ }
72
+ if (this.hintSelector) {
73
+ return this.hintSelector;
74
+ }
75
+ else if (this.formDirective && this.formDirective.hintSelector) {
76
+ return this.formDirective.hintSelector;
77
+ }
78
+ }
79
+ getWrapperSelector() {
80
+ if (this.wrapperSelector === false) {
81
+ return '';
82
+ }
83
+ if (this.wrapperSelector) {
84
+ return this.wrapperSelector;
85
+ }
86
+ else if (this.formDirective && this.formDirective.wrapperSelector) {
87
+ return this.formDirective.wrapperSelector;
88
+ }
89
+ }
90
+ getlabelSelector() {
91
+ if (this.labelSelector === false) {
92
+ return '';
93
+ }
94
+ if (this.labelSelector) {
95
+ return this.labelSelector;
96
+ }
97
+ else if (this.formDirective && this.formDirective.labelSelector) {
98
+ return this.formDirective.labelSelector;
99
+ }
100
+ }
101
+ getWrapperElement() {
102
+ const wrapper = this.getWrapper(this.elementRef.nativeElement);
103
+ if (wrapper) {
104
+ return wrapper;
105
+ }
106
+ return this.elementRef.nativeElement;
107
+ }
108
+ /*
109
+ <mat-form-field class="mat-form-field"> <-- Field Wrapper Class. Look for parents from the native element with the matching wrapperSelector. If not found defaults to native element.
110
+ <input>
111
+ <div class="fs-form-message"> <-- Message Selector. Look for the element with class .fs-form-message or messageSelector
112
+ <div class="fs-form-message"></div>
113
+ <div class="fs-form-hint"></div> <-- Hint Selector. Look for the element with class .fs-form-hint or hintSelector
114
+ </div>
115
+ </mat-form-field>
116
+ */
117
+ render() {
118
+ var _a;
119
+ if (this.ngControl) {
120
+ const renderer = this.renderer2;
121
+ const wrapper = this.getWrapperElement();
122
+ const error = this.ngControl.dirty ? this.getError(this.ngControl) : null;
123
+ if (!this.getMessageSelector()) {
124
+ return;
125
+ }
126
+ const messageWrapper = wrapper.querySelector(this.getMessageSelector());
127
+ if (!messageWrapper) {
128
+ return console.warn('Failed to locate ' + this.getMessageSelector(), this.elementRef.nativeElement);
129
+ }
130
+ if (this.getlabelSelector()) {
131
+ const labelWrapper = wrapper.querySelector(this.getlabelSelector());
132
+ if (labelWrapper) {
133
+ if (this.appendLabelClass) {
134
+ this.renderer2.addClass(labelWrapper, this.appendLabelClass);
135
+ }
136
+ }
137
+ }
138
+ if (this.appendMessageClass) {
139
+ renderer.addClass(messageWrapper, this.appendMessageClass);
140
+ }
141
+ if (this.getHintWrapperSelector()) {
142
+ const hint = messageWrapper.querySelector(this.getHintWrapperSelector());
143
+ if (hint) {
144
+ renderer.setStyle(hint, 'display', error ? 'none' : 'block');
145
+ if (this.appendHintClass) {
146
+ renderer.addClass(hint, this.appendHintClass);
147
+ }
148
+ }
149
+ }
150
+ let errorWrapper = wrapper.querySelector('.fs-form-error-target');
151
+ if (errorWrapper) {
152
+ errorWrapper.remove();
153
+ }
154
+ wrapper.classList.remove('ng-invalid');
155
+ const shouldErrorBeRendered = this.ngControl.invalid
156
+ && (this.ngControl.dirty || ((_a = this.formDirective.ngForm) === null || _a === void 0 ? void 0 : _a.submitted));
157
+ if (!shouldErrorBeRendered || !error) {
158
+ return;
159
+ }
160
+ wrapper.classList.add('ng-invalid');
161
+ errorWrapper = renderer.createElement('div');
162
+ renderer.addClass(errorWrapper, 'fs-form-error-target');
163
+ renderer.addClass(errorWrapper, this.appendErrorClass);
164
+ renderer.addClass(errorWrapper, this.appendErrorClass + '-' + error.name);
165
+ const errorText = renderer.createText(error.message);
166
+ renderer.appendChild(errorWrapper, errorText);
167
+ messageWrapper.appendChild(errorWrapper);
168
+ }
169
+ }
170
+ getWrapper(node, count = 0) {
171
+ if (!node || count > 10) {
172
+ return null;
173
+ }
174
+ if (node.parentNode && node.parentNode.querySelector(this.getWrapperSelector())) {
175
+ return node;
176
+ }
177
+ return this.getWrapper(node.parentNode, ++count);
178
+ }
179
+ parseErrorMessage(message, args) {
180
+ values(args)
181
+ .forEach((name) => {
182
+ message = message.replace(/\$\(\d\)/, name);
183
+ });
184
+ return message;
185
+ }
186
+ getError(controlRef) {
187
+ const name = keys(controlRef.control.errors)[0];
188
+ if (!name) {
189
+ return null;
190
+ }
191
+ let message = controlRef.control.errors[name];
192
+ if (this._validateMessages[name]) {
193
+ message = this.parseErrorMessage(this._validateMessages[name], message);
194
+ }
195
+ return { name: name, message: message };
196
+ }
197
+ _setupValidators() {
198
+ const control = this._control;
199
+ if (this.validate) {
200
+ const validators = control.validator
201
+ ? [control.validator, this.validate.bind(this)]
202
+ : this.validate.bind(this);
203
+ control.setValidators(validators);
204
+ }
205
+ if (this.validateAsync) {
206
+ const asyncValidators = control.asyncValidator
207
+ ? [control.asyncValidator, this.validateAsync.bind(this)]
208
+ : this.validateAsync.bind(this);
209
+ control.setAsyncValidators(asyncValidators);
210
+ }
211
+ control.updateValueAndValidity();
212
+ }
213
+ }
214
+ FsControlDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsControlDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.Injector }, { token: VALIDATE_MESSAGES, self: true }, { token: i1.NgControl, optional: true }, { token: FsFormDirective, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
215
+ FsControlDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.16", type: FsControlDirective, selector: "[fsFormControl]", inputs: { wrapperSelector: "wrapperSelector", messageSelector: "messageSelector", hintSelector: "hintSelector", labelSelector: "labelSelector", appendMessageClass: "appendMessageClass", appendLabelClass: "appendLabelClass", appendErrorClass: "appendErrorClass", appendHintClass: "appendHintClass", validateMessages: "validateMessages" }, providers: [
216
+ VALIDATE_MESSAGE_PROVIDER
217
+ ], ngImport: i0 });
218
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsControlDirective, decorators: [{
219
+ type: Directive,
220
+ args: [{
221
+ selector: '[fsFormControl]',
222
+ providers: [
223
+ VALIDATE_MESSAGE_PROVIDER
224
+ ],
225
+ }]
226
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.Injector }, { type: undefined, decorators: [{
227
+ type: Self
228
+ }, {
229
+ type: Inject,
230
+ args: [VALIDATE_MESSAGES]
231
+ }] }, { type: i1.NgControl, decorators: [{
232
+ type: Optional
233
+ }] }, { type: i2.FsFormDirective, decorators: [{
234
+ type: Optional
235
+ }, {
236
+ type: Inject,
237
+ args: [FsFormDirective]
238
+ }] }]; }, propDecorators: { wrapperSelector: [{
239
+ type: Input
240
+ }], messageSelector: [{
241
+ type: Input
242
+ }], hintSelector: [{
243
+ type: Input
244
+ }], labelSelector: [{
245
+ type: Input
246
+ }], appendMessageClass: [{
247
+ type: Input
248
+ }], appendLabelClass: [{
249
+ type: Input
250
+ }], appendErrorClass: [{
251
+ type: Input
252
+ }], appendHintClass: [{
253
+ type: Input
254
+ }], validateMessages: [{
255
+ type: Input
256
+ }] } });
257
257
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control.directive.js","sourceRoot":"","sources":["../../../../../src/app/directives/validators/control.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Input,\n  ElementRef,\n  Renderer2,\n  Directive,\n  Injector,\n  Optional,\n  Inject,\n  Self,\n  OnInit,\n  OnDestroy,\n  AfterContentInit,\n} from '@angular/core';\nimport { NgControl, AbstractControl, ValidationErrors } from '@angular/forms';\n\nimport { Observable, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { values, keys } from 'lodash-es';\n\nimport { FsFormDirective } from '../form/form.directive';\nimport {\n  VALIDATE_MESSAGE_PROVIDER,\n  VALIDATE_MESSAGES\n} from '../../providers/validate-messages.provider';\n\n\nexport interface FsControlDirective {\n  validate?(control: AbstractControl): ValidationErrors | null;\n  validateAsync?(control: AbstractControl): Promise<ValidationErrors | null> | Observable<ValidationErrors | null>;\n}\n\n\n@Directive({\n  selector: '[fsFormControl]',\n  providers: [\n    VALIDATE_MESSAGE_PROVIDER\n  ],\n})\nexport class FsControlDirective implements OnInit, AfterContentInit, OnDestroy {\n\n  @Input() wrapperSelector: string | false;\n  @Input() messageSelector: string | false;\n  @Input() hintSelector: string | false;\n  @Input() labelSelector: string | false;\n  @Input() appendMessageClass = 'fs-form-message';\n  @Input() appendLabelClass = 'fs-form-label';\n  @Input() appendErrorClass = 'fs-form-error';\n  @Input() appendHintClass = 'fs-form-hint';\n\n  @Input()\n  public set validateMessages(messages: Record<string, string>) {\n    this._validateMessages = {\n      ...this._validateMessages,\n      ...messages,\n    };\n  }\n\n  public errors = [];\n\n  // protected _validateMessages = { ...ERROR_MESSAGES };\n  protected _destroy$ = new Subject();\n  protected _control: AbstractControl;\n\n  constructor(\n    protected elementRef: ElementRef,\n    protected renderer2: Renderer2,\n    protected injector: Injector,\n    @Self() @Inject(VALIDATE_MESSAGES) protected _validateMessages,\n    @Optional() protected ngControl: NgControl,\n    @Optional() @Inject(FsFormDirective) private formDirective: FsFormDirective,\n  ) {\n\n    if (ngControl) {\n      this._control = ngControl.control;\n    } else {\n      console.error('The element does not have a valid ngModel', this.elementRef.nativeElement);\n    }\n  }\n\n  ngOnInit() {\n    this._setupValidators();\n  }\n\n  ngOnDestroy() {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  ngAfterContentInit() {\n    if (this._control) {\n\n      /*\n        Ensure that statusChanges has one subscription per control. Multiple can happen\n        when multiple fsForm validation directives are applied to the same element\n      */\n      if (!(<any>this._control).statusChangesSubscribe) {\n\n        this._control.statusChanges\n        .pipe(\n            takeUntil(this._destroy$)\n        )\n        .subscribe(this.render.bind(this));\n\n        (<any>this._control).statusChangesSubscribe = true;\n      }\n    }\n  }\n\n  protected getMessageSelector(): string {\n\n    if (this.messageSelector === false) {\n      return '';\n    }\n\n    if (this.messageSelector) {\n      return this.messageSelector;\n\n    } else if (this.formDirective && this.formDirective.messageSelector) {\n      return this.formDirective.messageSelector;\n    }\n  }\n\n  protected getHintWrapperSelector(): string {\n\n    if (this.hintSelector === false) {\n      return '';\n    }\n\n    if (this.hintSelector) {\n      return this.hintSelector;\n\n    } else if (this.formDirective && this.formDirective.hintSelector) {\n      return this.formDirective.hintSelector;\n    }\n  }\n\n  protected getWrapperSelector(): string {\n\n    if (this.wrapperSelector === false) {\n      return '';\n    }\n\n    if (this.wrapperSelector) {\n      return this.wrapperSelector;\n\n    } else if (this.formDirective && this.formDirective.wrapperSelector) {\n      return this.formDirective.wrapperSelector;\n    }\n  }\n\n  protected getlabelSelector(): string {\n\n    if (this.labelSelector === false) {\n      return '';\n    }\n\n    if (this.labelSelector) {\n      return this.labelSelector;\n\n    } else if (this.formDirective && this.formDirective.labelSelector) {\n      return this.formDirective.labelSelector;\n    }\n  }\n\n  protected getWrapperElement() {\n\n    const wrapper = this.getWrapper(this.elementRef.nativeElement);\n\n    if (wrapper) {\n      return wrapper;\n    }\n\n    return this.elementRef.nativeElement;\n  }\n\n  /*\n    <mat-form-field class=\"mat-form-field\">  <-- Field Wrapper Class. Look for parents from the native element with the matching wrapperSelector. If not found defaults to native element.\n      <input>\n      <div class=\"fs-form-message\"> <-- Message Selector. Look for the element with class .fs-form-message or messageSelector\n        <div class=\"fs-form-message\"></div>\n        <div class=\"fs-form-hint\"></div> <-- Hint Selector. Look for the element with class .fs-form-hint or hintSelector\n      </div>\n    </mat-form-field>\n  */\n\n  protected render() {\n    if (this.ngControl) {\n\n      const renderer = this.renderer2;\n      const wrapper = this.getWrapperElement();\n      const error = this.ngControl.dirty ? this.getError(this.ngControl) : null;\n\n      if (!this.getMessageSelector()) {\n        return;\n      }\n\n      const messageWrapper = wrapper.querySelector(this.getMessageSelector());\n\n      if (!messageWrapper) {\n        return console.warn('Failed to locate ' + this.getMessageSelector(), this.elementRef.nativeElement);\n      }\n\n      if (this.getlabelSelector()) {\n        const labelWrapper = wrapper.querySelector(this.getlabelSelector());\n\n        if (labelWrapper) {\n          if (this.appendLabelClass) {\n            this.renderer2.addClass(labelWrapper, this.appendLabelClass);\n          }\n        }\n      }\n\n      if (this.appendMessageClass) {\n        renderer.addClass(messageWrapper, this.appendMessageClass);\n      }\n\n      if (this.getHintWrapperSelector()) {\n        const hint = messageWrapper.querySelector(this.getHintWrapperSelector());\n\n        if (hint) {\n          renderer.setStyle(hint, 'display', error ? 'none' : 'block');\n\n          if (this.appendHintClass) {\n            renderer.addClass(hint, this.appendHintClass);\n          }\n        }\n      }\n\n      let errorWrapper = wrapper.querySelector('.fs-form-error-target');\n      if (errorWrapper) {\n        errorWrapper.remove();\n      }\n\n      wrapper.classList.remove('ng-invalid');\n\n      const shouldErrorBeRendered = this.ngControl.invalid\n        && (this.ngControl.dirty || this.formDirective.ngForm?.submitted);\n\n      if (!shouldErrorBeRendered || !error) {\n        return;\n      }\n\n      wrapper.classList.add('ng-invalid');\n\n      errorWrapper = renderer.createElement('div');\n      renderer.addClass(errorWrapper, 'fs-form-error-target');\n      renderer.addClass(errorWrapper, this.appendErrorClass);\n      renderer.addClass(errorWrapper, this.appendErrorClass + '-' + error.name);\n\n      const errorText = renderer.createText(error.message);\n\n      renderer.appendChild(errorWrapper, errorText);\n      messageWrapper.appendChild(errorWrapper);\n    }\n  }\n\n  protected getWrapper(node, count = 0) {\n\n    if (!node || count > 10) {\n      return null;\n    }\n\n    if (node.parentNode && node.parentNode.querySelector(this.getWrapperSelector())) {\n      return node;\n    }\n\n    return this.getWrapper(node.parentNode, ++count);\n  }\n\n  protected parseErrorMessage(message, args): string {\n    values(args)\n      .forEach((name) => {\n          message = message.replace(/\\$\\(\\d\\)/, name);\n      });\n\n    return message;\n  }\n\n  protected getError(controlRef): { name: string, message: string } {\n\n    const name = keys(controlRef.control.errors)[0];\n\n    if (!name) {\n      return null;\n    }\n\n    let message = controlRef.control.errors[name];\n\n    if (this._validateMessages[name]) {\n      message = this.parseErrorMessage(this._validateMessages[name], message);\n    }\n\n    return { name: name, message: message };\n  }\n\n  private _setupValidators(): void {\n    const control = this._control;\n\n    if (this.validate) {\n      const validators = control.validator\n        ? [ control.validator, this.validate.bind(this)]\n        : this.validate.bind(this);\n\n      control.setValidators(validators);\n    }\n\n    if (this.validateAsync) {\n      const asyncValidators = control.asyncValidator\n        ? [ control.asyncValidator, this.validateAsync.bind(this)]\n        : this.validateAsync.bind(this);\n\n      control.setAsyncValidators(asyncValidators);\n    }\n\n    control.updateValueAndValidity();\n  }\n\n}\n"]}
@@ -1,41 +1,41 @@
1
- import { Directive, Input } from '@angular/core';
2
- import { FsControlDirective } from './control.directive';
3
- import { FsValidators } from '../../validators/validators';
4
- import { VALIDATE_MESSAGE_PROVIDER } from '../../providers/validate-messages.provider';
5
- import { isEnabled } from '../../helpers/is-enabled';
6
- import * as i0 from "@angular/core";
7
- export class FsFormDateRangeDirective extends FsControlDirective {
8
- set validationMessage(value) {
9
- this._validateMessages.dateRange = value;
10
- }
11
- ngOnChanges() {
12
- this._control.updateValueAndValidity();
13
- }
14
- validate(control) {
15
- if (isEnabled(this.fsFormDateRange)) {
16
- return FsValidators.dateRange(this._control);
17
- }
18
- else {
19
- return null;
20
- }
21
- }
22
- }
23
- FsFormDateRangeDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsFormDateRangeDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
24
- FsFormDateRangeDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.16", type: FsFormDateRangeDirective, selector: "[fsFormDateRange]", inputs: { fsFormDateRange: "fsFormDateRange", validationMessage: ["fsFormDateRangeMessage", "validationMessage"] }, providers: [
25
- VALIDATE_MESSAGE_PROVIDER
26
- ], usesInheritance: true, usesOnChanges: true, ngImport: i0 });
27
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsFormDateRangeDirective, decorators: [{
28
- type: Directive,
29
- args: [{
30
- selector: '[fsFormDateRange]',
31
- providers: [
32
- VALIDATE_MESSAGE_PROVIDER
33
- ],
34
- }]
35
- }], propDecorators: { fsFormDateRange: [{
36
- type: Input
37
- }], validationMessage: [{
38
- type: Input,
39
- args: ['fsFormDateRangeMessage']
40
- }] } });
1
+ import { Directive, Input } from '@angular/core';
2
+ import { FsControlDirective } from './control.directive';
3
+ import { FsValidators } from '../../validators/validators';
4
+ import { VALIDATE_MESSAGE_PROVIDER } from '../../providers/validate-messages.provider';
5
+ import { isEnabled } from '../../helpers/is-enabled';
6
+ import * as i0 from "@angular/core";
7
+ export class FsFormDateRangeDirective extends FsControlDirective {
8
+ set validationMessage(value) {
9
+ this._validateMessages.dateRange = value;
10
+ }
11
+ ngOnChanges() {
12
+ this._control.updateValueAndValidity();
13
+ }
14
+ validate(control) {
15
+ if (isEnabled(this.fsFormDateRange)) {
16
+ return FsValidators.dateRange(this._control);
17
+ }
18
+ else {
19
+ return null;
20
+ }
21
+ }
22
+ }
23
+ FsFormDateRangeDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsFormDateRangeDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
24
+ FsFormDateRangeDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.16", type: FsFormDateRangeDirective, selector: "[fsFormDateRange]", inputs: { fsFormDateRange: "fsFormDateRange", validationMessage: ["fsFormDateRangeMessage", "validationMessage"] }, providers: [
25
+ VALIDATE_MESSAGE_PROVIDER
26
+ ], usesInheritance: true, usesOnChanges: true, ngImport: i0 });
27
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsFormDateRangeDirective, decorators: [{
28
+ type: Directive,
29
+ args: [{
30
+ selector: '[fsFormDateRange]',
31
+ providers: [
32
+ VALIDATE_MESSAGE_PROVIDER
33
+ ],
34
+ }]
35
+ }], propDecorators: { fsFormDateRange: [{
36
+ type: Input
37
+ }], validationMessage: [{
38
+ type: Input,
39
+ args: ['fsFormDateRangeMessage']
40
+ }] } });
41
41
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXJhbmdlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvZGlyZWN0aXZlcy92YWxpZGF0b3JzL2RhdGVyYW5nZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQWEsTUFBTSxlQUFlLENBQUM7QUFHNUQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDekQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQzNELE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLDRDQUE0QyxDQUFDO0FBRXZGLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7QUFTckQsTUFBTSxPQUFPLHdCQUF5QixTQUFRLGtCQUFrQjtJQUs5RCxJQUNXLGlCQUFpQixDQUFDLEtBQWE7UUFDeEMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7SUFDM0MsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxzQkFBc0IsRUFBRSxDQUFDO0lBQ3pDLENBQUM7SUFFTSxRQUFRLENBQUMsT0FBd0I7UUFDdEMsSUFBSSxTQUFTLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxFQUFFO1lBQ25DLE9BQU8sWUFBWSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7U0FDOUM7YUFBTTtZQUNMLE9BQU8sSUFBSSxDQUFDO1NBQ2I7SUFDSCxDQUFDOztzSEFwQlUsd0JBQXdCOzBHQUF4Qix3QkFBd0IsZ0tBSnhCO1FBQ1QseUJBQXlCO0tBQzFCOzRGQUVVLHdCQUF3QjtrQkFOcEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsbUJBQW1CO29CQUM3QixTQUFTLEVBQUU7d0JBQ1QseUJBQXlCO3FCQUMxQjtpQkFDRjs4QkFJUSxlQUFlO3NCQURyQixLQUFLO2dCQUlLLGlCQUFpQjtzQkFEM0IsS0FBSzt1QkFBQyx3QkFBd0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0LCBPbkNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFic3RyYWN0Q29udHJvbCwgVmFsaWRhdGlvbkVycm9ycyB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuaW1wb3J0IHsgRnNDb250cm9sRGlyZWN0aXZlIH0gZnJvbSAnLi9jb250cm9sLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBGc1ZhbGlkYXRvcnMgfSBmcm9tICcuLi8uLi92YWxpZGF0b3JzL3ZhbGlkYXRvcnMnO1xuaW1wb3J0IHsgVkFMSURBVEVfTUVTU0FHRV9QUk9WSURFUiB9IGZyb20gJy4uLy4uL3Byb3ZpZGVycy92YWxpZGF0ZS1tZXNzYWdlcy5wcm92aWRlcic7XG5pbXBvcnQgeyBGc1ZhbGlkYXRvciB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvdmFsaWRhdG9yJztcbmltcG9ydCB7IGlzRW5hYmxlZCB9IGZyb20gJy4uLy4uL2hlbHBlcnMvaXMtZW5hYmxlZCc7XG5cblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2ZzRm9ybURhdGVSYW5nZV0nLFxuICBwcm92aWRlcnM6IFtcbiAgICBWQUxJREFURV9NRVNTQUdFX1BST1ZJREVSXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEZzRm9ybURhdGVSYW5nZURpcmVjdGl2ZSBleHRlbmRzIEZzQ29udHJvbERpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uQ2hhbmdlcywgRnNWYWxpZGF0b3Ige1xuXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBmc0Zvcm1EYXRlUmFuZ2U7XG5cbiAgQElucHV0KCdmc0Zvcm1EYXRlUmFuZ2VNZXNzYWdlJylcbiAgcHVibGljIHNldCB2YWxpZGF0aW9uTWVzc2FnZSh2YWx1ZTogc3RyaW5nKSB7XG4gICAgdGhpcy5fdmFsaWRhdGVNZXNzYWdlcy5kYXRlUmFuZ2UgPSB2YWx1ZTtcbiAgfVxuXG4gIHB1YmxpYyBuZ09uQ2hhbmdlcygpIHtcbiAgICB0aGlzLl9jb250cm9sLnVwZGF0ZVZhbHVlQW5kVmFsaWRpdHkoKTtcbiAgfVxuXG4gIHB1YmxpYyB2YWxpZGF0ZShjb250cm9sOiBBYnN0cmFjdENvbnRyb2wpOiBWYWxpZGF0aW9uRXJyb3JzIHwgbnVsbCB7XG4gICAgaWYgKGlzRW5hYmxlZCh0aGlzLmZzRm9ybURhdGVSYW5nZSkpIHtcbiAgICAgIHJldHVybiBGc1ZhbGlkYXRvcnMuZGF0ZVJhbmdlKHRoaXMuX2NvbnRyb2wpO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG4gIH1cbn1cbiJdfQ==