@firestitch/form 12.4.14 → 12.4.16

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 (102) hide show
  1. package/app/components/form-dialog-actions/form-dialog-actions.component.d.ts +23 -23
  2. package/app/consts/error-messages.const.d.ts +19 -19
  3. package/app/directives/button.directive.d.ts +35 -35
  4. package/app/directives/form/form.directive.d.ts +122 -122
  5. package/app/directives/form-dialog-close.directive.d.ts +12 -12
  6. package/app/directives/index.d.ts +2 -2
  7. package/app/directives/submit-button.directive.d.ts +6 -6
  8. package/app/directives/validators/compare.directive.d.ts +15 -15
  9. package/app/directives/validators/control.directive.d.ts +48 -48
  10. package/app/directives/validators/daterange.directive.d.ts +13 -13
  11. package/app/directives/validators/email.directive.d.ts +13 -13
  12. package/app/directives/validators/emails.directive.d.ts +13 -13
  13. package/app/directives/validators/function.directive.d.ts +15 -15
  14. package/app/directives/validators/greater.directive.d.ts +13 -13
  15. package/app/directives/validators/integer.directive.d.ts +13 -13
  16. package/app/directives/validators/lesser.directive.d.ts +13 -13
  17. package/app/directives/validators/max.directive.d.ts +13 -13
  18. package/app/directives/validators/maxlength.directive.d.ts +13 -13
  19. package/app/directives/validators/min.directive.d.ts +13 -13
  20. package/app/directives/validators/minlength.directive.d.ts +13 -13
  21. package/app/directives/validators/no-fs-validators.directive.d.ts +13 -13
  22. package/app/directives/validators/numeric.directive.d.ts +13 -13
  23. package/app/directives/validators/pattern.directive.d.ts +13 -13
  24. package/app/directives/validators/phone.directive.d.ts +13 -13
  25. package/app/directives/validators/required.directive.d.ts +16 -16
  26. package/app/directives/validators/url.directive.d.ts +14 -14
  27. package/app/directives/validators/validate.directive.d.ts +15 -15
  28. package/app/enums/confirm-result.d.ts +7 -7
  29. package/app/enums/form-status.d.ts +10 -10
  30. package/app/fs-form.module.d.ts +37 -37
  31. package/app/guards/form-deactivate.guard.d.ts +14 -14
  32. package/app/helpers/confirm-result-continue.d.ts +1 -1
  33. package/app/helpers/confirm-unsaved.d.ts +5 -5
  34. package/app/helpers/get-active-route.d.ts +2 -2
  35. package/app/helpers/get-form-errors.d.ts +2 -2
  36. package/app/helpers/index.d.ts +2 -2
  37. package/app/helpers/is-enabled.d.ts +1 -1
  38. package/app/interfaces/async-validator.d.ts +14 -14
  39. package/app/interfaces/confirm-config.d.ts +7 -7
  40. package/app/interfaces/confirm-tab-group.d.ts +10 -10
  41. package/app/interfaces/index.d.ts +4 -4
  42. package/app/interfaces/submit-event.d.ts +6 -6
  43. package/app/interfaces/submitted-event.d.ts +7 -7
  44. package/app/interfaces/validator.d.ts +13 -13
  45. package/app/providers/validate-messages.provider.d.ts +25 -25
  46. package/app/services/fsform.service.d.ts +16 -16
  47. package/app/validators/validators.d.ts +12 -12
  48. package/bundles/firestitch-form.umd.js +2832 -2832
  49. package/esm2015/app/components/form-dialog-actions/form-dialog-actions.component.js +91 -91
  50. package/esm2015/app/consts/error-messages.const.js +19 -19
  51. package/esm2015/app/directives/button.directive.js +152 -152
  52. package/esm2015/app/directives/form/form.directive.js +695 -695
  53. package/esm2015/app/directives/form-dialog-close.directive.js +30 -30
  54. package/esm2015/app/directives/index.js +2 -2
  55. package/esm2015/app/directives/submit-button.directive.js +13 -13
  56. package/esm2015/app/directives/validators/compare.directive.js +48 -48
  57. package/esm2015/app/directives/validators/control.directive.js +257 -257
  58. package/esm2015/app/directives/validators/daterange.directive.js +40 -40
  59. package/esm2015/app/directives/validators/email.directive.js +40 -40
  60. package/esm2015/app/directives/validators/emails.directive.js +40 -40
  61. package/esm2015/app/directives/validators/function.directive.js +40 -40
  62. package/esm2015/app/directives/validators/greater.directive.js +39 -39
  63. package/esm2015/app/directives/validators/integer.directive.js +40 -40
  64. package/esm2015/app/directives/validators/lesser.directive.js +39 -39
  65. package/esm2015/app/directives/validators/max.directive.js +35 -35
  66. package/esm2015/app/directives/validators/maxlength.directive.js +34 -34
  67. package/esm2015/app/directives/validators/min.directive.js +35 -35
  68. package/esm2015/app/directives/validators/minlength.directive.js +34 -34
  69. package/esm2015/app/directives/validators/no-fs-validators.directive.js +46 -46
  70. package/esm2015/app/directives/validators/numeric.directive.js +40 -40
  71. package/esm2015/app/directives/validators/pattern.directive.js +34 -34
  72. package/esm2015/app/directives/validators/phone.directive.js +40 -40
  73. package/esm2015/app/directives/validators/required.directive.js +70 -70
  74. package/esm2015/app/directives/validators/url.directive.js +46 -46
  75. package/esm2015/app/directives/validators/validate.directive.js +42 -42
  76. package/esm2015/app/enums/confirm-result.js +8 -8
  77. package/esm2015/app/enums/form-status.js +11 -11
  78. package/esm2015/app/fs-form.module.js +180 -180
  79. package/esm2015/app/guards/form-deactivate.guard.js +44 -44
  80. package/esm2015/app/helpers/confirm-result-continue.js +4 -4
  81. package/esm2015/app/helpers/confirm-unsaved.js +71 -71
  82. package/esm2015/app/helpers/get-active-route.js +6 -6
  83. package/esm2015/app/helpers/get-form-errors.js +24 -24
  84. package/esm2015/app/helpers/index.js +2 -2
  85. package/esm2015/app/helpers/is-enabled.js +3 -3
  86. package/esm2015/app/interfaces/async-validator.js +1 -1
  87. package/esm2015/app/interfaces/confirm-config.js +1 -1
  88. package/esm2015/app/interfaces/confirm-tab-group.js +1 -1
  89. package/esm2015/app/interfaces/index.js +4 -4
  90. package/esm2015/app/interfaces/submit-event.js +1 -1
  91. package/esm2015/app/interfaces/submitted-event.js +1 -1
  92. package/esm2015/app/interfaces/validator.js +1 -1
  93. package/esm2015/app/providers/validate-messages.provider.js +10 -10
  94. package/esm2015/app/services/fsform.service.js +39 -39
  95. package/esm2015/app/validators/validators.js +96 -96
  96. package/esm2015/firestitch-form.js +4 -4
  97. package/esm2015/public_api.js +36 -36
  98. package/fesm2015/firestitch-form.js +2269 -2269
  99. package/firestitch-form.d.ts +5 -5
  100. package/package.json +1 -1
  101. package/public_api.d.ts +34 -34
  102. package/styles.scss +3 -3
@@ -1,258 +1,258 @@
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
- this._control.statusChanges
46
- .pipe(takeUntil(this._destroy$))
47
- .subscribe(this.render.bind(this));
48
- }
49
- }
50
- getMessageSelector() {
51
- var _a;
52
- if (this.messageSelector === false) {
53
- return '';
54
- }
55
- if (this.messageSelector) {
56
- return this.messageSelector;
57
- }
58
- else if ((_a = this.formDirective) === null || _a === void 0 ? void 0 : _a.messageSelector) {
59
- return this.formDirective.messageSelector;
60
- }
61
- }
62
- getHintWrapperSelector() {
63
- var _a;
64
- if (this.hintSelector === false) {
65
- return '';
66
- }
67
- if (this.hintSelector) {
68
- return this.hintSelector;
69
- }
70
- else if ((_a = this.formDirective) === null || _a === void 0 ? void 0 : _a.hintSelector) {
71
- return this.formDirective.hintSelector;
72
- }
73
- }
74
- getWrapperSelector() {
75
- var _a;
76
- if (this.wrapperSelector === false) {
77
- return '';
78
- }
79
- if (this.wrapperSelector) {
80
- return this.wrapperSelector;
81
- }
82
- else if ((_a = this.formDirective) === null || _a === void 0 ? void 0 : _a.wrapperSelector) {
83
- return this.formDirective.wrapperSelector;
84
- }
85
- }
86
- getlabelSelector() {
87
- var _a;
88
- if (this.labelSelector === false) {
89
- return '';
90
- }
91
- if (this.labelSelector) {
92
- return this.labelSelector;
93
- }
94
- else if ((_a = this.formDirective) === null || _a === void 0 ? void 0 : _a.labelSelector) {
95
- return this.formDirective.labelSelector;
96
- }
97
- }
98
- getWrapperElement() {
99
- const wrapper = this.getWrapper(this.elementRef.nativeElement);
100
- if (wrapper) {
101
- return wrapper;
102
- }
103
- return this.elementRef.nativeElement;
104
- }
105
- /*
106
- <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.
107
- <input>
108
- <div class="fs-form-message"> <-- Message Selector. Look for the element with class .fs-form-message or messageSelector
109
- <div class="fs-form-message"></div>
110
- <div class="fs-form-hint"></div> <-- Hint Selector. Look for the element with class .fs-form-hint or hintSelector
111
- </div>
112
- </mat-form-field>
113
- */
114
- render() {
115
- var _a, _b;
116
- if (this.ngControl) {
117
- const renderer = this.renderer2;
118
- const wrapper = this.getWrapperElement();
119
- const error = this.ngControl.dirty ? this.getError(this.ngControl) : null;
120
- const shouldErrorBeRendered = this.ngControl.invalid
121
- && (this.ngControl.dirty || ((_b = (_a = this.formDirective) === null || _a === void 0 ? void 0 : _a.ngForm) === null || _b === void 0 ? void 0 : _b.submitted));
122
- if (shouldErrorBeRendered && error) {
123
- wrapper.classList.add('ng-invalid', 'ng-dirty');
124
- }
125
- else {
126
- wrapper.classList.remove('ng-invalid');
127
- }
128
- if (!this.getMessageSelector()) {
129
- return;
130
- }
131
- const messageWrapper = wrapper.querySelector(this.getMessageSelector());
132
- if (!messageWrapper) {
133
- return console.warn('Failed to locate ' + this.getMessageSelector(), this.elementRef.nativeElement);
134
- }
135
- if (this.getlabelSelector()) {
136
- const labelWrapper = wrapper.querySelector(this.getlabelSelector());
137
- if (labelWrapper) {
138
- if (this.appendLabelClass) {
139
- this.renderer2.addClass(labelWrapper, this.appendLabelClass);
140
- }
141
- }
142
- }
143
- if (this.appendMessageClass) {
144
- renderer.addClass(messageWrapper, this.appendMessageClass);
145
- }
146
- if (this.getHintWrapperSelector()) {
147
- const hint = messageWrapper.querySelector(this.getHintWrapperSelector());
148
- if (hint) {
149
- renderer.setStyle(hint, 'display', error ? 'none' : 'block');
150
- if (this.appendHintClass) {
151
- renderer.addClass(hint, this.appendHintClass);
152
- }
153
- }
154
- }
155
- let errorWrapper = wrapper.querySelector('.fs-form-error-target');
156
- if (errorWrapper) {
157
- errorWrapper.remove();
158
- }
159
- if (!shouldErrorBeRendered || !error) {
160
- return;
161
- }
162
- errorWrapper = renderer.createElement('div');
163
- renderer.addClass(errorWrapper, 'fs-form-error-target');
164
- renderer.addClass(errorWrapper, this.appendErrorClass);
165
- renderer.addClass(errorWrapper, this.appendErrorClass + '-' + error.name);
166
- const errorText = renderer.createText(error.message);
167
- renderer.appendChild(errorWrapper, errorText);
168
- messageWrapper.appendChild(errorWrapper);
169
- }
170
- }
171
- getWrapper(node, count = 0) {
172
- if (!node || count > 10) {
173
- return null;
174
- }
175
- if (node.parentNode && node.parentNode.querySelector(this.getWrapperSelector())) {
176
- return node;
177
- }
178
- return this.getWrapper(node.parentNode, ++count);
179
- }
180
- parseErrorMessage(message, args) {
181
- values(args)
182
- .forEach((name) => {
183
- message = message.replace(/\$\(\d\)/, name);
184
- });
185
- return message;
186
- }
187
- getError(controlRef) {
188
- const name = keys(controlRef.control.errors)[0];
189
- if (!name) {
190
- return null;
191
- }
192
- let message = controlRef.control.errors[name];
193
- if (this._validateMessages[name]) {
194
- message = this.parseErrorMessage(this._validateMessages[name], message);
195
- }
196
- return { name: name, message: message };
197
- }
198
- _setupValidators() {
199
- const control = this._control;
200
- if (this.validate) {
201
- const validators = control.validator
202
- ? [control.validator, this.validate.bind(this)]
203
- : this.validate.bind(this);
204
- control.setValidators(validators);
205
- }
206
- if (this.validateAsync) {
207
- const asyncValidators = control.asyncValidator
208
- ? [control.asyncValidator, this.validateAsync.bind(this)]
209
- : this.validateAsync.bind(this);
210
- control.setAsyncValidators(asyncValidators);
211
- }
212
- control.updateValueAndValidity();
213
- }
214
- }
215
- 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 });
216
- 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: [
217
- VALIDATE_MESSAGE_PROVIDER
218
- ], ngImport: i0 });
219
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsControlDirective, decorators: [{
220
- type: Directive,
221
- args: [{
222
- selector: '[fsFormControl]',
223
- providers: [
224
- VALIDATE_MESSAGE_PROVIDER
225
- ],
226
- }]
227
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.Injector }, { type: undefined, decorators: [{
228
- type: Self
229
- }, {
230
- type: Inject,
231
- args: [VALIDATE_MESSAGES]
232
- }] }, { type: i1.NgControl, decorators: [{
233
- type: Optional
234
- }] }, { type: i2.FsFormDirective, decorators: [{
235
- type: Optional
236
- }, {
237
- type: Inject,
238
- args: [FsFormDirective]
239
- }] }]; }, propDecorators: { wrapperSelector: [{
240
- type: Input
241
- }], messageSelector: [{
242
- type: Input
243
- }], hintSelector: [{
244
- type: Input
245
- }], labelSelector: [{
246
- type: Input
247
- }], appendMessageClass: [{
248
- type: Input
249
- }], appendLabelClass: [{
250
- type: Input
251
- }], appendErrorClass: [{
252
- type: Input
253
- }], appendHintClass: [{
254
- type: Input
255
- }], validateMessages: [{
256
- type: Input
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
+ this._control.statusChanges
46
+ .pipe(takeUntil(this._destroy$))
47
+ .subscribe(this.render.bind(this));
48
+ }
49
+ }
50
+ getMessageSelector() {
51
+ var _a;
52
+ if (this.messageSelector === false) {
53
+ return '';
54
+ }
55
+ if (this.messageSelector) {
56
+ return this.messageSelector;
57
+ }
58
+ else if ((_a = this.formDirective) === null || _a === void 0 ? void 0 : _a.messageSelector) {
59
+ return this.formDirective.messageSelector;
60
+ }
61
+ }
62
+ getHintWrapperSelector() {
63
+ var _a;
64
+ if (this.hintSelector === false) {
65
+ return '';
66
+ }
67
+ if (this.hintSelector) {
68
+ return this.hintSelector;
69
+ }
70
+ else if ((_a = this.formDirective) === null || _a === void 0 ? void 0 : _a.hintSelector) {
71
+ return this.formDirective.hintSelector;
72
+ }
73
+ }
74
+ getWrapperSelector() {
75
+ var _a;
76
+ if (this.wrapperSelector === false) {
77
+ return '';
78
+ }
79
+ if (this.wrapperSelector) {
80
+ return this.wrapperSelector;
81
+ }
82
+ else if ((_a = this.formDirective) === null || _a === void 0 ? void 0 : _a.wrapperSelector) {
83
+ return this.formDirective.wrapperSelector;
84
+ }
85
+ }
86
+ getlabelSelector() {
87
+ var _a;
88
+ if (this.labelSelector === false) {
89
+ return '';
90
+ }
91
+ if (this.labelSelector) {
92
+ return this.labelSelector;
93
+ }
94
+ else if ((_a = this.formDirective) === null || _a === void 0 ? void 0 : _a.labelSelector) {
95
+ return this.formDirective.labelSelector;
96
+ }
97
+ }
98
+ getWrapperElement() {
99
+ const wrapper = this.getWrapper(this.elementRef.nativeElement);
100
+ if (wrapper) {
101
+ return wrapper;
102
+ }
103
+ return this.elementRef.nativeElement;
104
+ }
105
+ /*
106
+ <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.
107
+ <input>
108
+ <div class="fs-form-message"> <-- Message Selector. Look for the element with class .fs-form-message or messageSelector
109
+ <div class="fs-form-message"></div>
110
+ <div class="fs-form-hint"></div> <-- Hint Selector. Look for the element with class .fs-form-hint or hintSelector
111
+ </div>
112
+ </mat-form-field>
113
+ */
114
+ render() {
115
+ var _a, _b;
116
+ if (this.ngControl) {
117
+ const renderer = this.renderer2;
118
+ const wrapper = this.getWrapperElement();
119
+ const error = this.ngControl.dirty ? this.getError(this.ngControl) : null;
120
+ const shouldErrorBeRendered = this.ngControl.invalid
121
+ && (this.ngControl.dirty || ((_b = (_a = this.formDirective) === null || _a === void 0 ? void 0 : _a.ngForm) === null || _b === void 0 ? void 0 : _b.submitted));
122
+ if (shouldErrorBeRendered && error) {
123
+ wrapper.classList.add('ng-invalid', 'ng-dirty');
124
+ }
125
+ else {
126
+ wrapper.classList.remove('ng-invalid');
127
+ }
128
+ if (!this.getMessageSelector()) {
129
+ return;
130
+ }
131
+ const messageWrapper = wrapper.querySelector(this.getMessageSelector());
132
+ if (!messageWrapper) {
133
+ return console.warn('Failed to locate ' + this.getMessageSelector(), this.elementRef.nativeElement);
134
+ }
135
+ if (this.getlabelSelector()) {
136
+ const labelWrapper = wrapper.querySelector(this.getlabelSelector());
137
+ if (labelWrapper) {
138
+ if (this.appendLabelClass) {
139
+ this.renderer2.addClass(labelWrapper, this.appendLabelClass);
140
+ }
141
+ }
142
+ }
143
+ if (this.appendMessageClass) {
144
+ renderer.addClass(messageWrapper, this.appendMessageClass);
145
+ }
146
+ if (this.getHintWrapperSelector()) {
147
+ const hint = messageWrapper.querySelector(this.getHintWrapperSelector());
148
+ if (hint) {
149
+ renderer.setStyle(hint, 'display', error ? 'none' : 'block');
150
+ if (this.appendHintClass) {
151
+ renderer.addClass(hint, this.appendHintClass);
152
+ }
153
+ }
154
+ }
155
+ let errorWrapper = wrapper.querySelector('.fs-form-error-target');
156
+ if (errorWrapper) {
157
+ errorWrapper.remove();
158
+ }
159
+ if (!shouldErrorBeRendered || !error) {
160
+ return;
161
+ }
162
+ errorWrapper = renderer.createElement('div');
163
+ renderer.addClass(errorWrapper, 'fs-form-error-target');
164
+ renderer.addClass(errorWrapper, this.appendErrorClass);
165
+ renderer.addClass(errorWrapper, this.appendErrorClass + '-' + error.name);
166
+ const errorText = renderer.createText(error.message);
167
+ renderer.appendChild(errorWrapper, errorText);
168
+ messageWrapper.appendChild(errorWrapper);
169
+ }
170
+ }
171
+ getWrapper(node, count = 0) {
172
+ if (!node || count > 10) {
173
+ return null;
174
+ }
175
+ if (node.parentNode && node.parentNode.querySelector(this.getWrapperSelector())) {
176
+ return node;
177
+ }
178
+ return this.getWrapper(node.parentNode, ++count);
179
+ }
180
+ parseErrorMessage(message, args) {
181
+ values(args)
182
+ .forEach((name) => {
183
+ message = message.replace(/\$\(\d\)/, name);
184
+ });
185
+ return message;
186
+ }
187
+ getError(controlRef) {
188
+ const name = keys(controlRef.control.errors)[0];
189
+ if (!name) {
190
+ return null;
191
+ }
192
+ let message = controlRef.control.errors[name];
193
+ if (this._validateMessages[name]) {
194
+ message = this.parseErrorMessage(this._validateMessages[name], message);
195
+ }
196
+ return { name: name, message: message };
197
+ }
198
+ _setupValidators() {
199
+ const control = this._control;
200
+ if (this.validate) {
201
+ const validators = control.validator
202
+ ? [control.validator, this.validate.bind(this)]
203
+ : this.validate.bind(this);
204
+ control.setValidators(validators);
205
+ }
206
+ if (this.validateAsync) {
207
+ const asyncValidators = control.asyncValidator
208
+ ? [control.asyncValidator, this.validateAsync.bind(this)]
209
+ : this.validateAsync.bind(this);
210
+ control.setAsyncValidators(asyncValidators);
211
+ }
212
+ control.updateValueAndValidity();
213
+ }
214
+ }
215
+ 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 });
216
+ 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: [
217
+ VALIDATE_MESSAGE_PROVIDER
218
+ ], ngImport: i0 });
219
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsControlDirective, decorators: [{
220
+ type: Directive,
221
+ args: [{
222
+ selector: '[fsFormControl]',
223
+ providers: [
224
+ VALIDATE_MESSAGE_PROVIDER
225
+ ],
226
+ }]
227
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.Injector }, { type: undefined, decorators: [{
228
+ type: Self
229
+ }, {
230
+ type: Inject,
231
+ args: [VALIDATE_MESSAGES]
232
+ }] }, { type: i1.NgControl, decorators: [{
233
+ type: Optional
234
+ }] }, { type: i2.FsFormDirective, decorators: [{
235
+ type: Optional
236
+ }, {
237
+ type: Inject,
238
+ args: [FsFormDirective]
239
+ }] }]; }, propDecorators: { wrapperSelector: [{
240
+ type: Input
241
+ }], messageSelector: [{
242
+ type: Input
243
+ }], hintSelector: [{
244
+ type: Input
245
+ }], labelSelector: [{
246
+ type: Input
247
+ }], appendMessageClass: [{
248
+ type: Input
249
+ }], appendLabelClass: [{
250
+ type: Input
251
+ }], appendErrorClass: [{
252
+ type: Input
253
+ }], appendHintClass: [{
254
+ type: Input
255
+ }], validateMessages: [{
256
+ type: Input
257
+ }] } });
258
258
  //# 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) protected 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      this._control.statusChanges\n        .pipe(\n          takeUntil(this._destroy$)\n        )\n        .subscribe(this.render.bind(this));\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?.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?.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?.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?.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      const renderer = this.renderer2;\n      const wrapper = this.getWrapperElement();\n      const error = this.ngControl.dirty ? this.getError(this.ngControl) : null;\n      const shouldErrorBeRendered = this.ngControl.invalid\n        && (this.ngControl.dirty || this.formDirective?.ngForm?.submitted);\n\n      if (shouldErrorBeRendered && error) {\n        wrapper.classList.add('ng-invalid', 'ng-dirty');\n      } else {\n        wrapper.classList.remove('ng-invalid');\n      }\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      if (!shouldErrorBeRendered || !error) {\n        return;\n      }\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==