@firestitch/form 18.0.8 → 18.0.10
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.
- package/app/components/confirm-unsaved/confirm-unsaved.component.d.ts +1 -1
- package/app/directives/button.directive.d.ts +9 -14
- package/app/directives/form/form.directive.d.ts +12 -22
- package/app/directives/form-base/form-base.directive.d.ts +32 -0
- package/app/directives/form-base/index.d.ts +1 -0
- package/app/directives/form-group/form-group.directive.d.ts +12 -0
- package/app/directives/form-group/index.d.ts +1 -0
- package/app/directives/index.d.ts +3 -2
- package/app/fs-form.module.d.ts +2 -2
- package/app/interfaces/submit-event.d.ts +2 -2
- package/app/interfaces/submitted-event.d.ts +2 -5
- package/app/services/fsform.service.d.ts +3 -8
- package/esm2022/app/components/confirm-unsaved/confirm-unsaved.component.mjs +11 -6
- package/esm2022/app/components/form-dialog-actions/form-dialog-actions.component.mjs +1 -1
- package/esm2022/app/components/form-template/form-template.component.mjs +1 -1
- package/esm2022/app/components/form-template/index.mjs +1 -1
- package/esm2022/app/components/form-template-outlet/form-template-outlet.component.mjs +1 -1
- package/esm2022/app/components/form-template-outlet/index.mjs +1 -1
- package/esm2022/app/directives/button.directive.mjs +24 -52
- package/esm2022/app/directives/form/form.directive.mjs +94 -160
- package/esm2022/app/directives/form-base/form-base.directive.mjs +104 -0
- package/esm2022/app/directives/form-base/index.mjs +2 -0
- package/esm2022/app/directives/form-group/form-group.directive.mjs +32 -0
- package/esm2022/app/directives/form-group/index.mjs +2 -0
- package/esm2022/app/directives/index.mjs +4 -3
- package/esm2022/app/fs-form.module.mjs +8 -5
- package/esm2022/app/guards/form-deactivate.guard.mjs +2 -2
- package/esm2022/app/interfaces/submit-event.mjs +1 -1
- package/esm2022/app/interfaces/submitted-event.mjs +1 -1
- package/esm2022/app/services/fsform.service.mjs +12 -30
- package/esm2022/public_api.mjs +2 -1
- package/fesm2022/firestitch-form.mjs +301 -281
- package/fesm2022/firestitch-form.mjs.map +1 -1
- package/package.json +1 -1
- package/public_api.d.ts +1 -0
- package/styles.scss +36 -32
|
@@ -1,48 +1,35 @@
|
|
|
1
|
-
import { ChangeDetectorRef, Directive, ElementRef,
|
|
1
|
+
import { ChangeDetectorRef, Directive, ElementRef, HostBinding, inject, Input, } from '@angular/core';
|
|
2
2
|
import { MatButton } from '@angular/material/button';
|
|
3
3
|
import { fromEvent, Subject } from 'rxjs';
|
|
4
4
|
import { takeUntil } from 'rxjs/operators';
|
|
5
|
-
import { FsFormDirective } from './form
|
|
5
|
+
import { FsFormDirective } from './form';
|
|
6
|
+
import { FsFormGroupDirective } from './form-group';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "@angular/material/button";
|
|
8
|
-
import * as i2 from "./form/form.directive";
|
|
9
8
|
export class FsButtonDirective {
|
|
10
|
-
_matButton;
|
|
11
|
-
_form;
|
|
12
|
-
_elementRef;
|
|
13
|
-
_cdRef;
|
|
14
9
|
name;
|
|
15
10
|
dirtySubmit = true;
|
|
16
|
-
form;
|
|
17
11
|
transitionStyle = null;
|
|
18
|
-
active = false;
|
|
19
12
|
submit = false;
|
|
20
13
|
_previousDisabled = false;
|
|
21
14
|
_destroy$ = new Subject();
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
15
|
+
_formGroup = inject(FsFormGroupDirective, { optional: true });
|
|
16
|
+
_form = inject(FsFormDirective, { optional: true });
|
|
17
|
+
_matButton = inject(MatButton, { optional: true, host: true });
|
|
18
|
+
_elementRef = inject(ElementRef);
|
|
19
|
+
_cdRef = inject(ChangeDetectorRef);
|
|
20
|
+
_formBase;
|
|
28
21
|
ngOnInit() {
|
|
29
22
|
this.submit = this._elementRef.nativeElement.getAttribute('type') === 'submit';
|
|
30
|
-
this.
|
|
31
|
-
if (this.
|
|
32
|
-
this.
|
|
23
|
+
this._formBase = this._form || this._formGroup;
|
|
24
|
+
if (this._formBase) {
|
|
25
|
+
this._formBase.addButton(this);
|
|
33
26
|
if (this.submit) {
|
|
34
27
|
fromEvent(this.element, 'click')
|
|
35
28
|
.pipe(takeUntil(this._destroy$))
|
|
36
29
|
.subscribe(() => {
|
|
37
|
-
this.
|
|
30
|
+
this._formBase.activeSubmitButton = this;
|
|
31
|
+
this._formBase.triggerSubmit();
|
|
38
32
|
});
|
|
39
|
-
if (this.dirtySubmit) {
|
|
40
|
-
if (this.form.dirtySubmitButton) {
|
|
41
|
-
if (!this.form.ngForm.dirty) {
|
|
42
|
-
this.disable();
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
}
|
|
46
33
|
this.transitionStyle = 'none';
|
|
47
34
|
setTimeout(() => {
|
|
48
35
|
this.transitionStyle = null;
|
|
@@ -51,7 +38,7 @@ export class FsButtonDirective {
|
|
|
51
38
|
}
|
|
52
39
|
}
|
|
53
40
|
disable() {
|
|
54
|
-
if (this._matButton && !this.
|
|
41
|
+
if (this._matButton && !this._formBase.activeSubmitButton) {
|
|
55
42
|
this._previousDisabled = this._matButton.disabled;
|
|
56
43
|
this._matButton.disabled = true;
|
|
57
44
|
this._matButton.disableRipple = true;
|
|
@@ -86,16 +73,12 @@ export class FsButtonDirective {
|
|
|
86
73
|
setClass(cls) {
|
|
87
74
|
const svg = this._getSvg(cls);
|
|
88
75
|
this._resetClass();
|
|
89
|
-
this.
|
|
90
|
-
this.element.classList.add(`submit-${cls}`);
|
|
76
|
+
this.element.classList.add(`fs-form-submit-button-${cls}`);
|
|
91
77
|
this.element.append(svg);
|
|
92
78
|
}
|
|
93
79
|
get element() {
|
|
94
80
|
return this._elementRef.nativeElement;
|
|
95
81
|
}
|
|
96
|
-
resetActive() {
|
|
97
|
-
this.active = false;
|
|
98
|
-
}
|
|
99
82
|
reset() {
|
|
100
83
|
if (!this._previousDisabled) {
|
|
101
84
|
this.enable();
|
|
@@ -112,14 +95,11 @@ export class FsButtonDirective {
|
|
|
112
95
|
ngOnDestroy() {
|
|
113
96
|
this._destroy$.next(null);
|
|
114
97
|
this._destroy$.complete();
|
|
115
|
-
this.
|
|
116
|
-
}
|
|
117
|
-
_disableShadowAnimation() {
|
|
118
|
-
// .mat-elevation-z2 removes the click shadow animation
|
|
119
|
-
//this.element.classList.add('mat-elevation-z2');
|
|
98
|
+
this._formBase?.removeButton(this);
|
|
120
99
|
}
|
|
121
100
|
_resetClass() {
|
|
122
|
-
this.element.classList
|
|
101
|
+
this.element.classList
|
|
102
|
+
.remove('fs-form-submit-button-success', 'fs-form-submit-button-error', 'fs-form-submit-button-process');
|
|
123
103
|
}
|
|
124
104
|
_getSvg(type) {
|
|
125
105
|
if (type === 'success') {
|
|
@@ -146,28 +126,20 @@ export class FsButtonDirective {
|
|
|
146
126
|
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;
|
|
147
127
|
}
|
|
148
128
|
}
|
|
149
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: FsButtonDirective, deps: [
|
|
150
|
-
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.7", type: FsButtonDirective, selector: "[mat-raised-button]
|
|
129
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: FsButtonDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
130
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.7", type: FsButtonDirective, selector: "[mat-raised-button],[mat-button],[mat-flat-button],[mat-stroked-button]", inputs: { name: "name", dirtySubmit: "dirtySubmit" }, host: { properties: { "style.transition": "this.transitionStyle" } }, ngImport: i0 });
|
|
151
131
|
}
|
|
152
132
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: FsButtonDirective, decorators: [{
|
|
153
133
|
type: Directive,
|
|
154
134
|
args: [{
|
|
155
|
-
selector: '[mat-raised-button]
|
|
135
|
+
selector: '[mat-raised-button],[mat-button],[mat-flat-button],[mat-stroked-button]',
|
|
156
136
|
}]
|
|
157
|
-
}],
|
|
158
|
-
type: Optional
|
|
159
|
-
}, {
|
|
160
|
-
type: Host
|
|
161
|
-
}] }, { type: i2.FsFormDirective, decorators: [{
|
|
162
|
-
type: Optional
|
|
163
|
-
}] }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }], propDecorators: { name: [{
|
|
137
|
+
}], propDecorators: { name: [{
|
|
164
138
|
type: Input
|
|
165
139
|
}], dirtySubmit: [{
|
|
166
140
|
type: Input
|
|
167
|
-
}], form: [{
|
|
168
|
-
type: Input
|
|
169
141
|
}], transitionStyle: [{
|
|
170
142
|
type: HostBinding,
|
|
171
143
|
args: ['style.transition']
|
|
172
144
|
}] } });
|
|
173
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.directive.js","sourceRoot":"","sources":["../../../../src/app/directives/button.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef, Directive, ElementRef, Host, HostBinding, Input, OnDestroy, OnInit, Optional,\n} from '@angular/core';\n\nimport { MatButton } from '@angular/material/button';\n\n\nimport { fromEvent, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { FsFormDirective } from './form/form.directive';\n\n\n@Directive({\n  selector: '[mat-raised-button]:not([fsFormButtonStandalone]),[mat-button]:not([fsFormButtonStandalone]),[mat-flat-button]:not([fsFormButtonStandalone]),[mat-stroked-button]:not([fsFormButtonStandalone])',\n})\nexport class FsButtonDirective implements OnInit, OnDestroy {\n\n  @Input()\n  public name;\n\n  @Input()\n  public dirtySubmit = true;\n\n  @Input()\n  public form: FsFormDirective;\n\n  @HostBinding('style.transition')\n  public transitionStyle = null;\n\n  public active = false;\n  public submit = false;\n\n  private _previousDisabled = false;\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    this.submit = this._elementRef.nativeElement.getAttribute('type') === 'submit';\n    this.form = this.form || this._form;\n\n    if (this.form) {\n      this.form.addButton(this);\n\n      if(this.submit) {\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\n  public disable() {    \n    if (this._matButton && !this.active) {\n      this._previousDisabled = this._matButton.disabled;\n      this._matButton.disabled = true;\n      this._matButton.disableRipple = 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    if (this._matButton) {\n      this._matButton.disableRipple = true;\n    }\n  }\n\n  public success() {\n    this.setClass('success');\n    if (this._matButton) {\n      this._matButton.disableRipple = false;\n    }\n  }\n\n  public error() {\n    this.setClass('error');\n    if (this._matButton) {\n      this._matButton.disableRipple = false;\n    }\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 resetActive() {\n    this.active = false;\n  }\n\n  public reset() {\n    if(!this._previousDisabled) {\n      this.enable();\n    }\n\n    this.element.querySelectorAll('.svg-icon')\n      .forEach((el) => {\n        el.remove();\n      });\n\n    if (this._matButton) {\n      this._matButton.disableRipple = false;\n    }\n    this._resetClass();\n  }\n\n  public ngOnDestroy(): void {\n    this._destroy$.next(null);\n    this._destroy$.complete();\n    this.form?.removeButton(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"]}
|
|
145
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.directive.js","sourceRoot":"","sources":["../../../../src/app/directives/button.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef, Directive, ElementRef,\n  HostBinding, inject, Input, OnDestroy, OnInit,\n} from '@angular/core';\n\nimport { MatButton } from '@angular/material/button';\n\nimport { fromEvent, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { FsFormDirective } from './form';\nimport { FsFormBaseDirective } from './form-base';\nimport { FsFormGroupDirective } from './form-group';\n\n\n@Directive({\n  selector: '[mat-raised-button],[mat-button],[mat-flat-button],[mat-stroked-button]',\n})\nexport class FsButtonDirective 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 submit = false;\n\n  private _previousDisabled = false;\n  private _destroy$ = new Subject();\n\n  private _formGroup = inject(FsFormGroupDirective, { optional: true });\n  private _form = inject(FsFormDirective, { optional: true });\n  private _matButton = inject(MatButton, { optional: true, host: true });\n  private _elementRef = inject(ElementRef);\n  private _cdRef = inject(ChangeDetectorRef);\n  private _formBase: FsFormBaseDirective;\n\n  public ngOnInit() {\n    this.submit = this._elementRef.nativeElement.getAttribute('type') === 'submit';\n    this._formBase = this._form || this._formGroup;\n\n    if (this._formBase) {\n      this._formBase.addButton(this);\n\n      if(this.submit) {\n        fromEvent(this.element, 'click')\n          .pipe(\n            takeUntil(this._destroy$),\n          )\n          .subscribe(() => {\n            this._formBase.activeSubmitButton = this;\n            this._formBase.triggerSubmit();\n          });\n\n        this.transitionStyle = 'none';\n        setTimeout(() => {\n          this.transitionStyle = null;\n        }, 500);\n      }\n    }\n  }\n\n  public disable() {    \n    if (this._matButton && !this._formBase.activeSubmitButton) {\n      this._previousDisabled = this._matButton.disabled;\n      this._matButton.disabled = true;\n      this._matButton.disableRipple = 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    if (this._matButton) {\n      this._matButton.disableRipple = true;\n    }\n  }\n\n  public success() {\n    this.setClass('success');\n    if (this._matButton) {\n      this._matButton.disableRipple = false;\n    }\n  }\n\n  public error() {\n    this.setClass('error');\n    if (this._matButton) {\n      this._matButton.disableRipple = false;\n    }\n  }\n\n  public setClass(cls) {\n    const svg = this._getSvg(cls);\n    this._resetClass();\n    this.element.classList.add(`fs-form-submit-button-${cls}`);\n    this.element.append(svg);\n  }\n\n  public get element() {\n    return this._elementRef.nativeElement;\n  }\n\n  public reset() {\n    if(!this._previousDisabled) {\n      this.enable();\n    }\n\n    this.element.querySelectorAll('.svg-icon')\n      .forEach((el) => {\n        el.remove();\n      });\n\n    if (this._matButton) {\n      this._matButton.disableRipple = false;\n    }\n    this._resetClass();\n  }\n\n  public ngOnDestroy(): void {\n    this._destroy$.next(null);\n    this._destroy$.complete();\n    this._formBase?.removeButton(this);\n  }\n\n  private _resetClass() {\n    this.element.classList\n      .remove(\n        'fs-form-submit-button-success', \n        'fs-form-submit-button-error', \n        'fs-form-submit-button-process',\n      );\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"]}
|