@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.
Files changed (36) hide show
  1. package/app/components/confirm-unsaved/confirm-unsaved.component.d.ts +1 -1
  2. package/app/directives/button.directive.d.ts +9 -14
  3. package/app/directives/form/form.directive.d.ts +12 -22
  4. package/app/directives/form-base/form-base.directive.d.ts +32 -0
  5. package/app/directives/form-base/index.d.ts +1 -0
  6. package/app/directives/form-group/form-group.directive.d.ts +12 -0
  7. package/app/directives/form-group/index.d.ts +1 -0
  8. package/app/directives/index.d.ts +3 -2
  9. package/app/fs-form.module.d.ts +2 -2
  10. package/app/interfaces/submit-event.d.ts +2 -2
  11. package/app/interfaces/submitted-event.d.ts +2 -5
  12. package/app/services/fsform.service.d.ts +3 -8
  13. package/esm2022/app/components/confirm-unsaved/confirm-unsaved.component.mjs +11 -6
  14. package/esm2022/app/components/form-dialog-actions/form-dialog-actions.component.mjs +1 -1
  15. package/esm2022/app/components/form-template/form-template.component.mjs +1 -1
  16. package/esm2022/app/components/form-template/index.mjs +1 -1
  17. package/esm2022/app/components/form-template-outlet/form-template-outlet.component.mjs +1 -1
  18. package/esm2022/app/components/form-template-outlet/index.mjs +1 -1
  19. package/esm2022/app/directives/button.directive.mjs +24 -52
  20. package/esm2022/app/directives/form/form.directive.mjs +94 -160
  21. package/esm2022/app/directives/form-base/form-base.directive.mjs +104 -0
  22. package/esm2022/app/directives/form-base/index.mjs +2 -0
  23. package/esm2022/app/directives/form-group/form-group.directive.mjs +32 -0
  24. package/esm2022/app/directives/form-group/index.mjs +2 -0
  25. package/esm2022/app/directives/index.mjs +4 -3
  26. package/esm2022/app/fs-form.module.mjs +8 -5
  27. package/esm2022/app/guards/form-deactivate.guard.mjs +2 -2
  28. package/esm2022/app/interfaces/submit-event.mjs +1 -1
  29. package/esm2022/app/interfaces/submitted-event.mjs +1 -1
  30. package/esm2022/app/services/fsform.service.mjs +12 -30
  31. package/esm2022/public_api.mjs +2 -1
  32. package/fesm2022/firestitch-form.mjs +301 -281
  33. package/fesm2022/firestitch-form.mjs.map +1 -1
  34. package/package.json +1 -1
  35. package/public_api.d.ts +1 -0
  36. package/styles.scss +36 -32
@@ -1,48 +1,35 @@
1
- import { ChangeDetectorRef, Directive, ElementRef, Host, HostBinding, Input, Optional, } from '@angular/core';
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/form.directive';
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
- constructor(_matButton, _form, _elementRef, _cdRef) {
23
- this._matButton = _matButton;
24
- this._form = _form;
25
- this._elementRef = _elementRef;
26
- this._cdRef = _cdRef;
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.form = this.form || this._form;
31
- if (this.form) {
32
- this.form.addButton(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.active = true;
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.active) {
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._disableShadowAnimation();
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.form?.removeButton(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.remove('submit-success', 'submit-error', 'submit-process', 'mat-elevation-z2');
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: [{ token: i1.MatButton, host: true, optional: true }, { token: i2.FsFormDirective, optional: true }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
150
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.7", type: FsButtonDirective, selector: "[mat-raised-button]:not([fsFormButtonStandalone]),[mat-button]:not([fsFormButtonStandalone]),[mat-flat-button]:not([fsFormButtonStandalone]),[mat-stroked-button]:not([fsFormButtonStandalone])", inputs: { name: "name", dirtySubmit: "dirtySubmit", form: "form" }, host: { properties: { "style.transition": "this.transitionStyle" } }, ngImport: i0 });
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]:not([fsFormButtonStandalone]),[mat-button]:not([fsFormButtonStandalone]),[mat-flat-button]:not([fsFormButtonStandalone]),[mat-stroked-button]:not([fsFormButtonStandalone])',
135
+ selector: '[mat-raised-button],[mat-button],[mat-flat-button],[mat-stroked-button]',
156
136
  }]
157
- }], ctorParameters: () => [{ type: i1.MatButton, decorators: [{
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"]}