@firestitch/form 12.4.11 → 12.4.13

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