@firestitch/form 12.5.0 → 12.5.2

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 (104) 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 +127 -127
  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 +49 -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 +14 -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 +2862 -2854
  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 +711 -711
  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 +261 -258
  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 +52 -47
  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 +96 -96
  97. package/esm2015/firestitch-form.js +4 -4
  98. package/esm2015/public_api.js +36 -36
  99. package/fesm2015/firestitch-form.js +2293 -2285
  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
  104. package/styles.scss +1 -1
@@ -1,258 +1,261 @@
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
- //# 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
+ 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
+ this._subscribeToStatusChagnes();
45
+ }
46
+ _subscribeToStatusChagnes() {
47
+ if (this._control) {
48
+ this._control.statusChanges
49
+ .pipe(takeUntil(this._destroy$))
50
+ .subscribe(this.render.bind(this));
51
+ }
52
+ }
53
+ getMessageSelector() {
54
+ var _a;
55
+ if (this.messageSelector === false) {
56
+ return '';
57
+ }
58
+ if (this.messageSelector) {
59
+ return this.messageSelector;
60
+ }
61
+ else if ((_a = this.formDirective) === null || _a === void 0 ? void 0 : _a.messageSelector) {
62
+ return this.formDirective.messageSelector;
63
+ }
64
+ }
65
+ getHintWrapperSelector() {
66
+ var _a;
67
+ if (this.hintSelector === false) {
68
+ return '';
69
+ }
70
+ if (this.hintSelector) {
71
+ return this.hintSelector;
72
+ }
73
+ else if ((_a = this.formDirective) === null || _a === void 0 ? void 0 : _a.hintSelector) {
74
+ return this.formDirective.hintSelector;
75
+ }
76
+ }
77
+ getWrapperSelector() {
78
+ var _a;
79
+ if (this.wrapperSelector === false) {
80
+ return '';
81
+ }
82
+ if (this.wrapperSelector) {
83
+ return this.wrapperSelector;
84
+ }
85
+ else if ((_a = this.formDirective) === null || _a === void 0 ? void 0 : _a.wrapperSelector) {
86
+ return this.formDirective.wrapperSelector;
87
+ }
88
+ }
89
+ getlabelSelector() {
90
+ var _a;
91
+ if (this.labelSelector === false) {
92
+ return '';
93
+ }
94
+ if (this.labelSelector) {
95
+ return this.labelSelector;
96
+ }
97
+ else if ((_a = this.formDirective) === null || _a === void 0 ? void 0 : _a.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, _b;
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
+ const shouldErrorBeRendered = this.ngControl.invalid
124
+ && (this.ngControl.dirty || ((_b = (_a = this.formDirective) === null || _a === void 0 ? void 0 : _a.ngForm) === null || _b === void 0 ? void 0 : _b.submitted));
125
+ if (shouldErrorBeRendered && error) {
126
+ wrapper.classList.add('ng-invalid', 'ng-dirty');
127
+ }
128
+ else {
129
+ wrapper.classList.remove('ng-invalid');
130
+ }
131
+ if (!this.getMessageSelector()) {
132
+ return;
133
+ }
134
+ const messageWrapper = wrapper.querySelector(this.getMessageSelector());
135
+ if (!messageWrapper) {
136
+ return console.warn('Failed to locate ' + this.getMessageSelector(), this.elementRef.nativeElement);
137
+ }
138
+ if (this.getlabelSelector()) {
139
+ const labelWrapper = wrapper.querySelector(this.getlabelSelector());
140
+ if (labelWrapper) {
141
+ if (this.appendLabelClass) {
142
+ this.renderer2.addClass(labelWrapper, this.appendLabelClass);
143
+ }
144
+ }
145
+ }
146
+ if (this.appendMessageClass) {
147
+ renderer.addClass(messageWrapper, this.appendMessageClass);
148
+ }
149
+ if (this.getHintWrapperSelector()) {
150
+ const hint = messageWrapper.querySelector(this.getHintWrapperSelector());
151
+ if (hint) {
152
+ renderer.setStyle(hint, 'display', error ? 'none' : 'block');
153
+ if (this.appendHintClass) {
154
+ renderer.addClass(hint, this.appendHintClass);
155
+ }
156
+ }
157
+ }
158
+ let errorWrapper = wrapper.querySelector('.fs-form-error-target');
159
+ if (errorWrapper) {
160
+ errorWrapper.remove();
161
+ }
162
+ if (!shouldErrorBeRendered || !error) {
163
+ return;
164
+ }
165
+ errorWrapper = renderer.createElement('div');
166
+ renderer.addClass(errorWrapper, 'fs-form-error-target');
167
+ renderer.addClass(errorWrapper, this.appendErrorClass);
168
+ renderer.addClass(errorWrapper, this.appendErrorClass + '-' + error.name);
169
+ const errorText = renderer.createText(error.message);
170
+ renderer.appendChild(errorWrapper, errorText);
171
+ messageWrapper.appendChild(errorWrapper);
172
+ }
173
+ }
174
+ getWrapper(node, count = 0) {
175
+ if (!node || count > 10) {
176
+ return null;
177
+ }
178
+ if (node.parentNode && node.parentNode.querySelector(this.getWrapperSelector())) {
179
+ return node;
180
+ }
181
+ return this.getWrapper(node.parentNode, ++count);
182
+ }
183
+ parseErrorMessage(message, args) {
184
+ values(args)
185
+ .forEach((name) => {
186
+ message = message.replace(/\$\(\d\)/, name);
187
+ });
188
+ return message;
189
+ }
190
+ getError(controlRef) {
191
+ const name = keys(controlRef.control.errors)[0];
192
+ if (!name) {
193
+ return null;
194
+ }
195
+ let message = controlRef.control.errors[name];
196
+ if (this._validateMessages[name]) {
197
+ message = this.parseErrorMessage(this._validateMessages[name], message);
198
+ }
199
+ return { name: name, message: message };
200
+ }
201
+ _setupValidators() {
202
+ const control = this._control;
203
+ if (this.validate) {
204
+ const validators = control.validator
205
+ ? [control.validator, this.validate.bind(this)]
206
+ : this.validate.bind(this);
207
+ control.setValidators(validators);
208
+ }
209
+ if (this.validateAsync) {
210
+ const asyncValidators = control.asyncValidator
211
+ ? [control.asyncValidator, this.validateAsync.bind(this)]
212
+ : this.validateAsync.bind(this);
213
+ control.setAsyncValidators(asyncValidators);
214
+ }
215
+ control.updateValueAndValidity();
216
+ }
217
+ }
218
+ 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 });
219
+ 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: [
220
+ VALIDATE_MESSAGE_PROVIDER
221
+ ], ngImport: i0 });
222
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsControlDirective, decorators: [{
223
+ type: Directive,
224
+ args: [{
225
+ selector: '[fsFormControl]',
226
+ providers: [
227
+ VALIDATE_MESSAGE_PROVIDER
228
+ ],
229
+ }]
230
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.Injector }, { type: undefined, decorators: [{
231
+ type: Self
232
+ }, {
233
+ type: Inject,
234
+ args: [VALIDATE_MESSAGES]
235
+ }] }, { type: i1.NgControl, decorators: [{
236
+ type: Optional
237
+ }] }, { type: i2.FsFormDirective, decorators: [{
238
+ type: Optional
239
+ }, {
240
+ type: Inject,
241
+ args: [FsFormDirective]
242
+ }] }]; }, propDecorators: { wrapperSelector: [{
243
+ type: Input
244
+ }], messageSelector: [{
245
+ type: Input
246
+ }], hintSelector: [{
247
+ type: Input
248
+ }], labelSelector: [{
249
+ type: Input
250
+ }], appendMessageClass: [{
251
+ type: Input
252
+ }], appendLabelClass: [{
253
+ type: Input
254
+ }], appendErrorClass: [{
255
+ type: Input
256
+ }], appendHintClass: [{
257
+ type: Input
258
+ }], validateMessages: [{
259
+ type: Input
260
+ }] } });
261
+ //# 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    this._subscribeToStatusChagnes();\n  }\n\n  protected _subscribeToStatusChagnes():void {\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"]}