@firestitch/form 12.0.1 → 12.0.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 (97) hide show
  1. package/app/components/form-dialog-actions/form-dialog-actions.component.d.ts +21 -21
  2. package/app/consts/error-messages.const.d.ts +19 -19
  3. package/app/directives/form/form.directive.d.ts +105 -105
  4. package/app/directives/form-dialog-close.directive.d.ts +12 -12
  5. package/app/directives/submit-button.directive.d.ts +31 -31
  6. package/app/directives/validators/compare.directive.d.ts +15 -15
  7. package/app/directives/validators/control.directive.d.ts +48 -48
  8. package/app/directives/validators/daterange.directive.d.ts +13 -13
  9. package/app/directives/validators/email.directive.d.ts +13 -13
  10. package/app/directives/validators/emails.directive.d.ts +13 -13
  11. package/app/directives/validators/function.directive.d.ts +14 -14
  12. package/app/directives/validators/greater.directive.d.ts +13 -13
  13. package/app/directives/validators/integer.directive.d.ts +13 -13
  14. package/app/directives/validators/lesser.directive.d.ts +13 -13
  15. package/app/directives/validators/max.directive.d.ts +13 -13
  16. package/app/directives/validators/maxlength.directive.d.ts +13 -13
  17. package/app/directives/validators/min.directive.d.ts +13 -13
  18. package/app/directives/validators/minlength.directive.d.ts +13 -13
  19. package/app/directives/validators/numeric.directive.d.ts +13 -13
  20. package/app/directives/validators/pattern.directive.d.ts +13 -13
  21. package/app/directives/validators/phone.directive.d.ts +13 -13
  22. package/app/directives/validators/required.directive.d.ts +16 -16
  23. package/app/directives/validators/url.directive.d.ts +14 -14
  24. package/app/directives/validators/validate.directive.d.ts +14 -14
  25. package/app/enums/confirm-result.d.ts +7 -7
  26. package/app/enums/form-status.d.ts +9 -9
  27. package/app/fs-form.module.d.ts +35 -35
  28. package/app/guards/form-deactivate.guard.d.ts +12 -12
  29. package/app/helpers/confirm-result-continue.d.ts +1 -1
  30. package/app/helpers/confirm-unsaved.d.ts +5 -5
  31. package/app/helpers/get-form-errors.d.ts +2 -2
  32. package/app/helpers/index.d.ts +2 -2
  33. package/app/helpers/is-enabled.d.ts +1 -1
  34. package/app/interfaces/async-validator.d.ts +14 -14
  35. package/app/interfaces/confirm-config.d.ts +7 -7
  36. package/app/interfaces/confirm-tab-group.d.ts +10 -10
  37. package/app/interfaces/form-deactivate.d.ts +4 -4
  38. package/app/interfaces/index.d.ts +4 -4
  39. package/app/interfaces/submit-event.d.ts +5 -5
  40. package/app/interfaces/submitted-event.d.ts +6 -6
  41. package/app/interfaces/validator.d.ts +13 -13
  42. package/app/providers/validate-messages.provider.d.ts +25 -25
  43. package/app/services/fsform.service.d.ts +10 -10
  44. package/app/validators/validators.d.ts +12 -12
  45. package/bundles/firestitch-form.umd.js +2613 -2613
  46. package/bundles/firestitch-form.umd.js.map +1 -1
  47. package/esm2015/app/components/form-dialog-actions/form-dialog-actions.component.js +85 -85
  48. package/esm2015/app/consts/error-messages.const.js +19 -19
  49. package/esm2015/app/directives/form/form.directive.js +618 -618
  50. package/esm2015/app/directives/form-dialog-close.directive.js +30 -30
  51. package/esm2015/app/directives/submit-button.directive.js +130 -130
  52. package/esm2015/app/directives/validators/compare.directive.js +48 -48
  53. package/esm2015/app/directives/validators/control.directive.js +256 -256
  54. package/esm2015/app/directives/validators/daterange.directive.js +40 -40
  55. package/esm2015/app/directives/validators/email.directive.js +40 -40
  56. package/esm2015/app/directives/validators/emails.directive.js +40 -40
  57. package/esm2015/app/directives/validators/function.directive.js +30 -30
  58. package/esm2015/app/directives/validators/greater.directive.js +39 -39
  59. package/esm2015/app/directives/validators/integer.directive.js +40 -40
  60. package/esm2015/app/directives/validators/lesser.directive.js +39 -39
  61. package/esm2015/app/directives/validators/max.directive.js +35 -35
  62. package/esm2015/app/directives/validators/maxlength.directive.js +34 -34
  63. package/esm2015/app/directives/validators/min.directive.js +35 -35
  64. package/esm2015/app/directives/validators/minlength.directive.js +34 -34
  65. package/esm2015/app/directives/validators/numeric.directive.js +40 -40
  66. package/esm2015/app/directives/validators/pattern.directive.js +35 -35
  67. package/esm2015/app/directives/validators/phone.directive.js +40 -40
  68. package/esm2015/app/directives/validators/required.directive.js +70 -70
  69. package/esm2015/app/directives/validators/url.directive.js +46 -46
  70. package/esm2015/app/directives/validators/validate.directive.js +32 -32
  71. package/esm2015/app/enums/confirm-result.js +8 -8
  72. package/esm2015/app/enums/form-status.js +10 -10
  73. package/esm2015/app/fs-form.module.js +164 -164
  74. package/esm2015/app/guards/form-deactivate.guard.js +39 -39
  75. package/esm2015/app/helpers/confirm-result-continue.js +4 -4
  76. package/esm2015/app/helpers/confirm-unsaved.js +69 -69
  77. package/esm2015/app/helpers/get-form-errors.js +24 -24
  78. package/esm2015/app/helpers/index.js +2 -2
  79. package/esm2015/app/helpers/is-enabled.js +3 -3
  80. package/esm2015/app/interfaces/async-validator.js +1 -1
  81. package/esm2015/app/interfaces/confirm-config.js +1 -1
  82. package/esm2015/app/interfaces/confirm-tab-group.js +1 -1
  83. package/esm2015/app/interfaces/form-deactivate.js +1 -1
  84. package/esm2015/app/interfaces/index.js +4 -4
  85. package/esm2015/app/interfaces/submit-event.js +1 -1
  86. package/esm2015/app/interfaces/submitted-event.js +1 -1
  87. package/esm2015/app/interfaces/validator.js +1 -1
  88. package/esm2015/app/providers/validate-messages.provider.js +10 -10
  89. package/esm2015/app/services/fsform.service.js +24 -24
  90. package/esm2015/app/validators/validators.js +96 -96
  91. package/esm2015/firestitch-form.js +4 -4
  92. package/esm2015/public_api.js +34 -34
  93. package/fesm2015/firestitch-form.js +2061 -2061
  94. package/fesm2015/firestitch-form.js.map +1 -1
  95. package/firestitch-form.d.ts +5 -5
  96. package/package.json +1 -1
  97. package/public_api.d.ts +33 -33
@@ -1,31 +1,31 @@
1
- import { Directive, HostListener, HostBinding } from '@angular/core';
2
- import { Subject } from 'rxjs';
3
- import * as i0 from "@angular/core";
4
- export class FsFormDialogCloseDirective {
5
- constructor() {
6
- this.clicked$ = new Subject();
7
- this.registered = false;
8
- this.type = 'button';
9
- }
10
- click() {
11
- this.clicked$.next();
12
- }
13
- ngOnDestroy() {
14
- this.clicked$.complete();
15
- }
16
- }
17
- FsFormDialogCloseDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsFormDialogCloseDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
18
- FsFormDialogCloseDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.16", type: FsFormDialogCloseDirective, selector: "[fsFormDialogClose],[fs-form-dialog-close]", host: { listeners: { "click": "click($event.target)" }, properties: { "attr.type": "this.type" } }, ngImport: i0 });
19
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsFormDialogCloseDirective, decorators: [{
20
- type: Directive,
21
- args: [{
22
- selector: '[fsFormDialogClose],[fs-form-dialog-close]'
23
- }]
24
- }], propDecorators: { type: [{
25
- type: HostBinding,
26
- args: ['attr.type']
27
- }], click: [{
28
- type: HostListener,
29
- args: ['click', ['$event.target']]
30
- }] } });
1
+ import { Directive, HostListener, HostBinding } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ import * as i0 from "@angular/core";
4
+ export class FsFormDialogCloseDirective {
5
+ constructor() {
6
+ this.clicked$ = new Subject();
7
+ this.registered = false;
8
+ this.type = 'button';
9
+ }
10
+ click() {
11
+ this.clicked$.next();
12
+ }
13
+ ngOnDestroy() {
14
+ this.clicked$.complete();
15
+ }
16
+ }
17
+ FsFormDialogCloseDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsFormDialogCloseDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
18
+ FsFormDialogCloseDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.16", type: FsFormDialogCloseDirective, selector: "[fsFormDialogClose],[fs-form-dialog-close]", host: { listeners: { "click": "click($event.target)" }, properties: { "attr.type": "this.type" } }, ngImport: i0 });
19
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsFormDialogCloseDirective, decorators: [{
20
+ type: Directive,
21
+ args: [{
22
+ selector: '[fsFormDialogClose],[fs-form-dialog-close]'
23
+ }]
24
+ }], propDecorators: { type: [{
25
+ type: HostBinding,
26
+ args: ['attr.type']
27
+ }], click: [{
28
+ type: HostListener,
29
+ args: ['click', ['$event.target']]
30
+ }] } });
31
31
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1kaWFsb2ctY2xvc2UuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FwcC9kaXJlY3RpdmVzL2Zvcm0tZGlhbG9nLWNsb3NlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBYSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEYsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQzs7QUFNL0IsTUFBTSxPQUFPLDBCQUEwQjtJQUh2QztRQUtTLGFBQVEsR0FBRyxJQUFJLE9BQU8sRUFBRSxDQUFDO1FBQ3pCLGVBQVUsR0FBRyxLQUFLLENBQUM7UUFFQSxTQUFJLEdBQUcsUUFBUSxDQUFDO0tBVTNDO0lBUFEsS0FBSztRQUNWLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDdkIsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUMzQixDQUFDOzt3SEFkVSwwQkFBMEI7NEdBQTFCLDBCQUEwQjs0RkFBMUIsMEJBQTBCO2tCQUh0QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSw0Q0FBNEM7aUJBQ3ZEOzhCQU0yQixJQUFJO3NCQUE3QixXQUFXO3VCQUFDLFdBQVc7Z0JBR2pCLEtBQUs7c0JBRFgsWUFBWTt1QkFBQyxPQUFPLEVBQUUsQ0FBQyxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEhvc3RMaXN0ZW5lciwgT25EZXN0cm95LCBIb3N0QmluZGluZyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuXG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tmc0Zvcm1EaWFsb2dDbG9zZV0sW2ZzLWZvcm0tZGlhbG9nLWNsb3NlXSdcbn0pXG5leHBvcnQgY2xhc3MgRnNGb3JtRGlhbG9nQ2xvc2VEaXJlY3RpdmUgaW1wbGVtZW50cyBPbkRlc3Ryb3kge1xuXG4gIHB1YmxpYyBjbGlja2VkJCA9IG5ldyBTdWJqZWN0KCk7XG4gIHB1YmxpYyByZWdpc3RlcmVkID0gZmFsc2U7XG5cbiAgQEhvc3RCaW5kaW5nKCdhdHRyLnR5cGUnKSB0eXBlID0gJ2J1dHRvbic7XG5cbiAgQEhvc3RMaXN0ZW5lcignY2xpY2snLCBbJyRldmVudC50YXJnZXQnXSlcbiAgcHVibGljIGNsaWNrKCkge1xuICAgIHRoaXMuY2xpY2tlZCQubmV4dCgpO1xuICB9XG5cbiAgcHVibGljIG5nT25EZXN0cm95KCkge1xuICAgIHRoaXMuY2xpY2tlZCQuY29tcGxldGUoKTtcbiAgfVxufVxuIl19
@@ -1,102 +1,102 @@
1
- import { Directive, Host, ElementRef, HostBinding, Optional, Input, ChangeDetectorRef } from '@angular/core';
2
- import { MatButton } from '@angular/material/button';
3
- import { FsFormDirective } from '../directives/form/form.directive';
4
- import { fromEvent, Subject } from 'rxjs';
5
- import { takeUntil } from 'rxjs/operators';
6
- import * as i0 from "@angular/core";
7
- import * as i1 from "@angular/material/button";
8
- import * as i2 from "../directives/form/form.directive";
9
- export class FsSubmitButtonDirective {
10
- constructor(_matButton, _form, _elementRef, _cdRef) {
11
- this._matButton = _matButton;
12
- this._form = _form;
13
- this._elementRef = _elementRef;
14
- this._cdRef = _cdRef;
15
- this.dirtySubmit = true;
16
- this.transitionStyle = null;
17
- this.active = false;
18
- this._destroy$ = new Subject();
19
- }
20
- ngOnInit() {
21
- if (this._form) {
22
- this._form.addSubmitButton(this);
23
- fromEvent(this.element, 'click')
24
- .pipe(takeUntil(this._destroy$))
25
- .subscribe(() => {
26
- this.active = true;
27
- });
28
- if (this.dirtySubmit) {
29
- if (this._form.dirtySubmitButton) {
30
- if (!this._form.ngForm.dirty) {
31
- this.disable();
32
- }
33
- }
34
- }
35
- this.transitionStyle = 'none';
36
- setTimeout(() => {
37
- this.transitionStyle = null;
38
- }, 500);
39
- }
40
- }
41
- disable() {
42
- if (this._matButton) {
43
- this._matButton.disabled = true;
44
- this._cdRef.markForCheck();
45
- }
46
- }
47
- enable() {
48
- if (this._matButton) {
49
- this._matButton.disabled = false;
50
- this._matButton.disableRipple = true;
51
- this._cdRef.markForCheck();
52
- }
53
- }
54
- process() {
55
- this.setClass('process');
56
- this._matButton.disableRipple = true;
57
- }
58
- success() {
59
- this.setClass('success');
60
- this._matButton.disableRipple = false;
61
- }
62
- error() {
63
- this.setClass('error');
64
- this._matButton.disableRipple = false;
65
- }
66
- setClass(cls) {
67
- const svg = this._getSvg(cls);
68
- this._resetClass();
69
- this._disableShadowAnimation();
70
- this.element.classList.add(`submit-${cls}`);
71
- this.element.append(svg);
72
- }
73
- get element() {
74
- return this._elementRef.nativeElement;
75
- }
76
- reset() {
77
- this.active = false;
78
- this.enable();
79
- this.element.querySelectorAll('.svg-icon')
80
- .forEach((el) => {
81
- el.remove();
82
- });
83
- this._matButton.disableRipple = false;
84
- this._resetClass();
85
- }
86
- ngOnDestroy() {
87
- this._destroy$.next();
88
- this._destroy$.complete();
89
- this._form.removeSubmitButton(this);
90
- }
91
- _disableShadowAnimation() {
92
- // .mat-elevation-z2 removes the click shadow animation
93
- //this.element.classList.add('mat-elevation-z2');
94
- }
95
- _resetClass() {
96
- this.element.classList.remove('submit-success', 'submit-error', 'submit-process', 'mat-elevation-z2');
97
- }
98
- _getSvg(type) {
99
- if (type === 'success') {
1
+ import { Directive, Host, ElementRef, HostBinding, Optional, Input, ChangeDetectorRef } from '@angular/core';
2
+ import { MatButton } from '@angular/material/button';
3
+ import { FsFormDirective } from '../directives/form/form.directive';
4
+ import { fromEvent, Subject } from 'rxjs';
5
+ import { takeUntil } from 'rxjs/operators';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/material/button";
8
+ import * as i2 from "../directives/form/form.directive";
9
+ export class FsSubmitButtonDirective {
10
+ constructor(_matButton, _form, _elementRef, _cdRef) {
11
+ this._matButton = _matButton;
12
+ this._form = _form;
13
+ this._elementRef = _elementRef;
14
+ this._cdRef = _cdRef;
15
+ this.dirtySubmit = true;
16
+ this.transitionStyle = null;
17
+ this.active = false;
18
+ this._destroy$ = new Subject();
19
+ }
20
+ ngOnInit() {
21
+ if (this._form) {
22
+ this._form.addSubmitButton(this);
23
+ fromEvent(this.element, 'click')
24
+ .pipe(takeUntil(this._destroy$))
25
+ .subscribe(() => {
26
+ this.active = true;
27
+ });
28
+ if (this.dirtySubmit) {
29
+ if (this._form.dirtySubmitButton) {
30
+ if (!this._form.ngForm.dirty) {
31
+ this.disable();
32
+ }
33
+ }
34
+ }
35
+ this.transitionStyle = 'none';
36
+ setTimeout(() => {
37
+ this.transitionStyle = null;
38
+ }, 500);
39
+ }
40
+ }
41
+ disable() {
42
+ if (this._matButton) {
43
+ this._matButton.disabled = true;
44
+ this._cdRef.markForCheck();
45
+ }
46
+ }
47
+ enable() {
48
+ if (this._matButton) {
49
+ this._matButton.disabled = false;
50
+ this._matButton.disableRipple = true;
51
+ this._cdRef.markForCheck();
52
+ }
53
+ }
54
+ process() {
55
+ this.setClass('process');
56
+ this._matButton.disableRipple = true;
57
+ }
58
+ success() {
59
+ this.setClass('success');
60
+ this._matButton.disableRipple = false;
61
+ }
62
+ error() {
63
+ this.setClass('error');
64
+ this._matButton.disableRipple = false;
65
+ }
66
+ setClass(cls) {
67
+ const svg = this._getSvg(cls);
68
+ this._resetClass();
69
+ this._disableShadowAnimation();
70
+ this.element.classList.add(`submit-${cls}`);
71
+ this.element.append(svg);
72
+ }
73
+ get element() {
74
+ return this._elementRef.nativeElement;
75
+ }
76
+ reset() {
77
+ this.active = false;
78
+ this.enable();
79
+ this.element.querySelectorAll('.svg-icon')
80
+ .forEach((el) => {
81
+ el.remove();
82
+ });
83
+ this._matButton.disableRipple = false;
84
+ this._resetClass();
85
+ }
86
+ ngOnDestroy() {
87
+ this._destroy$.next();
88
+ this._destroy$.complete();
89
+ this._form.removeSubmitButton(this);
90
+ }
91
+ _disableShadowAnimation() {
92
+ // .mat-elevation-z2 removes the click shadow animation
93
+ //this.element.classList.add('mat-elevation-z2');
94
+ }
95
+ _resetClass() {
96
+ this.element.classList.remove('submit-success', 'submit-error', 'submit-process', 'mat-elevation-z2');
97
+ }
98
+ _getSvg(type) {
99
+ if (type === 'success') {
100
100
  return new DOMParser().parseFromString(`<svg class="svg-icon svg-icon-success" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" x="0px" y="0px" viewBox="0 0 38 38" style="enable-background:new 0 0 38 38;" xml:space="preserve" width="38px" height="38px">
101
101
  <g>
102
102
  <g class="check">
@@ -105,41 +105,41 @@ export class FsSubmitButtonDirective {
105
105
  </g>
106
106
  </g>
107
107
  </g>
108
- </svg>`, 'text/xml').firstChild;
109
- }
110
- if (type === 'process') {
108
+ </svg>`, 'text/xml').firstChild;
109
+ }
110
+ if (type === 'process') {
111
111
  return new DOMParser().parseFromString(`<svg class="svg-icon svg-icon-process" width="38" height="38" viewBox="0 0 38 38" xmlns="http://www.w3.org/2000/svg">
112
112
  <g fill="none" fill-rule="evenodd">
113
113
  <g transform="translate(1 1)" stroke-width="2"><circle stroke-opacity=".5" cx="18" cy="18" r="18"/>
114
114
  <path d="M36 18c0-9.94-8.06-18-18-18"><animateTransform attributeName="transform" type="rotate" from="0 18 18" to="360 18 18" dur=".7s" repeatCount="indefinite"/></path>
115
115
  </g>
116
116
  </g>
117
- </svg>`, 'text/xml').firstChild;
118
- }
119
- if (type === 'error') {
120
- return new DOMParser().parseFromString(`<svg class="svg-icon svg-icon-error" xmlns="http://www.w3.org/2000/svg" width="38px" height="38px" viewBox="0 0 16 16"><g><path d="M8 1c3.9 0 7 3.1 7 7s-3.1 7-7 7-7-3.1-7-7 3.1-7 7-7zM8 0c-4.4 0-8 3.6-8 8s3.6 8 8 8 8-3.6 8-8-3.6-8-8-8v0z" data-original="#444444" data-old_color="#444444"/><path d="M12.2 10.8l-2.8-2.8 2.8-2.8-1.4-1.4-2.8 2.8-2.8-2.8-1.4 1.4 2.8 2.8-2.8 2.8 1.4 1.4 2.8-2.8 2.8 2.8z"/></g> </svg>`, 'text/xml').firstChild;
121
- }
122
- }
123
- }
124
- FsSubmitButtonDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsSubmitButtonDirective, deps: [{ token: i1.MatButton, host: true, optional: true }, { token: i2.FsFormDirective, optional: true }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
125
- FsSubmitButtonDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.16", type: FsSubmitButtonDirective, selector: "button[type=\"submit\"]", inputs: { name: "name", dirtySubmit: "dirtySubmit" }, host: { properties: { "style.transition": "this.transitionStyle" } }, ngImport: i0 });
126
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsSubmitButtonDirective, decorators: [{
127
- type: Directive,
128
- args: [{
129
- selector: 'button[type="submit"]',
130
- }]
131
- }], ctorParameters: function () { return [{ type: i1.MatButton, decorators: [{
132
- type: Optional
133
- }, {
134
- type: Host
135
- }] }, { type: i2.FsFormDirective, decorators: [{
136
- type: Optional
137
- }] }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { name: [{
138
- type: Input
139
- }], dirtySubmit: [{
140
- type: Input
141
- }], transitionStyle: [{
142
- type: HostBinding,
143
- args: ['style.transition']
144
- }] } });
117
+ </svg>`, 'text/xml').firstChild;
118
+ }
119
+ if (type === 'error') {
120
+ return new DOMParser().parseFromString(`<svg class="svg-icon svg-icon-error" xmlns="http://www.w3.org/2000/svg" width="38px" height="38px" viewBox="0 0 16 16"><g><path d="M8 1c3.9 0 7 3.1 7 7s-3.1 7-7 7-7-3.1-7-7 3.1-7 7-7zM8 0c-4.4 0-8 3.6-8 8s3.6 8 8 8 8-3.6 8-8-3.6-8-8-8v0z" data-original="#444444" data-old_color="#444444"/><path d="M12.2 10.8l-2.8-2.8 2.8-2.8-1.4-1.4-2.8 2.8-2.8-2.8-1.4 1.4 2.8 2.8-2.8 2.8 1.4 1.4 2.8-2.8 2.8 2.8z"/></g> </svg>`, 'text/xml').firstChild;
121
+ }
122
+ }
123
+ }
124
+ FsSubmitButtonDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsSubmitButtonDirective, deps: [{ token: i1.MatButton, host: true, optional: true }, { token: i2.FsFormDirective, optional: true }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
125
+ FsSubmitButtonDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.16", type: FsSubmitButtonDirective, selector: "button[type=\"submit\"]", inputs: { name: "name", dirtySubmit: "dirtySubmit" }, host: { properties: { "style.transition": "this.transitionStyle" } }, ngImport: i0 });
126
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsSubmitButtonDirective, decorators: [{
127
+ type: Directive,
128
+ args: [{
129
+ selector: 'button[type="submit"]',
130
+ }]
131
+ }], ctorParameters: function () { return [{ type: i1.MatButton, decorators: [{
132
+ type: Optional
133
+ }, {
134
+ type: Host
135
+ }] }, { type: i2.FsFormDirective, decorators: [{
136
+ type: Optional
137
+ }] }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { name: [{
138
+ type: Input
139
+ }], dirtySubmit: [{
140
+ type: Input
141
+ }], transitionStyle: [{
142
+ type: HostBinding,
143
+ args: ['style.transition']
144
+ }] } });
145
145
  //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"submit-button.directive.js","sourceRoot":"","sources":["../../../../src/app/directives/submit-button.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, OnInit, Host, ElementRef, HostBinding, Optional, Input, OnDestroy, ChangeDetectorRef } from '@angular/core';\n\nimport { MatButton } from '@angular/material/button';\nimport { FsFormDirective } from '../directives/form/form.directive';\n\nimport { fromEvent, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\n\n@Directive({\n  selector: 'button[type=\"submit\"]',\n})\nexport class FsSubmitButtonDirective implements OnInit, OnDestroy {\n\n  @Input()\n  public name;\n\n  @Input()\n  public dirtySubmit = true;\n\n  @HostBinding('style.transition')\n  public transitionStyle = null;\n\n  public active = false;\n\n  private _destroy$ = new Subject();\n\n  constructor(\n    @Optional() @Host() private _matButton: MatButton,\n    @Optional() private _form: FsFormDirective,\n    private _elementRef: ElementRef,\n    private _cdRef: ChangeDetectorRef,\n  ) {}\n\n  public ngOnInit() {\n    if (this._form) {\n      this._form.addSubmitButton(this); \n\n      fromEvent(this.element, 'click')\n        .pipe(\n          takeUntil(this._destroy$),\n        )\n        .subscribe(() => {\n          this.active = true;\n        });\n\n      if (this.dirtySubmit) {\n        if (this._form.dirtySubmitButton) {\n          if(!this._form.ngForm.dirty) {\n            this.disable();\n          }\n        }\n      } \n\n      this.transitionStyle = 'none';\n      setTimeout(() => {\n        this.transitionStyle = null;\n      }, 500);\n    }\n  }\n\n  public disable() {\n    if (this._matButton) {\n      this._matButton.disabled = true;\n      this._cdRef.markForCheck();\n    }\n  }\n\n  public enable() {\n    if (this._matButton) {\n      this._matButton.disabled = false;\n      this._matButton.disableRipple = true;\n      this._cdRef.markForCheck();\n    }\n  }\n\n  public process() {\n    this.setClass('process');\n    this._matButton.disableRipple = true;\n  }\n\n  public success() {\n    this.setClass('success');\n    this._matButton.disableRipple = false;\n  }\n\n  public error() {\n    this.setClass('error');\n    this._matButton.disableRipple = false;\n  }\n\n  public setClass(cls) {\n    const svg = this._getSvg(cls);\n    this._resetClass();\n    this._disableShadowAnimation();\n    this.element.classList.add(`submit-${cls}`);\n    this.element.append(svg);\n  }\n\n  public get element() {\n    return this._elementRef.nativeElement;\n  }\n\n  public reset() {\n    this.active = false;\n    this.enable();\n    this.element.querySelectorAll('.svg-icon')\n      .forEach((el) => {\n        el.remove();\n      });\n    this._matButton.disableRipple = false;\n    this._resetClass();\n  }\n\n  public ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n    this._form.removeSubmitButton(this);\n  }\n\n  private _disableShadowAnimation() {\n    // .mat-elevation-z2 removes the click shadow animation\n    //this.element.classList.add('mat-elevation-z2');\n  }\n\n  private _resetClass() {\n    this.element.classList.remove('submit-success', 'submit-error', 'submit-process', 'mat-elevation-z2');\n  }\n\n  private _getSvg(type) {\n    if (type === 'success') {\n      return new DOMParser().parseFromString(`<svg class=\"svg-icon svg-icon-success\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" version=\"1.1\" x=\"0px\" y=\"0px\" viewBox=\"0 0 38 38\" style=\"enable-background:new 0 0 38 38;\" xml:space=\"preserve\" width=\"38px\" height=\"38px\">\n      <g>\n        <g class=\"check\">\n          <g>\n            <path d=\"M29.6,11.9c-0.5-0.5-1.3-0.5-1.8,0L16.3,23.4l-6.1-6.1c-0.5-0.5-1.3-0.5-1.8,0s-0.5,1.3,0,1.8l7,7c0.3,0.3,0.6,0.4,0.9,0.4s0.7-0.1,0.9-0.4l12.4-12.4C30.1,13.2,30.1,12.4,29.6,11.9z\"/>\n          </g>\n        </g>\n      </g>\n      </svg>`, 'text/xml').firstChild;\n    }\n\n    if (type === 'process') {\n      return new DOMParser().parseFromString(`<svg class=\"svg-icon svg-icon-process\" width=\"38\" height=\"38\" viewBox=\"0 0 38 38\" xmlns=\"http://www.w3.org/2000/svg\">\n      <g fill=\"none\" fill-rule=\"evenodd\">\n        <g transform=\"translate(1 1)\" stroke-width=\"2\"><circle stroke-opacity=\".5\" cx=\"18\" cy=\"18\" r=\"18\"/>\n          <path d=\"M36 18c0-9.94-8.06-18-18-18\"><animateTransform attributeName=\"transform\" type=\"rotate\" from=\"0 18 18\" to=\"360 18 18\" dur=\".7s\" repeatCount=\"indefinite\"/></path>\n        </g>\n      </g>\n      </svg>`, 'text/xml').firstChild;\n    }\n\n    if (type === 'error') {\n      return new DOMParser().parseFromString(`<svg class=\"svg-icon svg-icon-error\" xmlns=\"http://www.w3.org/2000/svg\" width=\"38px\" height=\"38px\" viewBox=\"0 0 16 16\"><g><path d=\"M8 1c3.9 0 7 3.1 7 7s-3.1 7-7 7-7-3.1-7-7 3.1-7 7-7zM8 0c-4.4 0-8 3.6-8 8s3.6 8 8 8 8-3.6 8-8-3.6-8-8-8v0z\" data-original=\"#444444\" data-old_color=\"#444444\"/><path d=\"M12.2 10.8l-2.8-2.8 2.8-2.8-1.4-1.4-2.8 2.8-2.8-2.8-1.4 1.4 2.8 2.8-2.8 2.8 1.4 1.4 2.8-2.8 2.8 2.8z\"/></g> </svg>`, 'text/xml').firstChild;\n    }\n  }\n}\n"]}
@@ -1,49 +1,49 @@
1
- import { Directive, Input } from '@angular/core';
2
- import { FsControlDirective } from './control.directive';
3
- import { VALIDATE_MESSAGE_PROVIDER } from '../../providers/validate-messages.provider';
4
- import * as i0 from "@angular/core";
5
- export class FsFormCompareDirective extends FsControlDirective {
6
- set validationMessage(value) {
7
- this._validateMessages.compare = value;
8
- }
9
- ngOnChanges() {
10
- this._control.updateValueAndValidity();
11
- }
12
- validate(control) {
13
- if (this.fsFormCompare.value === this.elementRef.nativeElement.value) {
14
- return null;
15
- }
16
- else {
17
- return { compare: true };
18
- }
19
- }
20
- ngAfterViewInit() {
21
- this.fsFormCompare.addEventListener('keyup', () => {
22
- this._control.updateValueAndValidity();
23
- }, false);
24
- }
25
- ngOnDestroy() {
26
- this.fsFormCompare.removeEventListener('keyup', () => {
27
- this._control.updateValueAndValidity();
28
- }, false);
29
- }
30
- }
31
- FsFormCompareDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsFormCompareDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
32
- FsFormCompareDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.16", type: FsFormCompareDirective, selector: "[fsFormCompare]", inputs: { fsFormCompare: "fsFormCompare", validationMessage: ["fsFormCompareMessage", "validationMessage"] }, providers: [
33
- VALIDATE_MESSAGE_PROVIDER,
34
- ], usesInheritance: true, usesOnChanges: true, ngImport: i0 });
35
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsFormCompareDirective, decorators: [{
36
- type: Directive,
37
- args: [{
38
- selector: '[fsFormCompare]',
39
- providers: [
40
- VALIDATE_MESSAGE_PROVIDER,
41
- ],
42
- }]
43
- }], propDecorators: { fsFormCompare: [{
44
- type: Input
45
- }], validationMessage: [{
46
- type: Input,
47
- args: ['fsFormCompareMessage']
48
- }] } });
1
+ import { Directive, Input } from '@angular/core';
2
+ import { FsControlDirective } from './control.directive';
3
+ import { VALIDATE_MESSAGE_PROVIDER } from '../../providers/validate-messages.provider';
4
+ import * as i0 from "@angular/core";
5
+ export class FsFormCompareDirective extends FsControlDirective {
6
+ set validationMessage(value) {
7
+ this._validateMessages.compare = value;
8
+ }
9
+ ngOnChanges() {
10
+ this._control.updateValueAndValidity();
11
+ }
12
+ validate(control) {
13
+ if (this.fsFormCompare.value === this.elementRef.nativeElement.value) {
14
+ return null;
15
+ }
16
+ else {
17
+ return { compare: true };
18
+ }
19
+ }
20
+ ngAfterViewInit() {
21
+ this.fsFormCompare.addEventListener('keyup', () => {
22
+ this._control.updateValueAndValidity();
23
+ }, false);
24
+ }
25
+ ngOnDestroy() {
26
+ this.fsFormCompare.removeEventListener('keyup', () => {
27
+ this._control.updateValueAndValidity();
28
+ }, false);
29
+ }
30
+ }
31
+ FsFormCompareDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsFormCompareDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
32
+ FsFormCompareDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.16", type: FsFormCompareDirective, selector: "[fsFormCompare]", inputs: { fsFormCompare: "fsFormCompare", validationMessage: ["fsFormCompareMessage", "validationMessage"] }, providers: [
33
+ VALIDATE_MESSAGE_PROVIDER,
34
+ ], usesInheritance: true, usesOnChanges: true, ngImport: i0 });
35
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: FsFormCompareDirective, decorators: [{
36
+ type: Directive,
37
+ args: [{
38
+ selector: '[fsFormCompare]',
39
+ providers: [
40
+ VALIDATE_MESSAGE_PROVIDER,
41
+ ],
42
+ }]
43
+ }], propDecorators: { fsFormCompare: [{
44
+ type: Input
45
+ }], validationMessage: [{
46
+ type: Input,
47
+ args: ['fsFormCompareMessage']
48
+ }] } });
49
49
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcGFyZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvYXBwL2RpcmVjdGl2ZXMvdmFsaWRhdG9ycy9jb21wYXJlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBdUMsTUFBTSxlQUFlLENBQUM7QUFDdEYsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDekQsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sNENBQTRDLENBQUM7O0FBV3ZGLE1BQU0sT0FBTyxzQkFBdUIsU0FBUSxrQkFBa0I7SUFNNUQsSUFDVyxpQkFBaUIsQ0FBQyxLQUFhO1FBQ3hDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO0lBQ3pDLENBQUM7SUFFTSxXQUFXO1FBQ2hCLElBQUksQ0FBQyxRQUFRLENBQUMsc0JBQXNCLEVBQUUsQ0FBQztJQUN6QyxDQUFDO0lBRU0sUUFBUSxDQUFDLE9BQXdCO1FBQ3RDLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLEtBQUssSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFO1lBQ3BFLE9BQU8sSUFBSSxDQUFDO1NBQ2I7YUFBTTtZQUNMLE9BQU8sRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLENBQUM7U0FDMUI7SUFDSCxDQUFDO0lBRU0sZUFBZTtRQUNwQixJQUFJLENBQUMsYUFBYSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sRUFBRSxHQUFHLEVBQUU7WUFDaEQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxzQkFBc0IsRUFBRSxDQUFDO1FBQ3pDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUNaLENBQUM7SUFFTSxXQUFXO1FBQ2hCLElBQUksQ0FBQyxhQUFhLENBQUMsbUJBQW1CLENBQUMsT0FBTyxFQUFFLEdBQUcsRUFBRTtZQUNuRCxJQUFJLENBQUMsUUFBUSxDQUFDLHNCQUFzQixFQUFFLENBQUM7UUFDekMsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ1osQ0FBQzs7b0hBakNVLHNCQUFzQjt3R0FBdEIsc0JBQXNCLHdKQUp0QjtRQUNULHlCQUF5QjtLQUMxQjs0RkFFVSxzQkFBc0I7a0JBTmxDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGlCQUFpQjtvQkFDM0IsU0FBUyxFQUFFO3dCQUNULHlCQUF5QjtxQkFDMUI7aUJBQ0Y7OEJBS1EsYUFBYTtzQkFEbkIsS0FBSztnQkFJSyxpQkFBaUI7c0JBRDNCLEtBQUs7dUJBQUMsc0JBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBJbnB1dCwgT25EZXN0cm95LCBBZnRlclZpZXdJbml0LCBPbkNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZzQ29udHJvbERpcmVjdGl2ZSB9IGZyb20gJy4vY29udHJvbC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgVkFMSURBVEVfTUVTU0FHRV9QUk9WSURFUiB9IGZyb20gJy4uLy4uL3Byb3ZpZGVycy92YWxpZGF0ZS1tZXNzYWdlcy5wcm92aWRlcic7XG5pbXBvcnQgeyBBYnN0cmFjdENvbnRyb2wsIFZhbGlkYXRpb25FcnJvcnMgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBGc1ZhbGlkYXRvciB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvdmFsaWRhdG9yJztcblxuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZnNGb3JtQ29tcGFyZV0nLFxuICBwcm92aWRlcnM6IFtcbiAgICBWQUxJREFURV9NRVNTQUdFX1BST1ZJREVSLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBGc0Zvcm1Db21wYXJlRGlyZWN0aXZlIGV4dGVuZHMgRnNDb250cm9sRGlyZWN0aXZlXG4gIGltcGxlbWVudHMgT25DaGFuZ2VzLCBBZnRlclZpZXdJbml0LCBPbkRlc3Ryb3ksIEZzVmFsaWRhdG9yIHtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgZnNGb3JtQ29tcGFyZTtcblxuICBASW5wdXQoJ2ZzRm9ybUNvbXBhcmVNZXNzYWdlJylcbiAgcHVibGljIHNldCB2YWxpZGF0aW9uTWVzc2FnZSh2YWx1ZTogc3RyaW5nKSB7XG4gICAgdGhpcy5fdmFsaWRhdGVNZXNzYWdlcy5jb21wYXJlID0gdmFsdWU7XG4gIH1cblxuICBwdWJsaWMgbmdPbkNoYW5nZXMoKTogdm9pZCB7XG4gICAgdGhpcy5fY29udHJvbC51cGRhdGVWYWx1ZUFuZFZhbGlkaXR5KCk7XG4gIH1cblxuICBwdWJsaWMgdmFsaWRhdGUoY29udHJvbDogQWJzdHJhY3RDb250cm9sKTogVmFsaWRhdGlvbkVycm9ycyB8IG51bGwge1xuICAgIGlmICh0aGlzLmZzRm9ybUNvbXBhcmUudmFsdWUgPT09IHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LnZhbHVlKSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9IGVsc2Uge1xuICAgICAgcmV0dXJuIHsgY29tcGFyZTogdHJ1ZSB9O1xuICAgIH1cbiAgfVxuXG4gIHB1YmxpYyBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgdGhpcy5mc0Zvcm1Db21wYXJlLmFkZEV2ZW50TGlzdGVuZXIoJ2tleXVwJywgKCkgPT4ge1xuICAgICAgdGhpcy5fY29udHJvbC51cGRhdGVWYWx1ZUFuZFZhbGlkaXR5KCk7XG4gICAgfSwgZmFsc2UpO1xuICB9XG5cbiAgcHVibGljIG5nT25EZXN0cm95KCkge1xuICAgIHRoaXMuZnNGb3JtQ29tcGFyZS5yZW1vdmVFdmVudExpc3RlbmVyKCdrZXl1cCcsICgpID0+IHtcbiAgICAgIHRoaXMuX2NvbnRyb2wudXBkYXRlVmFsdWVBbmRWYWxpZGl0eSgpO1xuICAgIH0sIGZhbHNlKTtcbiAgfVxufVxuIl19