@sd-angular/core 1.2.26 → 1.2.29

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 (91) hide show
  1. package/bundles/sd-angular-core-button.umd.js +1 -0
  2. package/bundles/sd-angular-core-button.umd.js.map +1 -1
  3. package/bundles/sd-angular-core-button.umd.min.js +1 -1
  4. package/bundles/sd-angular-core-button.umd.min.js.map +1 -1
  5. package/bundles/sd-angular-core-date-range.umd.js +7 -1
  6. package/bundles/sd-angular-core-date-range.umd.js.map +1 -1
  7. package/bundles/sd-angular-core-date-range.umd.min.js +1 -1
  8. package/bundles/sd-angular-core-date-range.umd.min.js.map +1 -1
  9. package/bundles/sd-angular-core-date-time.umd.js +57 -13
  10. package/bundles/sd-angular-core-date-time.umd.js.map +1 -1
  11. package/bundles/sd-angular-core-date-time.umd.min.js +1 -1
  12. package/bundles/sd-angular-core-date-time.umd.min.js.map +1 -1
  13. package/bundles/sd-angular-core-editor.umd.js +54 -41
  14. package/bundles/sd-angular-core-editor.umd.js.map +1 -1
  15. package/bundles/sd-angular-core-editor.umd.min.js +1 -1
  16. package/bundles/sd-angular-core-editor.umd.min.js.map +1 -1
  17. package/bundles/sd-angular-core-grid-material.umd.js +21 -3
  18. package/bundles/sd-angular-core-grid-material.umd.js.map +1 -1
  19. package/bundles/sd-angular-core-grid-material.umd.min.js +1 -1
  20. package/bundles/sd-angular-core-grid-material.umd.min.js.map +1 -1
  21. package/bundles/sd-angular-core-input-currency.umd.js +3 -0
  22. package/bundles/sd-angular-core-input-currency.umd.js.map +1 -1
  23. package/bundles/sd-angular-core-input-currency.umd.min.js +2 -2
  24. package/bundles/sd-angular-core-input-currency.umd.min.js.map +1 -1
  25. package/bundles/sd-angular-core-select-editor.umd.js +1 -0
  26. package/bundles/sd-angular-core-select-editor.umd.js.map +1 -1
  27. package/bundles/sd-angular-core-select-editor.umd.min.js +1 -1
  28. package/bundles/sd-angular-core-select-editor.umd.min.js.map +1 -1
  29. package/bundles/sd-angular-core-switch.umd.js +1 -0
  30. package/bundles/sd-angular-core-switch.umd.js.map +1 -1
  31. package/bundles/sd-angular-core-switch.umd.min.js +1 -1
  32. package/bundles/sd-angular-core-switch.umd.min.js.map +1 -1
  33. package/bundles/sd-angular-core-tab-router.umd.js +4 -1
  34. package/bundles/sd-angular-core-tab-router.umd.js.map +1 -1
  35. package/bundles/sd-angular-core-tab-router.umd.min.js +2 -2
  36. package/bundles/sd-angular-core-tab-router.umd.min.js.map +1 -1
  37. package/bundles/sd-angular-core-utility.umd.js +17 -0
  38. package/bundles/sd-angular-core-utility.umd.js.map +1 -1
  39. package/bundles/sd-angular-core-utility.umd.min.js +1 -1
  40. package/bundles/sd-angular-core-utility.umd.min.js.map +1 -1
  41. package/button/sd-angular-core-button.metadata.json +1 -1
  42. package/date-range/sd-angular-core-date-range.metadata.json +1 -1
  43. package/date-range/src/lib/date-range.component.d.ts +3 -2
  44. package/date-time/sd-angular-core-date-time.metadata.json +1 -1
  45. package/date-time/src/lib/date-time.component.d.ts +5 -0
  46. package/editor/sd-angular-core-editor.metadata.json +1 -1
  47. package/editor/src/lib/editor.component.d.ts +3 -2
  48. package/esm2015/button/src/lib/button.component.js +3 -2
  49. package/esm2015/date-range/src/lib/date-range.component.js +9 -3
  50. package/esm2015/date-time/src/lib/date-time.component.js +54 -14
  51. package/esm2015/editor/src/lib/editor.component.js +55 -42
  52. package/esm2015/grid-material/src/lib/components/desktop-command/desktop-command.component.js +3 -2
  53. package/esm2015/grid-material/src/lib/components/grid-filter/grid-filter.component.js +10 -3
  54. package/esm2015/grid-material/src/lib/components/popup-export/popup-export.component.js +4 -2
  55. package/esm2015/grid-material/src/lib/components/popup-filter/popup-filter.component.js +12 -4
  56. package/esm2015/input-currency/src/lib/input-currency.component.js +5 -2
  57. package/esm2015/select-editor/src/lib/select-editor.component.js +3 -2
  58. package/esm2015/switch/src/lib/switch.component.js +3 -2
  59. package/esm2015/tab-router/src/lib/components/tab-router-outlet/tab-router-outlet.component.js +5 -2
  60. package/esm2015/utility/src/lib/utility.service.js +18 -1
  61. package/fesm2015/sd-angular-core-button.js +2 -1
  62. package/fesm2015/sd-angular-core-button.js.map +1 -1
  63. package/fesm2015/sd-angular-core-date-range.js +8 -2
  64. package/fesm2015/sd-angular-core-date-range.js.map +1 -1
  65. package/fesm2015/sd-angular-core-date-time.js +53 -13
  66. package/fesm2015/sd-angular-core-date-time.js.map +1 -1
  67. package/fesm2015/sd-angular-core-editor.js +54 -41
  68. package/fesm2015/sd-angular-core-editor.js.map +1 -1
  69. package/fesm2015/sd-angular-core-grid-material.js +22 -4
  70. package/fesm2015/sd-angular-core-grid-material.js.map +1 -1
  71. package/fesm2015/sd-angular-core-input-currency.js +4 -1
  72. package/fesm2015/sd-angular-core-input-currency.js.map +1 -1
  73. package/fesm2015/sd-angular-core-select-editor.js +2 -1
  74. package/fesm2015/sd-angular-core-select-editor.js.map +1 -1
  75. package/fesm2015/sd-angular-core-switch.js +2 -1
  76. package/fesm2015/sd-angular-core-switch.js.map +1 -1
  77. package/fesm2015/sd-angular-core-tab-router.js +4 -1
  78. package/fesm2015/sd-angular-core-tab-router.js.map +1 -1
  79. package/fesm2015/sd-angular-core-utility.js +17 -0
  80. package/fesm2015/sd-angular-core-utility.js.map +1 -1
  81. package/grid-material/sd-angular-core-grid-material.metadata.json +1 -1
  82. package/grid-material/src/lib/components/grid-filter/grid-filter.component.d.ts +3 -2
  83. package/grid-material/src/lib/components/popup-filter/popup-filter.component.d.ts +3 -2
  84. package/input-currency/sd-angular-core-input-currency.metadata.json +1 -1
  85. package/package.json +1 -1
  86. package/{sd-angular-core-1.2.26.tgz → sd-angular-core-1.2.29.tgz} +0 -0
  87. package/select-editor/sd-angular-core-select-editor.metadata.json +1 -1
  88. package/switch/sd-angular-core-switch.metadata.json +1 -1
  89. package/tab-router/sd-angular-core-tab-router.metadata.json +1 -1
  90. package/tab-router/src/lib/components/tab-router-outlet/tab-router-outlet.component.d.ts +1 -0
  91. package/utility/src/lib/utility.service.d.ts +1 -0
@@ -1,6 +1,6 @@
1
1
  var _name, _subscription, _model, _form, _updateValidator, _uploadImage;
2
2
  import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
- import { Component, ViewChild, Input, Output, EventEmitter, ChangeDetectorRef } from '@angular/core';
3
+ import { Component, ViewChild, Input, Output, EventEmitter, ChangeDetectorRef, ChangeDetectionStrategy, NgZone } from '@angular/core';
4
4
  import * as uuid from 'uuid';
5
5
  import { FormControl, NgForm, Validators } from '@angular/forms';
6
6
  import { Constants } from './constant';
@@ -8,7 +8,8 @@ import { Subscription } from 'rxjs';
8
8
  import { SdApiService } from '@sd-angular/core/api';
9
9
  import 'quill-mention';
10
10
  export class SdEditor {
11
- constructor(ref, sdApiService) {
11
+ constructor(ngZone, ref, sdApiService) {
12
+ this.ngZone = ngZone;
12
13
  this.ref = ref;
13
14
  this.sdApiService = sdApiService;
14
15
  _name.set(this, `N${uuid.v4()}`);
@@ -104,6 +105,7 @@ export class SdEditor {
104
105
  }
105
106
  this.formControl.setValidators(validators);
106
107
  this.formControl.updateValueAndValidity();
108
+ this.ref.markForCheck();
107
109
  });
108
110
  this.editorInit = (quill) => {
109
111
  this.quillEvent = quill;
@@ -126,43 +128,48 @@ export class SdEditor {
126
128
  // // this.formControl.setValue(html);
127
129
  // });
128
130
  const self = this;
129
- quill.getModule('toolbar').addHandler('image', function () {
130
- let fileInput = this.container.querySelector('input.ql-image[type=file]');
131
- if (fileInput == null) {
132
- fileInput = document.createElement('input');
133
- fileInput.setAttribute('type', Constants.FILE);
134
- fileInput.setAttribute('accept', 'image/png, image/gif, image/jpeg, image/bmp, image/x-icon');
135
- fileInput.classList.add('ql-image');
136
- fileInput.addEventListener('change', () => {
137
- const files = fileInput.files;
138
- const range = this.quill.getSelection(true);
139
- if (!files || !files.length) {
140
- return;
141
- }
142
- const formData = new FormData();
143
- formData.append(Constants.FILE, files[0]);
144
- this.quill.enable(false);
145
- /*this.apiService.post(this.domain + this.urlUploadImage, formData).subscribe((resp: any) => {
146
- this.quill.enable(true);
147
- this.quill.editor.insertEmbed(range.index, 'image', resp.data.imageUrl || resp.data.publish_url || resp.url);
148
- const content = this.quill.getContents();
149
- this.quill.setContents(content);
150
- this.quill.setSelection(range.index + 1, 'silent');
151
- fileInput.value = '';
152
- });*/
153
- __classPrivateFieldGet(self, _uploadImage).call(self, formData, quill, range, fileInput);
154
- });
155
- this.container.appendChild(fileInput);
156
- }
157
- fileInput.click();
131
+ this.ngZone.runOutsideAngular(() => {
132
+ quill.getModule('toolbar').addHandler('image', function () {
133
+ let fileInput = this.container.querySelector('input.ql-image[type=file]');
134
+ if (fileInput == null) {
135
+ fileInput = document.createElement('input');
136
+ fileInput.setAttribute('type', Constants.FILE);
137
+ fileInput.setAttribute('accept', 'image/png, image/gif, image/jpeg, image/bmp, image/x-icon');
138
+ fileInput.classList.add('ql-image');
139
+ fileInput.addEventListener('change', () => {
140
+ const files = fileInput.files;
141
+ const range = this.quill.getSelection(true);
142
+ if (!files || !files.length) {
143
+ return;
144
+ }
145
+ const formData = new FormData();
146
+ formData.append(Constants.FILE, files[0]);
147
+ this.quill.enable(false);
148
+ /*this.apiService.post(this.domain + this.urlUploadImage, formData).subscribe((resp: any) => {
149
+ this.quill.enable(true);
150
+ this.quill.editor.insertEmbed(range.index, 'image', resp.data.imageUrl || resp.data.publish_url || resp.url);
151
+ const content = this.quill.getContents();
152
+ this.quill.setContents(content);
153
+ this.quill.setSelection(range.index + 1, 'silent');
154
+ fileInput.value = '';
155
+ });*/
156
+ __classPrivateFieldGet(self, _uploadImage).call(self, formData, quill, range, fileInput);
157
+ });
158
+ this.container.appendChild(fileInput);
159
+ }
160
+ fileInput.click();
161
+ });
158
162
  });
163
+ this.ref.markForCheck();
159
164
  };
160
165
  this.onModelChange = (val) => {
161
166
  this.formControl.setValue(val);
162
167
  this.modelHTML = val;
168
+ this.ref.markForCheck();
163
169
  };
164
170
  this.onClickShowHtmlEditor = () => {
165
171
  this.showHtmlEditor = !this.showHtmlEditor;
172
+ this.ref.markForCheck();
166
173
  };
167
174
  _uploadImage.set(this, (formData, quill, range, fileInput) => {
168
175
  if (!this.urlUploadImage) {
@@ -170,17 +177,20 @@ export class SdEditor {
170
177
  }
171
178
  // this.domain = 'https://api-commerce-qc.vinid.dev';
172
179
  this.sdApiService.post(this.urlUploadImage, formData).then((resp) => {
173
- var _a, _b, _c, _d;
174
- quill.enable(true);
175
- // quill.editor.insertEmbed(range.index, 'image', resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '');
176
- quill.getModule('clipboard').dangerouslyPasteHTML(range.index, '<a target="_blank" href="' + (((_a = resp === null || resp === void 0 ? void 0 : resp.data) === null || _a === void 0 ? void 0 : _a.imageUrl) || ((_b = resp === null || resp === void 0 ? void 0 : resp.data) === null || _b === void 0 ? void 0 : _b.publish_url) || (resp === null || resp === void 0 ? void 0 : resp.url) || '')
177
- + '"><img src="' + (((_c = resp === null || resp === void 0 ? void 0 : resp.data) === null || _c === void 0 ? void 0 : _c.imageUrl) || ((_d = resp === null || resp === void 0 ? void 0 : resp.data) === null || _d === void 0 ? void 0 : _d.publish_url) || (resp === null || resp === void 0 ? void 0 : resp.url) || '') + '" alt="c-image-editor-quill"></a>', 'user');
178
- // quill.insertText();
179
- const content = quill.getContents();
180
- quill.setContents(content);
181
- quill.setSelection(range.index + 1, 'user');
182
- fileInput.value = '';
180
+ this.ngZone.runOutsideAngular(() => {
181
+ var _a, _b, _c, _d;
182
+ quill.enable(true);
183
+ // quill.editor.insertEmbed(range.index, 'image', resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '');
184
+ quill.getModule('clipboard').dangerouslyPasteHTML(range.index, '<a target="_blank" href="' + (((_a = resp === null || resp === void 0 ? void 0 : resp.data) === null || _a === void 0 ? void 0 : _a.imageUrl) || ((_b = resp === null || resp === void 0 ? void 0 : resp.data) === null || _b === void 0 ? void 0 : _b.publish_url) || (resp === null || resp === void 0 ? void 0 : resp.url) || '')
185
+ + '"><img src="' + (((_c = resp === null || resp === void 0 ? void 0 : resp.data) === null || _c === void 0 ? void 0 : _c.imageUrl) || ((_d = resp === null || resp === void 0 ? void 0 : resp.data) === null || _d === void 0 ? void 0 : _d.publish_url) || (resp === null || resp === void 0 ? void 0 : resp.url) || '') + '" alt="c-image-editor-quill"></a>', 'user');
186
+ // quill.insertText();
187
+ const content = quill.getContents();
188
+ quill.setContents(content);
189
+ quill.setSelection(range.index + 1, 'user');
190
+ fileInput.value = '';
191
+ });
183
192
  });
193
+ this.ref.markForCheck();
184
194
  });
185
195
  }
186
196
  set model(val) {
@@ -229,6 +239,7 @@ export class SdEditor {
229
239
  this.quillConfig.toolbar.container = this.toolbar;
230
240
  console.log('toolbar', this.quillConfig);
231
241
  }
242
+ this.ref.markForCheck();
232
243
  }
233
244
  ngAfterViewInit() {
234
245
  __classPrivateFieldGet(this, _subscription).add(this.formControl.valueChanges.subscribe((val) => {
@@ -247,10 +258,12 @@ SdEditor.decorators = [
247
258
  { type: Component, args: [{
248
259
  selector: 'sd-editor',
249
260
  template: "<label *ngIf=\"label\" class=\"d-block T14M\">{{label}} <span class=\"text-danger mb-2\" *ngIf=\"required\">*</span></label>\r\n<ng-container *ngIf=\"!formControl.disabled && !showHtmlEditor\">\r\n <quill-editor #editor [styles]=\"styles\" (onEditorCreated)=\"editorInit($event)\" [ngModel]=\"formControl.value\"\r\n (ngModelChange)=\"onModelChange($event)\" [id]=\"id\" [modules]=\"quillConfig\" [placeholder]=\"placeholder\"\r\n [maxLength]=\"maxlength\" >\r\n </quill-editor>\r\n <span class=\"d-block text-danger mt-5\" *ngIf=\"formControl.errors?.required\">\r\n {{'This field is required' | sdTranslate}}\r\n </span>\r\n <span class=\"d-block text-danger mt-5\" *ngIf=\"formControl.errors?.minlength\">\r\n {{'Max length' | sdTranslate}} <strong>{{minlength}}</strong>\r\n </span>\r\n <span class=\"d-block text-danger mt-5\" *ngIf=\"formControl.errors?.maxlength\">\r\n {{'Max length' | sdTranslate}} <strong>{{maxlength}}</strong>\r\n </span>\r\n</ng-container>\r\n<ng-container *ngIf=\"formControl.disabled\">\r\n <div [innerHtml]=\"formControl.value\"></div>\r\n</ng-container>\r\n<ng-container *ngIf=\"enableHTMLButton\">\r\n <sd-textarea [(model)]=\"modelHTML\" *ngIf=\"showHtmlEditor\" rows=\"20\"\r\n (modelChange)=\"onModelChange($event)\"></sd-textarea>\r\n <sd-button\r\n title=\"{{showHtmlEditor?'\u1EA8n':'Hi\u1EC7n'}} m\u00E3 HTML\"\r\n class=\"mr-8\"\r\n fontSet=\"material-icons-outlined\"\r\n (action)=\"onClickShowHtmlEditor()\"\r\n type=\"light\"\r\n ></sd-button>\r\n</ng-container>\r\n",
261
+ changeDetection: ChangeDetectionStrategy.OnPush,
250
262
  styles: ["::ng-deep img[alt=c-image-editor-quill]{max-width:80%}"]
251
263
  },] }
252
264
  ];
253
265
  SdEditor.ctorParameters = () => [
266
+ { type: NgZone },
254
267
  { type: ChangeDetectorRef },
255
268
  { type: SdApiService }
256
269
  ];
@@ -274,4 +287,4 @@ SdEditor.propDecorators = {
274
287
  hashTagValues: [{ type: Input }],
275
288
  sdChange: [{ type: Output }]
276
289
  };
277
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/editor/","sources":["src/lib/editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewChild,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  EventEmitter,\r\n  ChangeDetectorRef,\r\n  AfterViewInit, OnDestroy\r\n} from '@angular/core';\r\nimport {QuillEditorComponent} from 'ngx-quill';\r\nimport * as uuid from 'uuid';\r\nimport {FormControl, FormGroup, NgForm, ValidatorFn, Validators} from '@angular/forms';\r\nimport {Constants} from './constant';\r\nimport {Subscription} from 'rxjs';\r\nimport {SdApiService} from '@sd-angular/core/api';\r\nimport 'quill-mention';\r\n\r\n@Component({\r\n  selector: 'sd-editor',\r\n  templateUrl: './editor.component.html',\r\n  styleUrls: ['./editor.component.scss'],\r\n})\r\nexport class SdEditor implements OnInit, AfterViewInit, OnDestroy {\r\n  #name = `N${uuid.v4()}`;\r\n  id: string = `I${uuid.v4()}`;\r\n  #subscription = new Subscription();\r\n  @ViewChild('editor') editor: QuillEditorComponent;\r\n  @Input() label: string;\r\n  #model: string;\r\n  @Input() set model(val: string) {\r\n    this.#model = val;\r\n    this.modelHTML = val;\r\n    this.formControl.setValue(this.#model, {\r\n      emitEvent: false\r\n    });\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  @Input() set disabled(val: boolean | '') {\r\n    val = (val === '') || val;\r\n    if (val) {\r\n      this.formControl.disable();\r\n    } else {\r\n      this.formControl.enable();\r\n    }\r\n  }\r\n\r\n  required = false;\r\n\r\n  @Input() set pRequired(val: boolean | '') {\r\n    this.required = (val === '') || val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  minlength: number;\r\n\r\n  @Input('minlength') set _minlength(val: number) {\r\n    this.minlength = +val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  maxlength: number;\r\n\r\n  @Input('maxlength') set _maxlength(val: number) {\r\n    this.maxlength = +val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  @Output() modelChange = new EventEmitter<string>();\r\n\r\n  @Input() placeholder: string = '';\r\n\r\n  @Input() styles: any = {height: '250px'};\r\n\r\n  formControl = new FormControl();\r\n\r\n  @Input() domain = '';\r\n  @Input() urlUploadImage: string;\r\n  #form: FormGroup;\r\n  @Input() set form(val: NgForm | FormGroup) {\r\n    if (val) {\r\n      if (val instanceof NgForm) {\r\n        this.#form = val.form;\r\n      } else {\r\n        this.#form = val;\r\n      }\r\n    }\r\n  }\r\n\r\n  @Input() toolbar: any;\r\n  @Input() enableHTMLButton = false;\r\n  showHtmlEditor = false;\r\n  modelHTML: string;\r\n\r\n  quillEvent: any;\r\n  @Input() mentionValues: { id: string, value: string, link?: string }[];\r\n  @Input() hashTagValues: { id: string, value: string, link?: string }[];\r\n  quillConfig = {\r\n    // toolbar: '.toolbar',\r\n    toolbar: {\r\n      container: [\r\n        ['bold', 'italic', 'underline', 'strike'],        // toggled buttons\r\n        ['blockquote', 'code-block'],\r\n\r\n        [{'header': 1}, {'header': 2}],               // custom button values\r\n        [{'list': 'ordered'}, {'list': 'bullet'}],\r\n        [{'script': 'sub'}, {'script': 'super'}],      // superscript/subscript\r\n        [{'indent': '-1'}, {'indent': '+1'}],          // outdent/indent\r\n        [{'direction': 'rtl'}],                         // text direction\r\n\r\n        [{'size': ['small', false, 'large', 'huge']}],  // custom dropdown\r\n        [{'header': [1, 2, 3, 4, 5, 6, false]}],\r\n\r\n        [{'color': []}, {'background': []}],          // dropdown with defaults from theme\r\n        [{'font': []}],\r\n        [{'align': []}],\r\n\r\n        ['clean'],                                         // remove formatting button\r\n\r\n        ['link', 'image', 'video']                         // link and image, video\r\n      ]\r\n    },\r\n    mention: {\r\n      allowedChars: /^[A-Za-z0-9\\sÅÄÖåäö._-]*$/,\r\n      mentionDenotationChars: ['@', '#'],\r\n      source: (searchTerm, renderList, mentionChar) => {\r\n        if ((this.mentionValues && mentionChar === '@') || (this.hashTagValues && mentionChar === '#')) {\r\n          let values;\r\n          if (mentionChar === '@') {\r\n            values = this.mentionValues;\r\n          } else if (mentionChar === '#') {\r\n            values = this.hashTagValues;\r\n          } else {\r\n            values = [];\r\n          }\r\n\r\n          if (searchTerm.length === 0) {\r\n            renderList(values, searchTerm);\r\n          } else {\r\n            const matches = [];\r\n            // tslint:disable-next-line:prefer-for-of\r\n            for (let i = 0; i < values.length; i++) {\r\n              // tslint:disable-next-line:no-bitwise\r\n              if (~values[i].value.toLowerCase().indexOf(searchTerm.toLowerCase())) {\r\n                matches.push(values[i]);\r\n              }\r\n            }\r\n            renderList(matches, searchTerm);\r\n          }\r\n        }\r\n      },\r\n    },\r\n    keyboard: {\r\n      bindings: {\r\n        enter: {\r\n          key: 13,\r\n          handler: (range, context) => {\r\n            return true;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  };\r\n\r\n  textLength: number = 0;\r\n  @Output() sdChange = new EventEmitter<string>();\r\n\r\n  constructor(\r\n    private ref: ChangeDetectorRef,\r\n    private sdApiService: SdApiService\r\n  ) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.#form?.addControl(this.#name, this.formControl);\r\n    if (this.toolbar) {\r\n      this.quillConfig.toolbar.container = this.toolbar;\r\n      console.log('toolbar', this.quillConfig);\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.#subscription.add(this.formControl.valueChanges.subscribe((val) => {\r\n      this.modelChange.emit(val);\r\n      this.sdChange.emit(val);\r\n    }));\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.#form?.removeControl(this.#name);\r\n    this.#subscription.unsubscribe();\r\n  }\r\n\r\n  #updateValidator = () => {\r\n    this.formControl.clearValidators();\r\n    this.formControl.clearAsyncValidators();\r\n    const validators: ValidatorFn[] = [];\r\n    if (this.required) {\r\n      validators.push(Validators.required);\r\n    }\r\n    if (this.minlength > 0) {\r\n      validators.push(Validators.minLength(this.minlength));\r\n    }\r\n    if (this.maxlength > 0) {\r\n      validators.push(Validators.maxLength(this.maxlength));\r\n    }\r\n    this.formControl.setValidators(validators);\r\n    this.formControl.updateValueAndValidity();\r\n  }\r\n\r\n  editorInit = (quill) => {\r\n    this.quillEvent = quill;\r\n    // const txtArea = document.createElement('textarea');\r\n    // txtArea.style.cssText =\r\n    //   'width: 100%;margin: 0px;background: rgb(29, 29, 29);' +\r\n    //   'box-sizing: border-box;color: rgb(204, 204, 204);' +\r\n    //   'font-size: 15px;outline: none;padding: 20px;' +\r\n    //   'line-height: 24px;font-family: Consolas, Menlo, Monaco, &quot;Courier New&quot;, monospace;' +\r\n    //   'position: absolute;top: 0;bottom: 0;border: none;display:none';\r\n\r\n    // const htmlEditor = quill.addContainer('ql-custom');\r\n    // htmlEditor.appendChild(txtArea);\r\n\r\n    // const myEditor = quill.container;\r\n    // quill.on('text-change', (delta, oldDelta, source) => {\r\n    //   const html = myEditor.children[0].innerHTML;\r\n    //   txtArea.value = html;\r\n    //   // if (quill.getLength() > this.maxlength) {\r\n    //   //   quill.deleteText(this.maxlength, quill.getLength());\r\n    //   // }\r\n    //   // this.formControl.setValue(html);\r\n    // });\r\n\r\n    const self = this;\r\n    quill.getModule('toolbar').addHandler('image', function () {\r\n      let fileInput = this.container.querySelector('input.ql-image[type=file]');\r\n\r\n      if (fileInput == null) {\r\n        fileInput = document.createElement('input');\r\n        fileInput.setAttribute('type', Constants.FILE);\r\n        fileInput.setAttribute('accept', 'image/png, image/gif, image/jpeg, image/bmp, image/x-icon');\r\n        fileInput.classList.add('ql-image');\r\n        fileInput.addEventListener('change', () => {\r\n          const files = fileInput.files;\r\n          const range = this.quill.getSelection(true);\r\n          if (!files || !files.length) {\r\n            return;\r\n          }\r\n\r\n          const formData = new FormData();\r\n          formData.append(Constants.FILE, files[0]);\r\n\r\n          this.quill.enable(false);\r\n          /*this.apiService.post(this.domain + this.urlUploadImage, formData).subscribe((resp: any) => {\r\n            this.quill.enable(true);\r\n            this.quill.editor.insertEmbed(range.index, 'image', resp.data.imageUrl || resp.data.publish_url ||  resp.url);\r\n            const content = this.quill.getContents();\r\n            this.quill.setContents(content);\r\n            this.quill.setSelection(range.index + 1, 'silent');\r\n            fileInput.value = '';\r\n          });*/\r\n          self.#uploadImage(formData, quill, range, fileInput);\r\n        });\r\n        this.container.appendChild(fileInput);\r\n      }\r\n      fileInput.click();\r\n    });\r\n  }\r\n\r\n  onModelChange = (val: string) => {\r\n    this.formControl.setValue(val);\r\n    this.modelHTML = val;\r\n  }\r\n\r\n  onClickShowHtmlEditor = () => {\r\n    this.showHtmlEditor = !this.showHtmlEditor;\r\n  }\r\n\r\n  #uploadImage = (formData, quill, range, fileInput) => {\r\n    if (!this.urlUploadImage) {\r\n      this.urlUploadImage = '/partner/v2/merchandise/file/uploaduserfile';\r\n    }\r\n    // this.domain = 'https://api-commerce-qc.vinid.dev';\r\n    this.sdApiService.post(this.urlUploadImage, formData).then((resp: any) => {\r\n      quill.enable(true);\r\n      // quill.editor.insertEmbed(range.index, 'image', resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '');\r\n      quill.getModule('clipboard').dangerouslyPasteHTML(range.index, '<a target=\"_blank\" href=\"' + (resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '')\r\n        + '\"><img src=\"' + (resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '') + '\" alt=\"c-image-editor-quill\"></a>', 'user');\r\n      // quill.insertText();\r\n      const content = quill.getContents();\r\n      quill.setContents(content);\r\n      quill.setSelection(range.index + 1, 'user');\r\n      fileInput.value = '';\r\n    });\r\n  }\r\n}\r\n"]}
290
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/editor/","sources":["src/lib/editor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewChild,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  EventEmitter,\r\n  ChangeDetectorRef,\r\n  AfterViewInit, OnDestroy, ChangeDetectionStrategy, NgZone\r\n} from '@angular/core';\r\nimport {QuillEditorComponent} from 'ngx-quill';\r\nimport * as uuid from 'uuid';\r\nimport {FormControl, FormGroup, NgForm, ValidatorFn, Validators} from '@angular/forms';\r\nimport {Constants} from './constant';\r\nimport {Subscription} from 'rxjs';\r\nimport {SdApiService} from '@sd-angular/core/api';\r\nimport 'quill-mention';\r\n\r\n@Component({\r\n  selector: 'sd-editor',\r\n  templateUrl: './editor.component.html',\r\n  styleUrls: ['./editor.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class SdEditor implements OnInit, AfterViewInit, OnDestroy {\r\n  #name = `N${uuid.v4()}`;\r\n  id: string = `I${uuid.v4()}`;\r\n  #subscription = new Subscription();\r\n  @ViewChild('editor') editor: QuillEditorComponent;\r\n  @Input() label: string;\r\n  #model: string;\r\n  @Input() set model(val: string) {\r\n    this.#model = val;\r\n    this.modelHTML = val;\r\n    this.formControl.setValue(this.#model, {\r\n      emitEvent: false\r\n    });\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  @Input() set disabled(val: boolean | '') {\r\n    val = (val === '') || val;\r\n    if (val) {\r\n      this.formControl.disable();\r\n    } else {\r\n      this.formControl.enable();\r\n    }\r\n  }\r\n\r\n  required = false;\r\n\r\n  @Input() set pRequired(val: boolean | '') {\r\n    this.required = (val === '') || val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  minlength: number;\r\n\r\n  @Input('minlength') set _minlength(val: number) {\r\n    this.minlength = +val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  maxlength: number;\r\n\r\n  @Input('maxlength') set _maxlength(val: number) {\r\n    this.maxlength = +val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  @Output() modelChange = new EventEmitter<string>();\r\n\r\n  @Input() placeholder: string = '';\r\n\r\n  @Input() styles: any = {height: '250px'};\r\n\r\n  formControl = new FormControl();\r\n\r\n  @Input() domain = '';\r\n  @Input() urlUploadImage: string;\r\n  #form: FormGroup;\r\n  @Input() set form(val: NgForm | FormGroup) {\r\n    if (val) {\r\n      if (val instanceof NgForm) {\r\n        this.#form = val.form;\r\n      } else {\r\n        this.#form = val;\r\n      }\r\n    }\r\n  }\r\n\r\n  @Input() toolbar: any;\r\n  @Input() enableHTMLButton = false;\r\n  showHtmlEditor = false;\r\n  modelHTML: string;\r\n\r\n  quillEvent: any;\r\n  @Input() mentionValues: { id: string, value: string, link?: string }[];\r\n  @Input() hashTagValues: { id: string, value: string, link?: string }[];\r\n  quillConfig = {\r\n    // toolbar: '.toolbar',\r\n    toolbar: {\r\n      container: [\r\n        ['bold', 'italic', 'underline', 'strike'],        // toggled buttons\r\n        ['blockquote', 'code-block'],\r\n\r\n        [{'header': 1}, {'header': 2}],               // custom button values\r\n        [{'list': 'ordered'}, {'list': 'bullet'}],\r\n        [{'script': 'sub'}, {'script': 'super'}],      // superscript/subscript\r\n        [{'indent': '-1'}, {'indent': '+1'}],          // outdent/indent\r\n        [{'direction': 'rtl'}],                         // text direction\r\n\r\n        [{'size': ['small', false, 'large', 'huge']}],  // custom dropdown\r\n        [{'header': [1, 2, 3, 4, 5, 6, false]}],\r\n\r\n        [{'color': []}, {'background': []}],          // dropdown with defaults from theme\r\n        [{'font': []}],\r\n        [{'align': []}],\r\n\r\n        ['clean'],                                         // remove formatting button\r\n\r\n        ['link', 'image', 'video']                         // link and image, video\r\n      ]\r\n    },\r\n    mention: {\r\n      allowedChars: /^[A-Za-z0-9\\sÅÄÖåäö._-]*$/,\r\n      mentionDenotationChars: ['@', '#'],\r\n      source: (searchTerm, renderList, mentionChar) => {\r\n        if ((this.mentionValues && mentionChar === '@') || (this.hashTagValues && mentionChar === '#')) {\r\n          let values;\r\n          if (mentionChar === '@') {\r\n            values = this.mentionValues;\r\n          } else if (mentionChar === '#') {\r\n            values = this.hashTagValues;\r\n          } else {\r\n            values = [];\r\n          }\r\n\r\n          if (searchTerm.length === 0) {\r\n            renderList(values, searchTerm);\r\n          } else {\r\n            const matches = [];\r\n            // tslint:disable-next-line:prefer-for-of\r\n            for (let i = 0; i < values.length; i++) {\r\n              // tslint:disable-next-line:no-bitwise\r\n              if (~values[i].value.toLowerCase().indexOf(searchTerm.toLowerCase())) {\r\n                matches.push(values[i]);\r\n              }\r\n            }\r\n            renderList(matches, searchTerm);\r\n          }\r\n        }\r\n      },\r\n    },\r\n    keyboard: {\r\n      bindings: {\r\n        enter: {\r\n          key: 13,\r\n          handler: (range, context) => {\r\n            return true;\r\n          }\r\n        }\r\n      }\r\n    }\r\n  };\r\n\r\n  textLength: number = 0;\r\n  @Output() sdChange = new EventEmitter<string>();\r\n\r\n  constructor(\r\n    private ngZone: NgZone,\r\n    private ref: ChangeDetectorRef,\r\n    private sdApiService: SdApiService\r\n  ) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.#form?.addControl(this.#name, this.formControl);\r\n    if (this.toolbar) {\r\n      this.quillConfig.toolbar.container = this.toolbar;\r\n      console.log('toolbar', this.quillConfig);\r\n    }\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.#subscription.add(this.formControl.valueChanges.subscribe((val) => {\r\n      this.modelChange.emit(val);\r\n      this.sdChange.emit(val);\r\n    }));\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.#form?.removeControl(this.#name);\r\n    this.#subscription.unsubscribe();\r\n  }\r\n\r\n  #updateValidator = () => {\r\n    this.formControl.clearValidators();\r\n    this.formControl.clearAsyncValidators();\r\n    const validators: ValidatorFn[] = [];\r\n    if (this.required) {\r\n      validators.push(Validators.required);\r\n    }\r\n    if (this.minlength > 0) {\r\n      validators.push(Validators.minLength(this.minlength));\r\n    }\r\n    if (this.maxlength > 0) {\r\n      validators.push(Validators.maxLength(this.maxlength));\r\n    }\r\n    this.formControl.setValidators(validators);\r\n    this.formControl.updateValueAndValidity();\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  editorInit = (quill) => {\r\n    this.quillEvent = quill;\r\n    // const txtArea = document.createElement('textarea');\r\n    // txtArea.style.cssText =\r\n    //   'width: 100%;margin: 0px;background: rgb(29, 29, 29);' +\r\n    //   'box-sizing: border-box;color: rgb(204, 204, 204);' +\r\n    //   'font-size: 15px;outline: none;padding: 20px;' +\r\n    //   'line-height: 24px;font-family: Consolas, Menlo, Monaco, &quot;Courier New&quot;, monospace;' +\r\n    //   'position: absolute;top: 0;bottom: 0;border: none;display:none';\r\n\r\n    // const htmlEditor = quill.addContainer('ql-custom');\r\n    // htmlEditor.appendChild(txtArea);\r\n\r\n    // const myEditor = quill.container;\r\n    // quill.on('text-change', (delta, oldDelta, source) => {\r\n    //   const html = myEditor.children[0].innerHTML;\r\n    //   txtArea.value = html;\r\n    //   // if (quill.getLength() > this.maxlength) {\r\n    //   //   quill.deleteText(this.maxlength, quill.getLength());\r\n    //   // }\r\n    //   // this.formControl.setValue(html);\r\n    // });\r\n\r\n    const self = this;\r\n    this.ngZone.runOutsideAngular(() => {\r\n      quill.getModule('toolbar').addHandler('image', function () {\r\n        let fileInput = this.container.querySelector('input.ql-image[type=file]');\r\n  \r\n        if (fileInput == null) {\r\n          fileInput = document.createElement('input');\r\n          fileInput.setAttribute('type', Constants.FILE);\r\n          fileInput.setAttribute('accept', 'image/png, image/gif, image/jpeg, image/bmp, image/x-icon');\r\n          fileInput.classList.add('ql-image');\r\n          fileInput.addEventListener('change', () => {\r\n            const files = fileInput.files;\r\n            const range = this.quill.getSelection(true);\r\n            if (!files || !files.length) {\r\n              return;\r\n            }\r\n  \r\n            const formData = new FormData();\r\n            formData.append(Constants.FILE, files[0]);\r\n  \r\n            this.quill.enable(false);\r\n            /*this.apiService.post(this.domain + this.urlUploadImage, formData).subscribe((resp: any) => {\r\n              this.quill.enable(true);\r\n              this.quill.editor.insertEmbed(range.index, 'image', resp.data.imageUrl || resp.data.publish_url ||  resp.url);\r\n              const content = this.quill.getContents();\r\n              this.quill.setContents(content);\r\n              this.quill.setSelection(range.index + 1, 'silent');\r\n              fileInput.value = '';\r\n            });*/\r\n            self.#uploadImage(formData, quill, range, fileInput);\r\n          });\r\n          this.container.appendChild(fileInput);\r\n        }\r\n        fileInput.click();\r\n      });\r\n    })\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  onModelChange = (val: string) => {\r\n    this.formControl.setValue(val);\r\n    this.modelHTML = val;\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  onClickShowHtmlEditor = () => {\r\n    this.showHtmlEditor = !this.showHtmlEditor;\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  #uploadImage = (formData, quill, range, fileInput) => {\r\n    if (!this.urlUploadImage) {\r\n      this.urlUploadImage = '/partner/v2/merchandise/file/uploaduserfile';\r\n    }\r\n    // this.domain = 'https://api-commerce-qc.vinid.dev';\r\n    this.sdApiService.post(this.urlUploadImage, formData).then((resp: any) => {\r\n      this.ngZone.runOutsideAngular(() => {\r\n        quill.enable(true);\r\n        // quill.editor.insertEmbed(range.index, 'image', resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '');\r\n        quill.getModule('clipboard').dangerouslyPasteHTML(range.index, '<a target=\"_blank\" href=\"' + (resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '')\r\n          + '\"><img src=\"' + (resp?.data?.imageUrl || resp?.data?.publish_url || resp?.url || '') + '\" alt=\"c-image-editor-quill\"></a>', 'user');\r\n        // quill.insertText();\r\n        const content = quill.getContents();\r\n        quill.setContents(content);\r\n        quill.setSelection(range.index + 1, 'user');\r\n        fileInput.value = '';\r\n      })\r\n    });\r\n    this.ref.markForCheck();\r\n  }\r\n}\r\n"]}
@@ -1,4 +1,4 @@
1
- import { Component, Input } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
2
  export class SdDesktopCommand {
3
3
  constructor() {
4
4
  this.commands = [];
@@ -8,6 +8,7 @@ SdDesktopCommand.decorators = [
8
8
  { type: Component, args: [{
9
9
  selector: 'sd-desktop-command',
10
10
  template: "<ng-container *ngIf=\"item | commandFilter:commands | async; $implicit as filteredCommands\">\r\n <ng-container *ngFor=\"let command of filteredCommands\">\r\n <ng-container *ngIf=\"command?.click; else elseChildren\">\r\n <button (click)=\"command.click(item)\" [matTooltip]=\"command.title | commandTitle:item\" aria-hidden=\"true\"\r\n [disabled]=\"item | commandDisable:command\" mat-icon-button>\r\n <mat-icon class=\"c-icon\" [fontSet]=\"command.fontSet\">{{command | commandIcon:item}}</mat-icon>\r\n </button>\r\n </ng-container>\r\n <ng-template #elseChildren>\r\n <button [matMenuTriggerFor]=\"menu\" aria-hidden=\"true\" mat-icon-button>\r\n <mat-icon *ngIf=\"command?.icon\" class=\"c-icon\" [fontSet]=\"command.fontSet\">{{command | commandIcon:item}}\r\n </mat-icon>\r\n <mat-icon *ngIf=\"!command?.icon\" class=\"c-icon\">more_vert</mat-icon>\r\n </button>\r\n <mat-menu #menu=\"matMenu\">\r\n <span>\r\n <button *ngFor=\"let childCommand of command.children\" mat-menu-item (click)=\"childCommand.click(item)\"\r\n [disabled]=\"item | commandDisable:childCommand\">\r\n <ng-container *ngIf=\"!childCommand.htmlTemplate\">\r\n <mat-icon [fontSet]=\"command.fontSet\" class=\"c-icon\">{{childCommand | commandIcon:item}}\r\n </mat-icon>\r\n <span> {{childCommand | commandTitle:item}}</span>\r\n </ng-container>\r\n <ng-container *ngIf=\"childCommand.htmlTemplate\">\r\n <div [innerHTML]=\"childCommand.htmlTemplate(item)\"></div>\r\n </ng-container>\r\n </button>\r\n </span>\r\n </mat-menu>\r\n </ng-template>\r\n </ng-container>\r\n</ng-container>\r\n",
11
+ changeDetection: ChangeDetectionStrategy.OnPush,
11
12
  styles: [":host{align-items:center;display:flex}mat-icon.c-icon{color:rgba(0,0,0,.54)!important}"]
12
13
  },] }
13
14
  ];
@@ -16,4 +17,4 @@ SdDesktopCommand.propDecorators = {
16
17
  item: [{ type: Input }],
17
18
  commands: [{ type: Input }]
18
19
  };
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVza3RvcC1jb21tYW5kLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJDOi9Vc2Vycy9uZ2hpYXR0MTVfb25lbW91bnQvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvZ3JpZC1tYXRlcmlhbC8iLCJzb3VyY2VzIjpbInNyYy9saWIvY29tcG9uZW50cy9kZXNrdG9wLWNvbW1hbmQvZGVza3RvcC1jb21tYW5kLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQVFqRCxNQUFNLE9BQU8sZ0JBQWdCO0lBRzNCO1FBRFMsYUFBUSxHQUE0QixFQUFFLENBQUM7SUFFaEQsQ0FBQzs7O1lBVEYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxvQkFBb0I7Z0JBQzlCLHN3REFBK0M7O2FBRWhEOzs7O21CQUVFLEtBQUs7dUJBQ0wsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU2RHcmlkTWF0ZXJpYWxDb21tYW5kIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2dyaWQtY29tbWFuZC5tb2RlbCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3NkLWRlc2t0b3AtY29tbWFuZCcsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2Rlc2t0b3AtY29tbWFuZC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vZGVza3RvcC1jb21tYW5kLmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIFNkRGVza3RvcENvbW1hbmQge1xyXG4gIEBJbnB1dCgpIGl0ZW06IGFueTtcclxuICBASW5wdXQoKSBjb21tYW5kczogU2RHcmlkTWF0ZXJpYWxDb21tYW5kW10gPSBbXTtcclxuICBjb25zdHJ1Y3RvcigpIHtcclxuICB9XHJcbn1cclxuIl19
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVza3RvcC1jb21tYW5kLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJDOi9Vc2Vycy9uZ2hpYXR0MTVfb25lbW91bnQvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvZ3JpZC1tYXRlcmlhbC8iLCJzb3VyY2VzIjpbInNyYy9saWIvY29tcG9uZW50cy9kZXNrdG9wLWNvbW1hbmQvZGVza3RvcC1jb21tYW5kLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQVMxRSxNQUFNLE9BQU8sZ0JBQWdCO0lBRzNCO1FBRFMsYUFBUSxHQUE0QixFQUFFLENBQUM7SUFFaEQsQ0FBQzs7O1lBVkYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxvQkFBb0I7Z0JBQzlCLHN3REFBK0M7Z0JBRS9DLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNOzthQUNoRDs7OzttQkFFRSxLQUFLO3VCQUNMLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBTZEdyaWRNYXRlcmlhbENvbW1hbmQgfSBmcm9tICcuLi8uLi9tb2RlbHMvZ3JpZC1jb21tYW5kLm1vZGVsJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnc2QtZGVza3RvcC1jb21tYW5kJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZGVza3RvcC1jb21tYW5kLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9kZXNrdG9wLWNvbW1hbmQuY29tcG9uZW50LnNjc3MnXSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2REZXNrdG9wQ29tbWFuZCB7XHJcbiAgQElucHV0KCkgaXRlbTogYW55O1xyXG4gIEBJbnB1dCgpIGNvbW1hbmRzOiBTZEdyaWRNYXRlcmlhbENvbW1hbmRbXSA9IFtdO1xyXG4gIGNvbnN0cnVjdG9yKCkge1xyXG4gIH1cclxufVxyXG4iXX0=
@@ -1,13 +1,14 @@
1
1
  var _filterOptionChanges, _subscription, _loadDefault, _clearFilter;
2
2
  import { __classPrivateFieldGet } from "tslib";
3
- import { Component, Input, Output, EventEmitter, ViewChild } from '@angular/core';
3
+ import { Component, Input, Output, EventEmitter, ViewChild, ChangeDetectionStrategy, ChangeDetectorRef } from '@angular/core';
4
4
  import { SdPopupFilter } from '../popup-filter/popup-filter.component';
5
5
  import { Subject, Subscription } from 'rxjs';
6
6
  import { startWith } from 'rxjs/operators';
7
7
  import { SdGridFilterService } from '../../services/grid-filter.service';
8
8
  import { DeviceDetectorService } from 'ngx-device-detector';
9
9
  export class SdGridFilter {
10
- constructor(deviceService, gridFilterService) {
10
+ constructor(ref, deviceService, gridFilterService) {
11
+ this.ref = ref;
11
12
  this.deviceService = deviceService;
12
13
  this.gridFilterService = gridFilterService;
13
14
  this.isVisible = true;
@@ -106,6 +107,7 @@ export class SdGridFilter {
106
107
  selectedQuickFilter: null
107
108
  });
108
109
  this.filterChange.emit();
110
+ this.ref.markForCheck();
109
111
  };
110
112
  this.onClearFilter = () => {
111
113
  var _a;
@@ -139,8 +141,10 @@ export class SdGridFilter {
139
141
  };
140
142
  }
141
143
  }
144
+ this.ref.markForCheck();
142
145
  };
143
146
  this.isMobileOrTablet = !this.deviceService.isDesktop();
147
+ this.ref.markForCheck();
144
148
  }
145
149
  set _filter(filter) {
146
150
  var _a;
@@ -163,6 +167,7 @@ export class SdGridFilter {
163
167
  __classPrivateFieldGet(this, _loadDefault).call(this);
164
168
  this.filterChange.emit();
165
169
  });
170
+ this.ref.markForCheck();
166
171
  }));
167
172
  }
168
173
  ngOnDestroy() {
@@ -174,10 +179,12 @@ SdGridFilter.decorators = [
174
179
  { type: Component, args: [{
175
180
  selector: 'sd-grid-filter',
176
181
  template: "<ng-container *ngIf=\"isVisible\">\r\n <div *ngIf=\"!isMobileOrTablet && ((columns?.length && !filter?.inlineColumn) || externalFilters?.length || filterDefs?.length)\"\r\n class=\"row mx-0 pb-10\">\r\n <ng-container *ngIf=\"filter?.sorts?.length\">\r\n <ng-container *ngFor=\"let field of filter?.sorts\">\r\n <ng-container *ngIf=\"columns?.length && !filter?.inlineColumn\">\r\n <ng-container *ngFor=\"let item of columns | sdFilterColumn:field\">\r\n <ng-container *ngTemplateOutlet=\"filterColumn; context: {item: item}\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"externalFilters?.length\">\r\n <ng-container *ngFor=\"let item of externalFilters | sdFilterExternal:field\">\r\n <ng-container *ngTemplateOutlet=\"filterExternal; context: {item: item}\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngFor=\"let item of filterDefs\">\r\n <div *ngIf=\"inlineFilterDef[item.sdMaterialFilterDef] && item.sdMaterialFilterDef === field\"\r\n class=\"col-lg-2 col-md-3 col-sm-6 px-8\">\r\n <ng-container *ngTemplateOutlet=\"item.templateRef;context:{filterDef:filterDef, isInline: true}\">\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"!filter?.sorts?.length\">\r\n <ng-container *ngIf=\"columns?.length && !filter?.inlineColumn\">\r\n <ng-container *ngFor=\"let item of columns | sdFilterColumn\">\r\n <ng-container *ngTemplateOutlet=\"filterColumn; context: {item: item}\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"externalFilters?.length\">\r\n <ng-container *ngFor=\"let item of externalFilters | sdFilterExternal\">\r\n <ng-container *ngTemplateOutlet=\"filterExternal; context: {item: item}\"></ng-container>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngFor=\"let item of filterDefs\">\r\n <div *ngIf=\"inlineFilterDef[item.sdMaterialFilterDef]\" class=\"col-lg-2 col-md-3 col-sm-6 px-8\">\r\n <ng-container *ngTemplateOutlet=\"item.templateRef;context:{filterDef:filterDef, isInline: true}\">\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n <ng-template #filterColumn let-item=\"item\">\r\n <div *ngIf=\"inlineColumn[item.field]\" class=\"col-lg-2 col-md-3 col-sm-6 px-8\">\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'string'\" type=\"text\" [(model)]=\"columnFilter[item.field]\"\r\n (keyupEnter)=\"onFilter(item)\" appearance=\"outline\">\r\n </sd-input>\r\n <sd-input-number [label]=\"item.title\" *ngIf=\"item.type === 'number'\" [(model)]=\"columnFilter[item.field]\"\r\n (keyupEnter)=\"onFilter(item)\" appearance=\"outline\">\r\n </sd-input-number>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'bool'\" [items]=\"[{value:'1',display:item.option?.displayOnTrue || 'True' },\r\n {value:'0',display:item.option?.displayOnFalse || 'False' }]\" valueField=\"value\" displayField=\"display\"\r\n [(model)]=\"columnFilter[item.field]\" (sdChange)=\"onFilter(item)\" appearance=\"outline\">\r\n </sd-select>\r\n <sd-select *ngIf=\"item.type === 'values' && item?.option?.selection !== 'AUTOCOMPLETE'\"\r\n [items]=\"item.option?.items\" [valueField]=\"item.option?.valueField\"\r\n [displayField]=\"item.option.displayField\" [(model)]=\"columnFilter[item.field]\" (sdChange)=\"onFilter(item)\"\r\n [disabled]=\"item.filter?.disabled\"\r\n [multiple]=\"item?.option?.selection === 'MULTIPLE' || item?.item?.selection === 'MULTIPLEAUTOCOMPLETE'\"\r\n [filtered]=\"item?.option?.selection === 'MULTIPLEAUTOCOMPLETE'\" appearance=\"outline\">\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"item.type === 'values' && item?.option?.selection === 'AUTOCOMPLETE'\"\r\n [items]=\"item.option?.items\" [valueField]=\"item.option?.valueField\"\r\n [displayField]=\"item.option?.displayField\" [(model)]=\"columnFilter[item.field]\" (sdChange)=\"onFilter(item)\"\r\n [disabled]=\"item.filter?.disabled\" appearance=\"outline\">\r\n </sd-autocomplete>\r\n <sd-date-time *ngIf=\"item.type === 'date' || item.type === 'datetime' || item.type === 'time'\"\r\n [label]=\"item.title\" [(model)]=\"columnFilter[item.field]\" [type]=\"item.type\" (sdChange)=\"onFilter(item)\" appearance=\"outline\">\r\n </sd-date-time>\r\n </div>\r\n </ng-template>\r\n <ng-template #filterExternal let-item=\"item\">\r\n <div *ngIf=\"inlineExternal[item.field]\" class=\"col-lg-2 col-md-3 col-sm-6 px-8\">\r\n <sd-input [label]=\"item.title\" *ngIf=\"item.type === 'string'\" type=\"text\" [(model)]=\"externalFilter[item.field]\"\r\n (keyupEnter)=\"onFilter(item)\" appearance=\"outline\">\r\n </sd-input>\r\n <sd-input-number [label]=\"item.title\" *ngIf=\"item.type === 'number'\" [(model)]=\"externalFilter[item.field]\"\r\n (keyupEnter)=\"onFilter(item)\" appearance=\"outline\">\r\n </sd-input-number>\r\n <sd-select [label]=\"item.title\" *ngIf=\"item.type === 'bool'\" [items]=\"[{value:'1',display:item.option?.displayOnTrue || 'True' },\r\n {value:'0',display:item.option?.displayOnFalse || 'False' }]\" valueField=\"value\" displayField=\"display\"\r\n [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onFilter(item)\" appearance=\"outline\">\r\n </sd-select>\r\n <ng-container *ngIf=\"item.type === 'values' && item.option\">\r\n <sd-select *ngIf=\"item.option?.selection === 'MULTIPLE'\" [label]=\"item.title\" [items]=\"item.option.items\"\r\n [valueField]=\"item.option.valueField\" [displayField]=\"item.option.displayField\"\r\n [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onFilter(item)\" [selectAll]=\"item.option.selectAll\" appearance=\"outline\" multiple>\r\n </sd-select>\r\n <sd-autocomplete *ngIf=\"item.option?.selection === 'AUTOCOMPLETE'\" [label]=\"item.title\"\r\n [items]=\"item.option.items\" [valueField]=\"item.option.valueField\" [displayField]=\"item.option.displayField\"\r\n [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onFilter(item)\" appearance=\"outline\">\r\n </sd-autocomplete>\r\n <sd-select *ngIf=\"item.option?.selection === 'MULTIPLEAUTOCOMPLETE'\" [label]=\"item.title\"\r\n [items]=\"item.option.items\" [valueField]=\"item.option.valueField\" [displayField]=\"item.option.displayField\"\r\n [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onFilter(item)\" filtered=\"true\" appearance=\"outline\" multiple>\r\n </sd-select>\r\n <sd-select *ngIf=\"!item.option?.selection\" [label]=\"item.title\" [items]=\"item.option.items\"\r\n [valueField]=\"item.option.valueField\" [displayField]=\"item.option.displayField\"\r\n [(model)]=\"externalFilter[item.field]\" (sdChange)=\"onFilter(item)\" appearance=\"outline\">\r\n </sd-select>\r\n </ng-container>\r\n <sd-date-time [label]=\"item.title\" *ngIf=\"item.type ==='date' || item.type ==='datetime'\"\r\n [(model)]=\"externalFilter[item.field]\" [type]=\"item.type\" (sdChange)=\"onFilter(item)\" appearance=\"outline\">\r\n </sd-date-time>\r\n <sd-date-range [label]=\"item.title\" *ngIf=\"item.type ==='daterange' && externalFilter[item.field]\"\r\n [(from)]=\"externalFilter[item.field].from\" [(to)]=\"externalFilter[item.field].to\" [min]=\"item.minDate\"\r\n [max]=\"item.maxDate\" (sdChange)=\"onFilter(item)\" appearance=\"outline\">\r\n </sd-date-range>\r\n </div>\r\n </ng-template>\r\n <sd-popup-filter [columns]=\"columns\" [externalFilters]=\"externalFilters\" (changeFilter)=\"onChangeFilter($event)\"\r\n (clearFilter)=\"onReset()\" [filterDefs]=\"filterDefs\">\r\n </sd-popup-filter>\r\n</ng-container>",
182
+ changeDetection: ChangeDetectionStrategy.OnPush,
177
183
  styles: [":host{display:block;padding-left:0;padding-right:0}:host ::ng-deep .mat-form-field-wrapper{padding-bottom:0}"]
178
184
  },] }
179
185
  ];
180
186
  SdGridFilter.ctorParameters = () => [
187
+ { type: ChangeDetectorRef },
181
188
  { type: DeviceDetectorService },
182
189
  { type: SdGridFilterService }
183
190
  ];
@@ -188,4 +195,4 @@ SdGridFilter.propDecorators = {
188
195
  filterDefs: [{ type: Input }],
189
196
  filterChange: [{ type: Output }]
190
197
  };
191
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-filter.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/grid-material/","sources":["src/lib/components/grid-filter/grid-filter.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, ViewChild, AfterViewInit, OnDestroy } from '@angular/core';\r\nimport { SdGridMaterialFilterOption, SdGridMaterialExternalFilter } from '../../models/grid-filter.model';\r\nimport { SdGridMaterialColumn } from '../../models/grid-column.model';\r\nimport { SdPopupFilter } from '../popup-filter/popup-filter.component';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { startWith } from 'rxjs/operators';\r\nimport { SdGridFilterService } from '../../services/grid-filter.service';\r\nimport { DeviceDetectorService } from 'ngx-device-detector';\r\nimport { SdMaterialFilterDefDirective } from '../../directives/sd-material-filter-def.directive';\r\n\r\n@Component({\r\n  selector: 'sd-grid-filter',\r\n  templateUrl: './grid-filter.component.html',\r\n  styleUrls: ['./grid-filter.component.scss']\r\n})\r\nexport class SdGridFilter implements AfterViewInit, OnDestroy {\r\n  @ViewChild(SdPopupFilter) popupFilter: SdPopupFilter;\r\n  isVisible = true;\r\n  filter: Readonly<SdGridMaterialFilterOption>;\r\n  #filterOptionChanges = new Subject<SdGridMaterialFilterOption>();\r\n  @Input('filter') set _filter(filter: SdGridMaterialFilterOption) {\r\n    this.filter = filter;\r\n    this.isVisible = !this.filter?.disabled;\r\n    this.#filterOptionChanges.next(this.filter);\r\n  }\r\n  @Input() columns: SdGridMaterialColumn[] = [];\r\n  @Input() filterDefs: SdMaterialFilterDefDirective[] = [];\r\n  filterDef: any = {};\r\n  inlineFilterDef: {\r\n    [key: string]: boolean;\r\n  } = {};\r\n\r\n  @Output() filterChange = new EventEmitter();\r\n  #subscription = new Subscription();\r\n\r\n  columnFilter: any = {};\r\n  inlineColumn: {\r\n    [key: string]: boolean;\r\n  } = {};\r\n  externalFilters: SdGridMaterialExternalFilter[] = [];\r\n  externalFilter: any = {};\r\n  inlineExternal: {\r\n    [key: string]: boolean;\r\n  } = {};\r\n  isMobileOrTablet: boolean;\r\n  constructor(\r\n    private deviceService: DeviceDetectorService,\r\n    private gridFilterService: SdGridFilterService) {\r\n    this.isMobileOrTablet = !this.deviceService.isDesktop();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.#subscription.add(this.#filterOptionChanges.pipe(startWith(this.filter)).subscribe(() => {\r\n      if (!this.isVisible) {\r\n        this.filterChange.emit();\r\n        return;\r\n      }\r\n      this.externalFilters = this.filter?.externalFilters || [];\r\n      this.gridFilterService.get(this.filter?.key).then(configuration => {\r\n        this.inlineColumn = configuration.inlineColumn;\r\n        this.inlineExternal = configuration.inlineExternal;\r\n        this.inlineFilterDef = configuration.inlineFilterDef;\r\n        this.#loadDefault();\r\n        this.filterChange.emit();\r\n      });\r\n    }));\r\n  }\r\n\r\n  #loadDefault = () => {\r\n    for (const column of this.columns) {\r\n      this.inlineColumn[column.field] = this.inlineColumn[column.field] ?? column?.filter?.defaultShowing;\r\n      this.columnFilter[column.field] = this.columnFilter[column.field] ?? column?.filter?.default;\r\n    }\r\n    for (const externalFilter of this.externalFilters) {\r\n      this.inlineExternal[externalFilter.field] = this.inlineExternal[externalFilter.field] ?? externalFilter?.defaultShowing;\r\n      if (externalFilter.type === 'daterange') {\r\n        this.externalFilter[externalFilter.field] = {\r\n          from: this.externalFilter[externalFilter.field]?.from ?? externalFilter.default?.from ?? undefined,\r\n          to: this.externalFilter[externalFilter.field]?.to ?? externalFilter.default?.to ?? undefined\r\n        };\r\n      } else {\r\n        this.externalFilter[externalFilter.field] = this.externalFilter[externalFilter.field] ?? externalFilter.default;\r\n      }\r\n    }\r\n    for (const filterDef of this.filterDefs) {\r\n      this.inlineFilterDef[filterDef.sdMaterialFilterDef] = this.inlineFilterDef[filterDef.sdMaterialFilterDef] ?? filterDef?.defaultShowing;\r\n    }\r\n  }\r\n\r\n  #clearFilter = () => {\r\n    this.columnFilter = {};\r\n    this.externalFilter = {};\r\n    this.filterDef = {};\r\n    for (const externalFilter of this.externalFilters) {\r\n      if (externalFilter.type === 'daterange') {\r\n        this.externalFilter[externalFilter.field] = {\r\n          from: undefined,\r\n          to: undefined\r\n        };\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.#subscription.unsubscribe();\r\n  }\r\n\r\n  onFilter = (item?: SdGridMaterialColumn | SdGridMaterialExternalFilter) => {\r\n    this.filterChange.emit();\r\n  }\r\n\r\n  open = () => {\r\n    this.popupFilter.open({\r\n      columnFilter: this.columnFilter,\r\n      externalFilter: this.externalFilter,\r\n      filterDef: this.filterDef,\r\n      inlineColumn: this.inlineColumn,\r\n      inlineExternal: this.inlineExternal,\r\n      inlineFilterDef: this.inlineFilterDef\r\n    });\r\n  }\r\n\r\n  onChangeFilter = (args: {\r\n    inlineColumn: {\r\n      [key: string]: boolean\r\n    },\r\n    columnFilter: any,\r\n    inlineExternal: {\r\n      [key: string]: boolean\r\n    }\r\n    externalFilter: any,\r\n    inlineFilterDef: {\r\n      [key: string]: boolean\r\n    },\r\n    filterDef: any\r\n  }) => {\r\n    const { inlineColumn, columnFilter, inlineExternal, externalFilter, inlineFilterDef, filterDef } = args;\r\n    this.inlineColumn = inlineColumn;\r\n    this.columnFilter = columnFilter;\r\n    this.inlineExternal = inlineExternal;\r\n    this.externalFilter = externalFilter;\r\n    this.inlineFilterDef = inlineFilterDef;\r\n    this.filterDef = filterDef;\r\n    this.gridFilterService.set(this.filter?.key, {\r\n      inlineColumn,\r\n      inlineExternal,\r\n      quickFilters: [],\r\n      inlineFilterDef,\r\n      selectedQuickFilter: null\r\n    });\r\n    this.filterChange.emit();\r\n  }\r\n\r\n  onReset = () => {\r\n    this.inlineColumn = {};\r\n    this.columnFilter = {};\r\n    this.inlineExternal = {};\r\n    this.externalFilter = {};\r\n    this.inlineFilterDef = {};\r\n    this.filterDef = {};\r\n    this.#loadDefault();\r\n    this.gridFilterService.set(this.filter?.key, {\r\n      inlineColumn: this.inlineColumn,\r\n      inlineExternal: this.columnFilter,\r\n      inlineFilterDef: this.inlineFilterDef,\r\n      quickFilters: [],\r\n      selectedQuickFilter: null\r\n    });\r\n    this.filterChange.emit();\r\n  }\r\n\r\n  onClearFilter = () => {\r\n    this.#clearFilter();\r\n    this.gridFilterService.set(this.filter?.key, {\r\n      inlineColumn: this.inlineColumn,\r\n      inlineExternal: this.columnFilter,\r\n      inlineFilterDef: this.inlineFilterDef,\r\n      quickFilters: [],\r\n      selectedQuickFilter: null\r\n    });\r\n    this.filterChange.emit();\r\n  }\r\n\r\n  setFilter = (args: {\r\n    columnFilter?: any,\r\n    externalFilter?: any,\r\n    filterDef?: any\r\n  }) => {\r\n    const { columnFilter,  externalFilter, filterDef} = args;\r\n    if (columnFilter) {\r\n      this.columnFilter = columnFilter;\r\n    }\r\n    if (externalFilter) {\r\n      this.externalFilter = externalFilter;\r\n    }\r\n    if (filterDef) {\r\n      this.filterDef = filterDef;\r\n    }\r\n    for (const externalFilter of this.externalFilters) {\r\n      if (externalFilter.type === 'daterange') {\r\n        this.externalFilter[externalFilter.field] = {\r\n          from: this.externalFilter[externalFilter.field]?.from ?? undefined,\r\n          to: this.externalFilter[externalFilter.field]?.to ?? undefined\r\n        };\r\n      }\r\n    }\r\n  }\r\n}\r\n"]}
198
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-filter.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/grid-material/","sources":["src/lib/components/grid-filter/grid-filter.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, ViewChild, AfterViewInit, OnDestroy, ChangeDetectionStrategy, ChangeDetectorRef } from '@angular/core';\r\nimport { SdGridMaterialFilterOption, SdGridMaterialExternalFilter } from '../../models/grid-filter.model';\r\nimport { SdGridMaterialColumn } from '../../models/grid-column.model';\r\nimport { SdPopupFilter } from '../popup-filter/popup-filter.component';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { startWith } from 'rxjs/operators';\r\nimport { SdGridFilterService } from '../../services/grid-filter.service';\r\nimport { DeviceDetectorService } from 'ngx-device-detector';\r\nimport { SdMaterialFilterDefDirective } from '../../directives/sd-material-filter-def.directive';\r\n\r\n@Component({\r\n  selector: 'sd-grid-filter',\r\n  templateUrl: './grid-filter.component.html',\r\n  styleUrls: ['./grid-filter.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class SdGridFilter implements AfterViewInit, OnDestroy {\r\n  @ViewChild(SdPopupFilter) popupFilter: SdPopupFilter;\r\n  isVisible = true;\r\n  filter: Readonly<SdGridMaterialFilterOption>;\r\n  #filterOptionChanges = new Subject<SdGridMaterialFilterOption>();\r\n  @Input('filter') set _filter(filter: SdGridMaterialFilterOption) {\r\n    this.filter = filter;\r\n    this.isVisible = !this.filter?.disabled;\r\n    this.#filterOptionChanges.next(this.filter);\r\n  }\r\n  @Input() columns: SdGridMaterialColumn[] = [];\r\n  @Input() filterDefs: SdMaterialFilterDefDirective[] = [];\r\n  filterDef: any = {};\r\n  inlineFilterDef: {\r\n    [key: string]: boolean;\r\n  } = {};\r\n\r\n  @Output() filterChange = new EventEmitter();\r\n  #subscription = new Subscription();\r\n\r\n  columnFilter: any = {};\r\n  inlineColumn: {\r\n    [key: string]: boolean;\r\n  } = {};\r\n  externalFilters: SdGridMaterialExternalFilter[] = [];\r\n  externalFilter: any = {};\r\n  inlineExternal: {\r\n    [key: string]: boolean;\r\n  } = {};\r\n  isMobileOrTablet: boolean;\r\n  constructor(\r\n    private ref: ChangeDetectorRef,\r\n    private deviceService: DeviceDetectorService,\r\n    private gridFilterService: SdGridFilterService) {\r\n    this.isMobileOrTablet = !this.deviceService.isDesktop();\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.#subscription.add(this.#filterOptionChanges.pipe(startWith(this.filter)).subscribe(() => {\r\n      if (!this.isVisible) {\r\n        this.filterChange.emit();\r\n        return;\r\n      }\r\n      this.externalFilters = this.filter?.externalFilters || [];\r\n      this.gridFilterService.get(this.filter?.key).then(configuration => {\r\n        this.inlineColumn = configuration.inlineColumn;\r\n        this.inlineExternal = configuration.inlineExternal;\r\n        this.inlineFilterDef = configuration.inlineFilterDef;\r\n        this.#loadDefault();\r\n        this.filterChange.emit();\r\n      });\r\n      this.ref.markForCheck();\r\n    }));\r\n  }\r\n\r\n  #loadDefault = () => {\r\n    for (const column of this.columns) {\r\n      this.inlineColumn[column.field] = this.inlineColumn[column.field] ?? column?.filter?.defaultShowing;\r\n      this.columnFilter[column.field] = this.columnFilter[column.field] ?? column?.filter?.default;\r\n    }\r\n    for (const externalFilter of this.externalFilters) {\r\n      this.inlineExternal[externalFilter.field] = this.inlineExternal[externalFilter.field] ?? externalFilter?.defaultShowing;\r\n      if (externalFilter.type === 'daterange') {\r\n        this.externalFilter[externalFilter.field] = {\r\n          from: this.externalFilter[externalFilter.field]?.from ?? externalFilter.default?.from ?? undefined,\r\n          to: this.externalFilter[externalFilter.field]?.to ?? externalFilter.default?.to ?? undefined\r\n        };\r\n      } else {\r\n        this.externalFilter[externalFilter.field] = this.externalFilter[externalFilter.field] ?? externalFilter.default;\r\n      }\r\n    }\r\n    for (const filterDef of this.filterDefs) {\r\n      this.inlineFilterDef[filterDef.sdMaterialFilterDef] = this.inlineFilterDef[filterDef.sdMaterialFilterDef] ?? filterDef?.defaultShowing;\r\n    }\r\n  }\r\n\r\n  #clearFilter = () => {\r\n    this.columnFilter = {};\r\n    this.externalFilter = {};\r\n    this.filterDef = {};\r\n    for (const externalFilter of this.externalFilters) {\r\n      if (externalFilter.type === 'daterange') {\r\n        this.externalFilter[externalFilter.field] = {\r\n          from: undefined,\r\n          to: undefined\r\n        };\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.#subscription.unsubscribe();\r\n  }\r\n\r\n  onFilter = (item?: SdGridMaterialColumn | SdGridMaterialExternalFilter) => {\r\n    this.filterChange.emit();\r\n  }\r\n\r\n  open = () => {\r\n    this.popupFilter.open({\r\n      columnFilter: this.columnFilter,\r\n      externalFilter: this.externalFilter,\r\n      filterDef: this.filterDef,\r\n      inlineColumn: this.inlineColumn,\r\n      inlineExternal: this.inlineExternal,\r\n      inlineFilterDef: this.inlineFilterDef\r\n    });\r\n  }\r\n\r\n  onChangeFilter = (args: {\r\n    inlineColumn: {\r\n      [key: string]: boolean\r\n    },\r\n    columnFilter: any,\r\n    inlineExternal: {\r\n      [key: string]: boolean\r\n    }\r\n    externalFilter: any,\r\n    inlineFilterDef: {\r\n      [key: string]: boolean\r\n    },\r\n    filterDef: any\r\n  }) => {\r\n    const { inlineColumn, columnFilter, inlineExternal, externalFilter, inlineFilterDef, filterDef } = args;\r\n    this.inlineColumn = inlineColumn;\r\n    this.columnFilter = columnFilter;\r\n    this.inlineExternal = inlineExternal;\r\n    this.externalFilter = externalFilter;\r\n    this.inlineFilterDef = inlineFilterDef;\r\n    this.filterDef = filterDef;\r\n    this.gridFilterService.set(this.filter?.key, {\r\n      inlineColumn,\r\n      inlineExternal,\r\n      quickFilters: [],\r\n      inlineFilterDef,\r\n      selectedQuickFilter: null\r\n    });\r\n    this.filterChange.emit();\r\n  }\r\n\r\n  onReset = () => {\r\n    this.inlineColumn = {};\r\n    this.columnFilter = {};\r\n    this.inlineExternal = {};\r\n    this.externalFilter = {};\r\n    this.inlineFilterDef = {};\r\n    this.filterDef = {};\r\n    this.#loadDefault();\r\n    this.gridFilterService.set(this.filter?.key, {\r\n      inlineColumn: this.inlineColumn,\r\n      inlineExternal: this.columnFilter,\r\n      inlineFilterDef: this.inlineFilterDef,\r\n      quickFilters: [],\r\n      selectedQuickFilter: null\r\n    });\r\n    this.filterChange.emit();\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  onClearFilter = () => {\r\n    this.#clearFilter();\r\n    this.gridFilterService.set(this.filter?.key, {\r\n      inlineColumn: this.inlineColumn,\r\n      inlineExternal: this.columnFilter,\r\n      inlineFilterDef: this.inlineFilterDef,\r\n      quickFilters: [],\r\n      selectedQuickFilter: null\r\n    });\r\n    this.filterChange.emit();\r\n  }\r\n\r\n  setFilter = (args: {\r\n    columnFilter?: any,\r\n    externalFilter?: any,\r\n    filterDef?: any\r\n  }) => {\r\n    const { columnFilter,  externalFilter, filterDef} = args;\r\n    if (columnFilter) {\r\n      this.columnFilter = columnFilter;\r\n    }\r\n    if (externalFilter) {\r\n      this.externalFilter = externalFilter;\r\n    }\r\n    if (filterDef) {\r\n      this.filterDef = filterDef;\r\n    }\r\n    for (const externalFilter of this.externalFilters) {\r\n      if (externalFilter.type === 'daterange') {\r\n        this.externalFilter[externalFilter.field] = {\r\n          from: this.externalFilter[externalFilter.field]?.from ?? undefined,\r\n          to: this.externalFilter[externalFilter.field]?.to ?? undefined\r\n        };\r\n      }\r\n    }\r\n    this.ref.markForCheck();\r\n  }\r\n}\r\n"]}