@sd-angular/core 1.3.214 → 1.3.217
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/bundles/sd-angular-core-checkbox.umd.js +29 -3
- package/bundles/sd-angular-core-checkbox.umd.js.map +1 -1
- package/bundles/sd-angular-core-checkbox.umd.min.js +2 -2
- package/bundles/sd-angular-core-checkbox.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-date-time.umd.js +14 -6
- package/bundles/sd-angular-core-date-time.umd.js.map +1 -1
- package/bundles/sd-angular-core-date-time.umd.min.js +1 -1
- package/bundles/sd-angular-core-date-time.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-input-number.umd.js +3 -0
- package/bundles/sd-angular-core-input-number.umd.js.map +1 -1
- package/bundles/sd-angular-core-input-number.umd.min.js +1 -1
- package/bundles/sd-angular-core-input-number.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-input-upload-file.umd.js +54 -3
- package/bundles/sd-angular-core-input-upload-file.umd.js.map +1 -1
- package/bundles/sd-angular-core-input-upload-file.umd.min.js +2 -2
- package/bundles/sd-angular-core-input-upload-file.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-radio.umd.js +22 -2
- package/bundles/sd-angular-core-radio.umd.js.map +1 -1
- package/bundles/sd-angular-core-radio.umd.min.js +2 -2
- package/bundles/sd-angular-core-radio.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-switch.umd.js +34 -7
- package/bundles/sd-angular-core-switch.umd.js.map +1 -1
- package/bundles/sd-angular-core-switch.umd.min.js +2 -2
- package/bundles/sd-angular-core-switch.umd.min.js.map +1 -1
- package/checkbox/sd-angular-core-checkbox.metadata.json +1 -1
- package/checkbox/src/lib/checkbox.component.d.ts +4 -1
- package/date-time/sd-angular-core-date-time.metadata.json +1 -1
- package/date-time/src/lib/date-time.component.d.ts +1 -0
- package/esm2015/checkbox/src/lib/checkbox.component.js +26 -4
- package/esm2015/date-time/src/lib/date-time.component.js +8 -2
- package/esm2015/date-time/src/lib/date-time.module.js +6 -2
- package/esm2015/input-number/src/lib/input-number.component.js +4 -1
- package/esm2015/input-upload-file/src/lib/input-upload-file.component.js +44 -5
- package/esm2015/radio/src/lib/radio.component.js +19 -3
- package/esm2015/switch/src/lib/switch.component.js +26 -4
- package/esm2015/switch/src/lib/switch.module.js +3 -1
- package/fesm2015/sd-angular-core-checkbox.js +25 -3
- package/fesm2015/sd-angular-core-checkbox.js.map +1 -1
- package/fesm2015/sd-angular-core-date-time.js +12 -2
- package/fesm2015/sd-angular-core-date-time.js.map +1 -1
- package/fesm2015/sd-angular-core-input-number.js +3 -0
- package/fesm2015/sd-angular-core-input-number.js.map +1 -1
- package/fesm2015/sd-angular-core-input-upload-file.js +43 -4
- package/fesm2015/sd-angular-core-input-upload-file.js.map +1 -1
- package/fesm2015/sd-angular-core-radio.js +18 -2
- package/fesm2015/sd-angular-core-radio.js.map +1 -1
- package/fesm2015/sd-angular-core-switch.js +27 -3
- package/fesm2015/sd-angular-core-switch.js.map +1 -1
- package/input-number/sd-angular-core-input-number.metadata.json +1 -1
- package/input-number/src/lib/input-number.component.d.ts +1 -0
- package/input-upload-file/sd-angular-core-input-upload-file.metadata.json +1 -1
- package/input-upload-file/src/lib/input-upload-file.component.d.ts +8 -1
- package/package.json +1 -1
- package/radio/sd-angular-core-radio.metadata.json +1 -1
- package/radio/src/lib/radio.component.d.ts +4 -1
- package/{sd-angular-core-1.3.214.tgz → sd-angular-core-1.3.217.tgz} +0 -0
- package/switch/sd-angular-core-switch.metadata.json +1 -1
- package/switch/src/lib/switch.component.d.ts +4 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var _model, _subscription, _modelChanges, _validate, _uploadFile, _validator;
|
|
1
|
+
var _model, _subscription, _modelChanges, _updateValidator, _validate, _uploadFile, _validator;
|
|
2
2
|
import { __awaiter, __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
3
|
import { Component, Input, Output, EventEmitter, ChangeDetectorRef, } from '@angular/core';
|
|
4
4
|
import * as uuid from 'uuid';
|
|
@@ -7,7 +7,7 @@ import { SdNotifyService } from '@sd-angular/core/notify';
|
|
|
7
7
|
import { SdTranslateService } from '@sd-angular/core/translate';
|
|
8
8
|
import { Subscription, Subject } from 'rxjs';
|
|
9
9
|
import { startWith } from 'rxjs/operators';
|
|
10
|
-
import { FormControl } from '@angular/forms';
|
|
10
|
+
import { FormControl, Validators } from '@angular/forms';
|
|
11
11
|
class SdInputUploadFiletStateMatcher {
|
|
12
12
|
constructor(formControl) {
|
|
13
13
|
this.formControl = formControl;
|
|
@@ -30,6 +30,8 @@ export class SdInputUploadFile {
|
|
|
30
30
|
this.min = 0;
|
|
31
31
|
this.max = 1;
|
|
32
32
|
_model.set(this, void 0);
|
|
33
|
+
this.disableErrorMessage = false;
|
|
34
|
+
this.isRequired = false;
|
|
33
35
|
this.modelChange = new EventEmitter();
|
|
34
36
|
this.sdChange = new EventEmitter();
|
|
35
37
|
this.inputControl = new FormControl();
|
|
@@ -37,6 +39,23 @@ export class SdInputUploadFile {
|
|
|
37
39
|
this.matcher = new SdInputUploadFiletStateMatcher(this.formControl);
|
|
38
40
|
_subscription.set(this, new Subscription());
|
|
39
41
|
_modelChanges.set(this, new Subject());
|
|
42
|
+
_updateValidator.set(this, () => {
|
|
43
|
+
this.formControl.clearValidators();
|
|
44
|
+
this.formControl.clearAsyncValidators();
|
|
45
|
+
const validators = [];
|
|
46
|
+
const asyncValidators = [];
|
|
47
|
+
if (this.isRequired) {
|
|
48
|
+
validators.push(Validators.required);
|
|
49
|
+
}
|
|
50
|
+
if (this.inlineError) {
|
|
51
|
+
validators.push(this.customInlineErrorValidator());
|
|
52
|
+
}
|
|
53
|
+
this.formControl.setValidators(validators);
|
|
54
|
+
this.formControl.setAsyncValidators(asyncValidators);
|
|
55
|
+
this.formControl.updateValueAndValidity();
|
|
56
|
+
}
|
|
57
|
+
// Hàm tạo Validators tùy chỉnh cho inlineError
|
|
58
|
+
);
|
|
40
59
|
_validate.set(this, (file) => __awaiter(this, void 0, void 0, function* () {
|
|
41
60
|
var _a;
|
|
42
61
|
if (this.type === 'image') {
|
|
@@ -172,10 +191,27 @@ export class SdInputUploadFile {
|
|
|
172
191
|
__classPrivateFieldGet(this, _modelChanges).next(__classPrivateFieldGet(this, _model));
|
|
173
192
|
}
|
|
174
193
|
}
|
|
194
|
+
set _disableErrorMessage(val) {
|
|
195
|
+
this.disableErrorMessage = (val === '') || val;
|
|
196
|
+
}
|
|
197
|
+
set _inlineError(val) {
|
|
198
|
+
this.inlineError = val;
|
|
199
|
+
__classPrivateFieldGet(this, _updateValidator).call(this);
|
|
200
|
+
}
|
|
201
|
+
set required(val) {
|
|
202
|
+
this.isRequired = (val === '') || val;
|
|
203
|
+
__classPrivateFieldGet(this, _updateValidator).call(this);
|
|
204
|
+
}
|
|
175
205
|
ngOnInit() {
|
|
176
206
|
this.formControl.setValidators([__classPrivateFieldGet(this, _validator)]);
|
|
177
207
|
this.inputControl.disable();
|
|
178
208
|
}
|
|
209
|
+
// Hàm tạo Validators tùy chỉnh cho inlineError
|
|
210
|
+
customInlineErrorValidator() {
|
|
211
|
+
return (control) => {
|
|
212
|
+
return { inlineError: true };
|
|
213
|
+
};
|
|
214
|
+
}
|
|
179
215
|
ngAfterViewInit() {
|
|
180
216
|
__classPrivateFieldGet(this, _subscription).add(__classPrivateFieldGet(this, _modelChanges).pipe(startWith(__classPrivateFieldGet(this, _model))).subscribe((previewFiles) => {
|
|
181
217
|
if (Array.isArray(previewFiles)) {
|
|
@@ -200,11 +236,11 @@ export class SdInputUploadFile {
|
|
|
200
236
|
__classPrivateFieldGet(this, _subscription).unsubscribe();
|
|
201
237
|
}
|
|
202
238
|
}
|
|
203
|
-
_model = new WeakMap(), _subscription = new WeakMap(), _modelChanges = new WeakMap(), _validate = new WeakMap(), _uploadFile = new WeakMap(), _validator = new WeakMap();
|
|
239
|
+
_model = new WeakMap(), _subscription = new WeakMap(), _modelChanges = new WeakMap(), _updateValidator = new WeakMap(), _validate = new WeakMap(), _uploadFile = new WeakMap(), _validator = new WeakMap();
|
|
204
240
|
SdInputUploadFile.decorators = [
|
|
205
241
|
{ type: Component, args: [{
|
|
206
242
|
selector: 'sd-input-upload-file',
|
|
207
|
-
template: "<mat-form-field class=\"sd-md\" appearance=\"outline\">\r\n <mat-label *ngIf=\"label\">{{label}}</mat-label>\r\n <mat-chip-list [formControl]=\"formControl\" #chipList>\r\n <ng-container *ngFor=\"let item of previewFiles\">\r\n <mat-chip *ngIf=\"item\" [removable]=\"!formControl.disabled\" (removed)=\"onRemove(item)\"\r\n [removable]=\"formControl.disabled\">\r\n <span>{{item.fileName || item.src}}</span>\r\n <mat-icon matChipRemove *ngIf=\"!formControl.disabled\">cancel</mat-icon>\r\n </mat-chip>\r\n </ng-container>\r\n <input [formControl]=\"inputControl\" [placeholder]=\"placeholder || label\" [matChipInputFor]=\"chipList\"\r\n autocomplete=\"off\" [errorStateMatcher]=\"matcher\" matInput>\r\n <mat-icon class=\"pointer sd-suffix-icon\" (click)=\"onUpload()\" matSuffix>file_upload\r\n </mat-icon>\r\n </mat-chip-list>\r\n <mat-error *ngIf=\"formControl?.errors?.min\">\r\n {{formControl?.errors?.min}}\r\n </mat-error>\r\n <mat-error *ngIf=\"formControl?.errors?.max\">\r\n {{formControl?.errors?.max}}\r\n </mat-error>\r\n</mat-form-field>",
|
|
243
|
+
template: "<mat-form-field class=\"sd-md\" appearance=\"outline\">\r\n <mat-label *ngIf=\"label\">{{label}}</mat-label>\r\n <mat-chip-list [formControl]=\"formControl\" #chipList>\r\n <ng-container *ngFor=\"let item of previewFiles\">\r\n <mat-chip *ngIf=\"item\" [removable]=\"!formControl.disabled\" (removed)=\"onRemove(item)\"\r\n [removable]=\"formControl.disabled\">\r\n <span>{{item.fileName || item.src}}</span>\r\n <mat-icon matChipRemove *ngIf=\"!formControl.disabled\">cancel</mat-icon>\r\n </mat-chip>\r\n </ng-container>\r\n <input [formControl]=\"inputControl\" [placeholder]=\"placeholder || label\" [matChipInputFor]=\"chipList\"\r\n autocomplete=\"off\" [errorStateMatcher]=\"matcher\" matInput>\r\n <mat-icon class=\"pointer sd-suffix-icon\" (click)=\"onUpload()\" matSuffix>file_upload\r\n </mat-icon>\r\n </mat-chip-list>\r\n <mat-error *ngIf=\"formControl.errors?.required\">\r\n <ng-container *ngIf=\"!disableErrorMessage\">{{ \"This field is required\" | sdTranslate }}</ng-container>\r\n </mat-error>\r\n <mat-error *ngIf=\"formControl?.errors?.min\">\r\n {{formControl?.errors?.min}}\r\n </mat-error>\r\n <mat-error *ngIf=\"formControl?.errors?.max\">\r\n {{formControl?.errors?.max}}\r\n </mat-error>\r\n <mat-error *ngIf=\"formControl.errors?.inlineError\">\r\n <ng-container *ngIf=\"!disableErrorMessage\">{{inlineError}}</ng-container>\r\n </mat-error>\r\n</mat-form-field>",
|
|
208
244
|
styles: [":host{display:block;padding-top:5px}"]
|
|
209
245
|
},] }
|
|
210
246
|
];
|
|
@@ -225,7 +261,10 @@ SdInputUploadFile.propDecorators = {
|
|
|
225
261
|
maxHeight: [{ type: Input }],
|
|
226
262
|
disabled: [{ type: Input }],
|
|
227
263
|
model: [{ type: Input }],
|
|
264
|
+
_disableErrorMessage: [{ type: Input, args: ['disableErrorMessage',] }],
|
|
265
|
+
_inlineError: [{ type: Input, args: ['inlineError',] }],
|
|
266
|
+
required: [{ type: Input }],
|
|
228
267
|
modelChange: [{ type: Output }],
|
|
229
268
|
sdChange: [{ type: Output }]
|
|
230
269
|
};
|
|
231
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-upload-file.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/input-upload-file/","sources":["src/lib/input-upload-file.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ChangeDetectorRef,\r\n  AfterViewInit,\r\n  OnInit,\r\n  OnDestroy,\r\n} from '@angular/core';\r\nimport * as uuid from 'uuid';\r\nimport $ from 'jquery';\r\nimport { SdNotifyService } from '@sd-angular/core/notify';\r\nimport { SdTranslateService } from '@sd-angular/core/translate';\r\nimport { Subscription, Subject } from 'rxjs';\r\nimport { startWith } from 'rxjs/operators';\r\nimport { ErrorStateMatcher } from '@angular/material/core';\r\nimport { FormControl, FormGroupDirective, NgForm, AbstractControl, ValidatorFn } from '@angular/forms';\r\nclass SdInputUploadFiletStateMatcher implements ErrorStateMatcher {\r\n  constructor(private formControl: FormControl) { }\r\n  isErrorState(control: FormControl | null, form: FormGroupDirective | NgForm | null): boolean {\r\n    const isSubmitted = form && form.submitted;\r\n    return !!(this.formControl?.invalid && (this.formControl?.dirty || this.formControl?.touched || isSubmitted));\r\n  }\r\n}\r\n@Component({\r\n  selector: 'sd-input-upload-file',\r\n  templateUrl: './input-upload-file.component.html',\r\n  styleUrls: ['./input-upload-file.component.scss']\r\n})\r\nexport class SdInputUploadFile implements OnInit, AfterViewInit, OnDestroy {\r\n  id = `I${uuid.v4()}`;\r\n  previewFiles: SdPreviewFile[] = [];\r\n  @Input() label: string;\r\n  @Input() placeholder: string;\r\n  @Input() type: 'image' | 'file' = 'file';\r\n  @Input() extensions: string[] = [];\r\n  @Input() min = 0;\r\n  @Input() max = 1;\r\n  @Input() maxSize: number;\r\n  @Input() maxWidth: number;\r\n  @Input() maxHeight: number;\r\n  // Optional\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  #model: (string | SdPreviewFile)[];\r\n  @Input() set model(model: (string | SdPreviewFile)[]) {\r\n    if (this.previewFiles !== model && Array.isArray(model)) {\r\n      this.#model = model;\r\n      this.#modelChanges.next(this.#model);\r\n    }\r\n  }\r\n  @Output() modelChange = new EventEmitter<(string | SdPreviewFile)[]>();\r\n  @Output() sdChange = new EventEmitter<(string | SdPreviewFile)[]>();\r\n  inputControl = new FormControl();\r\n  formControl = new FormControl();\r\n  matcher = new SdInputUploadFiletStateMatcher(this.formControl);\r\n  #subscription = new Subscription();\r\n  #modelChanges = new Subject<(string | SdPreviewFile)[]>();\r\n  constructor(\r\n    private ref: ChangeDetectorRef,\r\n    private notifyService: SdNotifyService,\r\n    private translateService: SdTranslateService) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.formControl.setValidators([this.#validator]);\r\n    this.inputControl.disable();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.#subscription.add(this.#modelChanges.pipe(startWith(this.#model)).subscribe((previewFiles) => {\r\n      if (Array.isArray(previewFiles)) {\r\n        this.previewFiles = [];\r\n        previewFiles.forEach(previewFile => {\r\n          if (typeof (previewFile) === 'string') {\r\n            this.previewFiles.push({\r\n              file: null,\r\n              src: previewFile\r\n            })\r\n          } else {\r\n            this.previewFiles.push(previewFile);\r\n          }\r\n        });\r\n        this.formControl.setValue(this.previewFiles);\r\n        this.modelChange.emit(this.previewFiles);\r\n      }\r\n    }));\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.#subscription.unsubscribe();\r\n  }\r\n\r\n  #validate = async (file: File): Promise<string> => {\r\n    if (this.type === 'image') {\r\n      if (file.type.split('/')[0] !== 'image') {\r\n        return `[${file.name}] ${this.translateService.translate('Uploaded file is not an image')}`;\r\n      }\r\n    }\r\n    if (this.extensions?.length) {\r\n      const lastDot = file.name.lastIndexOf('.');\r\n      const extension = file.name.substring(lastDot + 1);\r\n      if (!this.extensions.some(e => e.toUpperCase() === extension.toUpperCase())) {\r\n        return `[${file.name}] ${this.translateService.translate('Uploaded file is not match extension')} ${this.extensions.join(', ')}`;\r\n      }\r\n    }\r\n    if (this.maxSize) {\r\n      if (this.maxSize * 1024 * 1024 < file.size) {\r\n        return `[${file.name}] ${this.translateService.translate('Max file size')} ${this.maxSize} Mbs`;\r\n      }\r\n    }\r\n    if (this.type === 'image' && (this.maxWidth || this.maxHeight)) {\r\n      const message: string = await new Promise(resolve => {\r\n        const URL = window.URL || window.webkitURL;\r\n        const img = new Image();\r\n        img.onload = () => {\r\n          if (this.maxWidth && img.width > this.maxWidth) {\r\n            resolve(`[${file.name}] ${this.translateService.translate('Max image width')} ${this.maxWidth}px`);\r\n          }\r\n          if (this.maxHeight && img.height > this.maxHeight) {\r\n            resolve(`[${file.name}] ${this.translateService.translate('Max image height')} ${this.maxHeight}px`);\r\n          }\r\n          resolve(null);\r\n        };\r\n        img.src = URL.createObjectURL(file);\r\n      });\r\n      if (message) {\r\n        return message;\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n\r\n  onUpload = () => {\r\n    if ($(`#${this.id}`).length) {\r\n      $('body').children(`#${this.id}`).remove();\r\n    }\r\n    if (this.max === 1) {\r\n      $('body').append(`<input id=\"${this.id}\" style=\"display: none\" type=\"file\" />`);\r\n    } else {\r\n      $('body').append(`<input id=\"${this.id}\" style=\"display: none\" type=\"file\" multiple />`);\r\n    }\r\n    $(`#${this.id}`).on('change', async (evt: any) => {\r\n      await this.#uploadFile(evt.target);\r\n      $('body').children(`#${this.id}`).remove();\r\n    });\r\n    $(`#${this.id}`).trigger('click');\r\n  }\r\n\r\n  #uploadFile = async (target: DataTransfer) => {\r\n    if (!target.files.length) {\r\n      return;\r\n    }\r\n    const originFiles = target.files;\r\n    const files: File[] = [];\r\n    if (originFiles.length + this.previewFiles.length > this.max) {\r\n      this.notifyService.notify.warning(`${this.translateService.translate('Max number of files')} ${this.max}`);\r\n      return;\r\n    }\r\n    for (let i = 0; i < originFiles.length; i++) {\r\n      let file = originFiles.item(i);\r\n      const message = await this.#validate(file);\r\n      if (message) {\r\n        this.notifyService.notify.warning(message);\r\n        return;\r\n      }\r\n      files.push(file);\r\n    }\r\n    for (const file of files) {\r\n      const lastDot = file.name.lastIndexOf('.');\r\n      const extension = file.name.substring(lastDot + 1);\r\n      this.previewFiles.push({\r\n        file,\r\n        src: null,\r\n        fileName: file.name,\r\n        extension\r\n      });\r\n    }\r\n    this.formControl.setValue(this.previewFiles);\r\n    this.sdChange.emit(this.previewFiles);\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  onRemove = (previewFile: SdPreviewFile): void => {\r\n    const idx = this.previewFiles.indexOf(previewFile);\r\n    this.previewFiles.splice(idx, 1);\r\n    this.formControl.setValue(this.previewFiles, {\r\n      emitEvent: false\r\n    });\r\n    this.formControl.setValue(this.previewFiles);\r\n    this.sdChange.emit(this.previewFiles);\r\n  }\r\n\r\n  #validator = (c: AbstractControl): { [key: string]: any } | null => {\r\n    const value = c.value || null;\r\n    if (this.min > 0) {\r\n      const previewFiles: SdPreviewFile[] = this.formControl.value || [];\r\n      if (previewFiles.length < this.min) {\r\n        return {\r\n          min: `${this.translateService.translate('Please select at least')} ${this.min}`\r\n        }\r\n      }\r\n    }\r\n    if (this.max > 0) {\r\n      const previewFiles: SdPreviewFile[] = this.formControl.value || [];\r\n      if (previewFiles.length > this.max) {\r\n        return {\r\n          max: `${this.translateService.translate('Please select at most')} ${this.max}`\r\n        }\r\n      }\r\n    }\r\n    return null;\r\n  };\r\n}\r\n\r\nexport interface SdPreviewFile {\r\n  file: File;\r\n  src: string | ArrayBuffer;\r\n  fileName?: string;\r\n  extension?: string;\r\n}\r\n"]}
|
|
270
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-upload-file.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/input-upload-file/","sources":["src/lib/input-upload-file.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ChangeDetectorRef,\r\n  AfterViewInit,\r\n  OnInit,\r\n  OnDestroy,\r\n} from '@angular/core';\r\nimport * as uuid from 'uuid';\r\nimport $ from 'jquery';\r\nimport { SdNotifyService } from '@sd-angular/core/notify';\r\nimport { SdTranslateService } from '@sd-angular/core/translate';\r\nimport { Subscription, Subject } from 'rxjs';\r\nimport { startWith } from 'rxjs/operators';\r\nimport { ErrorStateMatcher } from '@angular/material/core';\r\nimport { FormControl, FormGroupDirective, NgForm, AbstractControl, ValidatorFn, AsyncValidatorFn, Validators } from '@angular/forms';\r\nclass SdInputUploadFiletStateMatcher implements ErrorStateMatcher {\r\n  constructor(private formControl: FormControl) { }\r\n  isErrorState(control: FormControl | null, form: FormGroupDirective | NgForm | null): boolean {\r\n    const isSubmitted = form && form.submitted;\r\n    return !!(this.formControl?.invalid && (this.formControl?.dirty || this.formControl?.touched || isSubmitted));\r\n  }\r\n}\r\n@Component({\r\n  selector: 'sd-input-upload-file',\r\n  templateUrl: './input-upload-file.component.html',\r\n  styleUrls: ['./input-upload-file.component.scss']\r\n})\r\nexport class SdInputUploadFile implements OnInit, AfterViewInit, OnDestroy {\r\n  id = `I${uuid.v4()}`;\r\n  previewFiles: SdPreviewFile[] = [];\r\n  @Input() label: string;\r\n  @Input() placeholder: string;\r\n  @Input() type: 'image' | 'file' = 'file';\r\n  @Input() extensions: string[] = [];\r\n  @Input() min = 0;\r\n  @Input() max = 1;\r\n  @Input() maxSize: number;\r\n  @Input() maxWidth: number;\r\n  @Input() maxHeight: number;\r\n  // Optional\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  #model: (string | SdPreviewFile)[];\r\n  @Input() set model(model: (string | SdPreviewFile)[]) {\r\n    if (this.previewFiles !== model && Array.isArray(model)) {\r\n      this.#model = model;\r\n      this.#modelChanges.next(this.#model);\r\n    }\r\n  }\r\n  disableErrorMessage = false;\r\n  @Input('disableErrorMessage') set _disableErrorMessage(val: boolean | '') {\r\n    this.disableErrorMessage = (val === '') || val;\r\n  }\r\n  inlineError: string;\r\n  @Input('inlineError') set _inlineError(val: string) {\r\n    this.inlineError = val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  isRequired = false;\r\n  @Input() set required(val: boolean | '') {\r\n    this.isRequired = (val === '') || val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  @Output() modelChange = new EventEmitter<(string | SdPreviewFile)[]>();\r\n  @Output() sdChange = new EventEmitter<(string | SdPreviewFile)[]>();\r\n  inputControl = new FormControl();\r\n  formControl = new FormControl();\r\n  matcher = new SdInputUploadFiletStateMatcher(this.formControl);\r\n  #subscription = new Subscription();\r\n  #modelChanges = new Subject<(string | SdPreviewFile)[]>();\r\n  constructor(\r\n    private ref: ChangeDetectorRef,\r\n    private notifyService: SdNotifyService,\r\n    private translateService: SdTranslateService) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.formControl.setValidators([this.#validator]);\r\n    this.inputControl.disable();\r\n  }\r\n\r\n  \r\n  #updateValidator = () => {\r\n\r\n    this.formControl.clearValidators();\r\n    this.formControl.clearAsyncValidators();\r\n    const validators: ValidatorFn[] = [];\r\n    const asyncValidators: AsyncValidatorFn[] = [];\r\n    if (this.isRequired) {\r\n      validators.push(Validators.required);\r\n    }\r\n   \r\n    if (this.inlineError) {\r\n      validators.push(this.customInlineErrorValidator());\r\n    }\r\n    \r\n    this.formControl.setValidators(validators);\r\n    this.formControl.setAsyncValidators(asyncValidators);\r\n    this.formControl.updateValueAndValidity();\r\n  }\r\n\r\n  \r\n  // Hàm tạo Validators tùy chỉnh cho inlineError\r\n  customInlineErrorValidator(): ValidatorFn {\r\n    return (control: AbstractControl): { [key: string]: any } | null => {\r\n      return { inlineError: true };\r\n    };\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.#subscription.add(this.#modelChanges.pipe(startWith(this.#model)).subscribe((previewFiles) => {\r\n      if (Array.isArray(previewFiles)) {\r\n        this.previewFiles = [];\r\n        previewFiles.forEach(previewFile => {\r\n          if (typeof (previewFile) === 'string') {\r\n            this.previewFiles.push({\r\n              file: null,\r\n              src: previewFile\r\n            })\r\n          } else {\r\n            this.previewFiles.push(previewFile);\r\n          }\r\n        });\r\n        this.formControl.setValue(this.previewFiles);\r\n        this.modelChange.emit(this.previewFiles);\r\n      }\r\n    }));\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.#subscription.unsubscribe();\r\n  }\r\n\r\n  #validate = async (file: File): Promise<string> => {\r\n    if (this.type === 'image') {\r\n      if (file.type.split('/')[0] !== 'image') {\r\n        return `[${file.name}] ${this.translateService.translate('Uploaded file is not an image')}`;\r\n      }\r\n    }\r\n    if (this.extensions?.length) {\r\n      const lastDot = file.name.lastIndexOf('.');\r\n      const extension = file.name.substring(lastDot + 1);\r\n      if (!this.extensions.some(e => e.toUpperCase() === extension.toUpperCase())) {\r\n        return `[${file.name}] ${this.translateService.translate('Uploaded file is not match extension')} ${this.extensions.join(', ')}`;\r\n      }\r\n    }\r\n    if (this.maxSize) {\r\n      if (this.maxSize * 1024 * 1024 < file.size) {\r\n        return `[${file.name}] ${this.translateService.translate('Max file size')} ${this.maxSize} Mbs`;\r\n      }\r\n    }\r\n    if (this.type === 'image' && (this.maxWidth || this.maxHeight)) {\r\n      const message: string = await new Promise(resolve => {\r\n        const URL = window.URL || window.webkitURL;\r\n        const img = new Image();\r\n        img.onload = () => {\r\n          if (this.maxWidth && img.width > this.maxWidth) {\r\n            resolve(`[${file.name}] ${this.translateService.translate('Max image width')} ${this.maxWidth}px`);\r\n          }\r\n          if (this.maxHeight && img.height > this.maxHeight) {\r\n            resolve(`[${file.name}] ${this.translateService.translate('Max image height')} ${this.maxHeight}px`);\r\n          }\r\n          resolve(null);\r\n        };\r\n        img.src = URL.createObjectURL(file);\r\n      });\r\n      if (message) {\r\n        return message;\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n\r\n  onUpload = () => {\r\n    if ($(`#${this.id}`).length) {\r\n      $('body').children(`#${this.id}`).remove();\r\n    }\r\n    if (this.max === 1) {\r\n      $('body').append(`<input id=\"${this.id}\" style=\"display: none\" type=\"file\" />`);\r\n    } else {\r\n      $('body').append(`<input id=\"${this.id}\" style=\"display: none\" type=\"file\" multiple />`);\r\n    }\r\n    $(`#${this.id}`).on('change', async (evt: any) => {\r\n      await this.#uploadFile(evt.target);\r\n      $('body').children(`#${this.id}`).remove();\r\n    });\r\n    $(`#${this.id}`).trigger('click');\r\n  }\r\n\r\n  #uploadFile = async (target: DataTransfer) => {\r\n    if (!target.files.length) {\r\n      return;\r\n    }\r\n    const originFiles = target.files;\r\n    const files: File[] = [];\r\n    if (originFiles.length + this.previewFiles.length > this.max) {\r\n      this.notifyService.notify.warning(`${this.translateService.translate('Max number of files')} ${this.max}`);\r\n      return;\r\n    }\r\n    for (let i = 0; i < originFiles.length; i++) {\r\n      let file = originFiles.item(i);\r\n      const message = await this.#validate(file);\r\n      if (message) {\r\n        this.notifyService.notify.warning(message);\r\n        return;\r\n      }\r\n      files.push(file);\r\n    }\r\n    for (const file of files) {\r\n      const lastDot = file.name.lastIndexOf('.');\r\n      const extension = file.name.substring(lastDot + 1);\r\n      this.previewFiles.push({\r\n        file,\r\n        src: null,\r\n        fileName: file.name,\r\n        extension\r\n      });\r\n    }\r\n    this.formControl.setValue(this.previewFiles);\r\n    this.sdChange.emit(this.previewFiles);\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  onRemove = (previewFile: SdPreviewFile): void => {\r\n    const idx = this.previewFiles.indexOf(previewFile);\r\n    this.previewFiles.splice(idx, 1);\r\n    this.formControl.setValue(this.previewFiles, {\r\n      emitEvent: false\r\n    });\r\n    this.formControl.setValue(this.previewFiles);\r\n    this.sdChange.emit(this.previewFiles);\r\n  }\r\n\r\n  #validator = (c: AbstractControl): { [key: string]: any } | null => {\r\n    const value = c.value || null;\r\n    if (this.min > 0) {\r\n      const previewFiles: SdPreviewFile[] = this.formControl.value || [];\r\n      if (previewFiles.length < this.min) {\r\n        return {\r\n          min: `${this.translateService.translate('Please select at least')} ${this.min}`\r\n        }\r\n      }\r\n    }\r\n    if (this.max > 0) {\r\n      const previewFiles: SdPreviewFile[] = this.formControl.value || [];\r\n      if (previewFiles.length > this.max) {\r\n        return {\r\n          max: `${this.translateService.translate('Please select at most')} ${this.max}`\r\n        }\r\n      }\r\n    }\r\n    return null;\r\n  };\r\n}\r\n\r\nexport interface SdPreviewFile {\r\n  file: File;\r\n  src: string | ArrayBuffer;\r\n  fileName?: string;\r\n  extension?: string;\r\n}\r\n"]}
|
|
@@ -42,9 +42,14 @@ export class SdRadio {
|
|
|
42
42
|
if (__classPrivateFieldGet(this, _required)) {
|
|
43
43
|
validators.push(Validators.required);
|
|
44
44
|
}
|
|
45
|
+
if (this.inlineError) {
|
|
46
|
+
validators.push(this.customInlineErrorValidator());
|
|
47
|
+
}
|
|
45
48
|
this.formControl.setValidators(validators);
|
|
46
49
|
this.formControl.updateValueAndValidity();
|
|
47
|
-
}
|
|
50
|
+
}
|
|
51
|
+
// Hàm tạo Validators tùy chỉnh cho inlineError
|
|
52
|
+
);
|
|
48
53
|
this.reValidate = () => {
|
|
49
54
|
this.formControl.updateValueAndValidity({ emitEvent: true });
|
|
50
55
|
};
|
|
@@ -82,6 +87,10 @@ export class SdRadio {
|
|
|
82
87
|
__classPrivateFieldSet(this, _required, (val === '') || val);
|
|
83
88
|
__classPrivateFieldGet(this, _updateValidator).call(this);
|
|
84
89
|
}
|
|
90
|
+
set _inlineError(val) {
|
|
91
|
+
this.inlineError = val;
|
|
92
|
+
__classPrivateFieldGet(this, _updateValidator).call(this);
|
|
93
|
+
}
|
|
85
94
|
// Optional
|
|
86
95
|
set disabled(val) {
|
|
87
96
|
val = (val === '') || val;
|
|
@@ -120,12 +129,18 @@ export class SdRadio {
|
|
|
120
129
|
__classPrivateFieldGet(this, _subscription).unsubscribe();
|
|
121
130
|
(_a = __classPrivateFieldGet(this, _form)) === null || _a === void 0 ? void 0 : _a.removeControl(__classPrivateFieldGet(this, _name));
|
|
122
131
|
}
|
|
132
|
+
// Hàm tạo Validators tùy chỉnh cho inlineError
|
|
133
|
+
customInlineErrorValidator() {
|
|
134
|
+
return (control) => {
|
|
135
|
+
return { inlineError: true };
|
|
136
|
+
};
|
|
137
|
+
}
|
|
123
138
|
}
|
|
124
139
|
_name = new WeakMap(), _form = new WeakMap(), _model = new WeakMap(), _required = new WeakMap(), _subscription = new WeakMap(), _updateValidator = new WeakMap();
|
|
125
140
|
SdRadio.decorators = [
|
|
126
141
|
{ type: Component, args: [{
|
|
127
142
|
selector: 'sd-radio',
|
|
128
|
-
template: "<section [ngClass]=\"{'c-section': display == 'row'}\">\r\n <ng-container *ngIf=\"sdLabelDef?.templateRef\">\r\n <ng-container *ngTemplateOutlet=\"sdLabelDef.templateRef\">\r\n </ng-container>\r\n </ng-container>\r\n <label *ngIf=\"label&&!sdLabelDef?.templateRef\" class=\"d-block T14M\" [class.mb-0]=\"display === 'row'\">{{label}} <span class=\"text-danger mb-2\" *ngIf=\"required\">*</span></label>\r\n <mat-radio-group [ngClass]=\"{'c-radio-group-column': display === 'column', 'c-radio-group-row': display === 'row'}\"\r\n [formControl]=\"formControl\">\r\n <mat-radio-button color=\"primary\" [ngClass]=\"{'m-0': display === 'column', 'mr-16': display === 'row'}\"\r\n *ngFor=\"let item of items\" [value]=\"item[valueField]\">\r\n {{item[displayField]}}\r\n </mat-radio-button>\r\n </mat-radio-group>\r\n</section>",
|
|
143
|
+
template: "<section [ngClass]=\"{'c-section': display == 'row'}\">\r\n <ng-container *ngIf=\"sdLabelDef?.templateRef\">\r\n <ng-container *ngTemplateOutlet=\"sdLabelDef.templateRef\">\r\n </ng-container>\r\n </ng-container>\r\n <label *ngIf=\"label&&!sdLabelDef?.templateRef\" class=\"d-block T14M\" [class.mb-0]=\"display === 'row'\">{{label}} <span class=\"text-danger mb-2\" *ngIf=\"required\">*</span></label>\r\n <mat-radio-group [ngClass]=\"{'c-radio-group-column': display === 'column', 'c-radio-group-row': display === 'row'}\"\r\n [formControl]=\"formControl\">\r\n <mat-radio-button color=\"primary\" [ngClass]=\"{'m-0': display === 'column', 'mr-16': display === 'row'}\"\r\n *ngFor=\"let item of items\" [value]=\"item[valueField]\">\r\n {{item[displayField]}}\r\n </mat-radio-button>\r\n </mat-radio-group>\r\n \r\n <mat-error *ngIf=\"formControl.errors?.inlineError && formControl?.touched\">\r\n {{inlineError}}\r\n </mat-error>\r\n</section>",
|
|
129
144
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
130
145
|
styles: [":host{display:flex;flex-direction:column;height:100%}.c-section{align-content:center;align-items:center}.c-radio-group-column{align-items:flex-start;display:flex;flex:1;flex-direction:column}.c-radio-group-row{align-items:center;display:flex;flex:1;flex-direction:row}"]
|
|
131
146
|
},] }
|
|
@@ -144,10 +159,11 @@ SdRadio.propDecorators = {
|
|
|
144
159
|
valueField: [{ type: Input }],
|
|
145
160
|
displayField: [{ type: Input }],
|
|
146
161
|
required: [{ type: Input }],
|
|
162
|
+
_inlineError: [{ type: Input, args: ['inlineError',] }],
|
|
147
163
|
disabled: [{ type: Input }],
|
|
148
164
|
sdLabelDef: [{ type: ContentChild, args: [SdLabelDefDirective,] }],
|
|
149
165
|
modelChange: [{ type: Output }],
|
|
150
166
|
sdChange: [{ type: Output }],
|
|
151
167
|
sdSelection: [{ type: Output }]
|
|
152
168
|
};
|
|
153
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/radio/","sources":["src/lib/radio.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, ChangeDetectorRef, AfterViewInit, OnDestroy, OnInit, ChangeDetectionStrategy, ContentChild } from '@angular/core';\r\nimport { NgForm, Validators, ValidatorFn, FormGroup } from '@angular/forms';\r\nimport { SdLabelDefDirective } from '@sd-angular/core/common';\r\nimport { SdFormControl } from '@sd-angular/core/common';\r\nimport { Subscription } from 'rxjs';\r\nimport * as uuid from 'uuid';\r\n\r\n@Component({\r\n  selector: 'sd-radio',\r\n  templateUrl: './radio.component.html',\r\n  styleUrls: ['./radio.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class SdRadio implements OnInit, AfterViewInit, OnDestroy {\r\n  #name = uuid.v4();\r\n  @Input() set name(val: string) {\r\n    if (val) {\r\n      this.#name = val;\r\n    }\r\n  }\r\n  formControl = new SdFormControl();\r\n  // get isNumber() {\r\n  //   if (this.#model || this.#model === 0) {\r\n  //     return typeof (this.#model) === 'number';\r\n  //   }\r\n  //   if (this.items?.length) {\r\n  //     if (this.valueField) {\r\n  //       return typeof (this.items[0][this.valueField]) === 'number';\r\n  //     } else {\r\n  //       return typeof (this.items[0]) === 'number';\r\n  //     }\r\n  //   }\r\n  //   return false;\r\n  // }\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  @Input() label: string;\r\n  @Input() placeholder: string;\r\n  @Input() display: 'row' | 'column' = 'row';\r\n  // Model\r\n  #model: number | string | boolean;\r\n  @Input() set model(value: number | string | boolean) {\r\n    this.#model = value;\r\n    if (value !== this.formControl.value) {\r\n      this.formControl.setValue(value, {\r\n        emitEvent: false\r\n      });\r\n    }\r\n  }\r\n  // Items\r\n  items: any[] = [];\r\n  @Input('items') set pItems(items: any[]) {\r\n    if (!Array.isArray(items)) {\r\n      this.items = [];\r\n    }\r\n    this.items = items;\r\n  }\r\n  @Input() valueField: string;\r\n  @Input() displayField: string;\r\n\r\n  // Validator\r\n  #required = false;\r\n  @Input() set required(val: boolean | '') {\r\n    this.#required = (val === '') || val;\r\n    this.#updateValidator();\r\n  }\r\n  // Optional\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  @ContentChild(SdLabelDefDirective) sdLabelDef: SdLabelDefDirective;\r\n  @Output() modelChange = new EventEmitter();\r\n  @Output() sdChange = new EventEmitter();\r\n  @Output() sdSelection = new EventEmitter<{ value: any | any[], item?: any }>();\r\n  #subscription = new Subscription();\r\n  constructor(\r\n    public ref: ChangeDetectorRef\r\n  ) { }\r\n\r\n  ngOnInit() {\r\n    this.#subscription.add(this.formControl.sdChanges.subscribe(() => {\r\n      // this.formControl.updateValueAndValidity();\r\n      this.ref.markForCheck();\r\n    }));\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.#subscription.add(this.formControl.valueChanges.subscribe(value => {\r\n      let val = value;\r\n      // if (this.isNumber && Number.isNumber(value)) {\r\n      //   val = +value;\r\n      // }\r\n      this.modelChange.emit(val);\r\n      this.sdChange.emit(val);\r\n      this.sdSelection.emit({\r\n        value: val,\r\n        item: this.items?.find(e => val?.toString() === e?.[this.valueField]?.toString())\r\n      });\r\n    }));\r\n    this.#form?.addControl(this.#name, this.formControl);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.#subscription.unsubscribe();\r\n    this.#form?.removeControl(this.#name);\r\n  }\r\n\r\n  #updateValidator = () => {\r\n    this.formControl.clearValidators();\r\n    const validators: ValidatorFn[] = [];\r\n    if (this.#required) {\r\n      validators.push(Validators.required);\r\n    }\r\n    this.formControl.setValidators(validators);\r\n    this.formControl.updateValueAndValidity();\r\n  }\r\n\r\n  reValidate = () => {\r\n    this.formControl.updateValueAndValidity({ emitEvent: true });\r\n  }\r\n}\r\n"]}
|
|
169
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/radio/","sources":["src/lib/radio.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, ChangeDetectorRef, AfterViewInit, OnDestroy, OnInit, ChangeDetectionStrategy, ContentChild } from '@angular/core';\r\nimport { NgForm, Validators, ValidatorFn, FormGroup, AbstractControl } from '@angular/forms';\r\nimport { SdLabelDefDirective } from '@sd-angular/core/common';\r\nimport { SdFormControl } from '@sd-angular/core/common';\r\nimport { Subscription } from 'rxjs';\r\nimport * as uuid from 'uuid';\r\n\r\n@Component({\r\n  selector: 'sd-radio',\r\n  templateUrl: './radio.component.html',\r\n  styleUrls: ['./radio.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class SdRadio implements OnInit, AfterViewInit, OnDestroy {\r\n  #name = uuid.v4();\r\n  @Input() set name(val: string) {\r\n    if (val) {\r\n      this.#name = val;\r\n    }\r\n  }\r\n  formControl = new SdFormControl();\r\n  // get isNumber() {\r\n  //   if (this.#model || this.#model === 0) {\r\n  //     return typeof (this.#model) === 'number';\r\n  //   }\r\n  //   if (this.items?.length) {\r\n  //     if (this.valueField) {\r\n  //       return typeof (this.items[0][this.valueField]) === 'number';\r\n  //     } else {\r\n  //       return typeof (this.items[0]) === 'number';\r\n  //     }\r\n  //   }\r\n  //   return false;\r\n  // }\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  @Input() label: string;\r\n  @Input() placeholder: string;\r\n  @Input() display: 'row' | 'column' = 'row';\r\n  // Model\r\n  #model: number | string | boolean;\r\n  @Input() set model(value: number | string | boolean) {\r\n    this.#model = value;\r\n    if (value !== this.formControl.value) {\r\n      this.formControl.setValue(value, {\r\n        emitEvent: false\r\n      });\r\n    }\r\n  }\r\n  // Items\r\n  items: any[] = [];\r\n  @Input('items') set pItems(items: any[]) {\r\n    if (!Array.isArray(items)) {\r\n      this.items = [];\r\n    }\r\n    this.items = items;\r\n  }\r\n  @Input() valueField: string;\r\n  @Input() displayField: string;\r\n\r\n  // Validator\r\n  #required = false;\r\n  @Input() set required(val: boolean | '') {\r\n    this.#required = (val === '') || val;\r\n    this.#updateValidator();\r\n  }\r\n  \r\n  inlineError: string;\r\n  @Input('inlineError') set _inlineError(val: string) {\r\n    this.inlineError = val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  // Optional\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  @ContentChild(SdLabelDefDirective) sdLabelDef: SdLabelDefDirective;\r\n  @Output() modelChange = new EventEmitter();\r\n  @Output() sdChange = new EventEmitter();\r\n  @Output() sdSelection = new EventEmitter<{ value: any | any[], item?: any }>();\r\n  #subscription = new Subscription();\r\n  constructor(\r\n    public ref: ChangeDetectorRef\r\n  ) { }\r\n\r\n  ngOnInit() {\r\n    this.#subscription.add(this.formControl.sdChanges.subscribe(() => {\r\n      // this.formControl.updateValueAndValidity();\r\n      this.ref.markForCheck();\r\n    }));\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.#subscription.add(this.formControl.valueChanges.subscribe(value => {\r\n      let val = value;\r\n      // if (this.isNumber && Number.isNumber(value)) {\r\n      //   val = +value;\r\n      // }\r\n      this.modelChange.emit(val);\r\n      this.sdChange.emit(val);\r\n      this.sdSelection.emit({\r\n        value: val,\r\n        item: this.items?.find(e => val?.toString() === e?.[this.valueField]?.toString())\r\n      });\r\n    }));\r\n    this.#form?.addControl(this.#name, this.formControl);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.#subscription.unsubscribe();\r\n    this.#form?.removeControl(this.#name);\r\n  }\r\n\r\n  #updateValidator = () => {\r\n    this.formControl.clearValidators();\r\n    const validators: ValidatorFn[] = [];\r\n    if (this.#required) {\r\n      validators.push(Validators.required);\r\n    }\r\n    if (this.inlineError) {\r\n      validators.push(this.customInlineErrorValidator());\r\n    }\r\n    this.formControl.setValidators(validators);\r\n    this.formControl.updateValueAndValidity();\r\n  }\r\n\r\n    // Hàm tạo Validators tùy chỉnh cho inlineError\r\n    customInlineErrorValidator(): ValidatorFn {\r\n      return (control: AbstractControl): { [key: string]: any } | null => {\r\n        return { inlineError: true };\r\n      };\r\n    }\r\n\r\n  reValidate = () => {\r\n    this.formControl.updateValueAndValidity({ emitEvent: true });\r\n  }\r\n}\r\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var _name, _form, _subscription, _onChange;
|
|
1
|
+
var _name, _form, _subscription, _onChange, _updateValidator;
|
|
2
2
|
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
3
|
import { Component, Input, Output, EventEmitter, ChangeDetectorRef, ChangeDetectionStrategy } from '@angular/core';
|
|
4
4
|
import { FormControl, NgForm } from '@angular/forms';
|
|
@@ -18,6 +18,17 @@ export class SdSwitch {
|
|
|
18
18
|
this.modelChange.emit(value);
|
|
19
19
|
this.sdChange.emit(value);
|
|
20
20
|
});
|
|
21
|
+
_updateValidator.set(this, () => {
|
|
22
|
+
this.formControl.clearValidators();
|
|
23
|
+
const validators = [];
|
|
24
|
+
if (this.inlineError) {
|
|
25
|
+
validators.push(this.customInlineErrorValidator());
|
|
26
|
+
}
|
|
27
|
+
this.formControl.setValidators(validators);
|
|
28
|
+
this.formControl.updateValueAndValidity();
|
|
29
|
+
}
|
|
30
|
+
// Hàm tạo Validators tùy chỉnh cho inlineError
|
|
31
|
+
);
|
|
21
32
|
}
|
|
22
33
|
set form(val) {
|
|
23
34
|
if (val) {
|
|
@@ -45,6 +56,10 @@ export class SdSwitch {
|
|
|
45
56
|
});
|
|
46
57
|
}
|
|
47
58
|
}
|
|
59
|
+
set _inlineError(val) {
|
|
60
|
+
this.inlineError = val;
|
|
61
|
+
__classPrivateFieldGet(this, _updateValidator).call(this);
|
|
62
|
+
}
|
|
48
63
|
ngOnInit() {
|
|
49
64
|
}
|
|
50
65
|
ngAfterViewInit() {
|
|
@@ -58,12 +73,18 @@ export class SdSwitch {
|
|
|
58
73
|
(_a = __classPrivateFieldGet(this, _form)) === null || _a === void 0 ? void 0 : _a.removeControl(__classPrivateFieldGet(this, _name));
|
|
59
74
|
__classPrivateFieldGet(this, _subscription).unsubscribe();
|
|
60
75
|
}
|
|
76
|
+
// Hàm tạo Validators tùy chỉnh cho inlineError
|
|
77
|
+
customInlineErrorValidator() {
|
|
78
|
+
return (control) => {
|
|
79
|
+
return { inlineError: true };
|
|
80
|
+
};
|
|
81
|
+
}
|
|
61
82
|
}
|
|
62
|
-
_name = new WeakMap(), _form = new WeakMap(), _subscription = new WeakMap(), _onChange = new WeakMap();
|
|
83
|
+
_name = new WeakMap(), _form = new WeakMap(), _subscription = new WeakMap(), _onChange = new WeakMap(), _updateValidator = new WeakMap();
|
|
63
84
|
SdSwitch.decorators = [
|
|
64
85
|
{ type: Component, args: [{
|
|
65
86
|
selector: 'sd-switch',
|
|
66
|
-
template: "<mat-slide-toggle [formControl]=\"formControl\" [color]=\"color\"><span\r\n class=\"c-label\">{{label}}</span></mat-slide-toggle>",
|
|
87
|
+
template: "<mat-slide-toggle [formControl]=\"formControl\" [color]=\"color\"><span\r\n class=\"c-label\">{{label}}</span></mat-slide-toggle>\r\n <mat-error *ngIf=\"formControl.errors?.inlineError && formControl?.touched\">\r\n {{inlineError}}\r\n </mat-error>",
|
|
67
88
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
68
89
|
styles: [""]
|
|
69
90
|
},] }
|
|
@@ -78,7 +99,8 @@ SdSwitch.propDecorators = {
|
|
|
78
99
|
color: [{ type: Input }],
|
|
79
100
|
disabled: [{ type: Input }],
|
|
80
101
|
model: [{ type: Input }],
|
|
102
|
+
_inlineError: [{ type: Input, args: ['inlineError',] }],
|
|
81
103
|
modelChange: [{ type: Output }],
|
|
82
104
|
sdChange: [{ type: Output }]
|
|
83
105
|
};
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJDOi9Vc2Vycy9uZ2hpYXR0MTVfb25lbW91bnQvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvc3dpdGNoLyIsInNvdXJjZXMiOlsic3JjL2xpYi9zd2l0Y2guY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLFlBQVksRUFBRSxpQkFBaUIsRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuSCxPQUFPLEVBQW1CLFdBQVcsRUFBYSxNQUFNLEVBQWUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM5RixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ3BDLE9BQU8sS0FBSyxJQUFJLE1BQU0sTUFBTSxDQUFDO0FBUTdCLE1BQU0sT0FBTyxRQUFRO0lBMENuQixZQUFvQixHQUFzQjtRQUF0QixRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQXpDMUMsZ0JBQVEsSUFBSSxDQUFDLEVBQUUsRUFBRSxFQUFDO1FBRWxCLHdCQUFpQjtRQVdSLFVBQUssR0FBdUIsU0FBUyxDQUFDO1FBd0JyQyxnQkFBVyxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7UUFDakMsYUFBUSxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7UUFDeEMsZ0JBQVcsR0FBRyxJQUFJLFdBQVcsRUFBRSxDQUFDO1FBQ2hDLHdCQUFnQixJQUFJLFlBQVksRUFBRSxFQUFDO1FBaUJuQyxvQkFBWSxDQUFDLEtBQVUsRUFBRSxFQUFFO1lBQ3pCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQzdCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzVCLENBQUMsRUFBQTtRQUNELDJCQUFtQixHQUFHLEVBQUU7WUFDdEIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxlQUFlLEVBQUUsQ0FBQztZQUNuQyxNQUFNLFVBQVUsR0FBa0IsRUFBRSxDQUFDO1lBRXJDLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRTtnQkFDcEIsVUFBVSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsMEJBQTBCLEVBQUUsQ0FBQyxDQUFDO2FBQ3BEO1lBQ0QsSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDM0MsSUFBSSxDQUFDLFdBQVcsQ0FBQyxzQkFBc0IsRUFBRSxDQUFDO1FBQzVDLENBQUM7UUFDRSwrQ0FBK0M7VUFEakQ7SUE1QkQsQ0FBQztJQXZDRCxJQUFhLElBQUksQ0FBQyxHQUF1QjtRQUN2QyxJQUFJLEdBQUcsRUFBRTtZQUNQLElBQUksR0FBRyxZQUFZLE1BQU0sRUFBRTtnQkFDekIsdUJBQUEsSUFBSSxTQUFTLEdBQUcsQ0FBQyxJQUFJLEVBQUM7YUFDdkI7aUJBQU07Z0JBQ0wsdUJBQUEsSUFBSSxTQUFTLEdBQUcsRUFBQzthQUNsQjtTQUNGO0lBQ0gsQ0FBQztJQUdELElBQWEsUUFBUSxDQUFDLEdBQWlCO1FBQ3JDLEdBQUcsR0FBRyxDQUFDLEdBQUcsS0FBSyxFQUFFLENBQUMsSUFBSSxHQUFHLENBQUM7UUFDMUIsSUFBSSxHQUFHLEVBQUU7WUFDUCxJQUFJLENBQUMsV0FBVyxDQUFDLE9BQU8sRUFBRSxDQUFDO1NBQzVCO2FBQU07WUFDTCxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sRUFBRSxDQUFDO1NBQzNCO0lBQ0gsQ0FBQztJQUVELElBQWEsS0FBSyxDQUFDLEtBQVU7UUFDM0IsSUFBSSxJQUFJLENBQUMsV0FBVyxDQUFDLEtBQUssS0FBSyxLQUFLLEVBQUU7WUFDcEMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxRQUFRLENBQUMsS0FBSyxFQUFFO2dCQUMvQixTQUFTLEVBQUUsS0FBSzthQUNqQixDQUFDLENBQUM7U0FDSjtJQUNILENBQUM7SUFHRCxJQUEwQixZQUFZLENBQUMsR0FBVztRQUNoRCxJQUFJLENBQUMsV0FBVyxHQUFHLEdBQUcsQ0FBQztRQUN2QixvREFBQSxJQUFJLENBQW1CLENBQUM7SUFDMUIsQ0FBQztJQVNELFFBQVE7SUFDUixDQUFDO0lBQ0QsZUFBZTs7UUFDYiw0Q0FBbUIsR0FBRyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsWUFBWSxDQUFDLFNBQVMseUNBQWdCLENBQUMsQ0FBQztRQUNoRixtRkFBWSxVQUFVLHNDQUFhLElBQUksQ0FBQyxXQUFXLEVBQUU7UUFDckQsSUFBSSxDQUFDLEdBQUcsQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBRUQsV0FBVzs7UUFDVCxtRkFBWSxhQUFhLHNDQUFhO1FBQ3RDLDRDQUFtQixXQUFXLEVBQUUsQ0FBQztJQUNuQyxDQUFDO0lBZ0JFLCtDQUErQztJQUMvQywwQkFBMEI7UUFDekIsT0FBTyxDQUFDLE9BQXdCLEVBQWlDLEVBQUU7WUFDakUsT0FBTyxFQUFFLFdBQVcsRUFBRSxJQUFJLEVBQUUsQ0FBQztRQUMvQixDQUFDLENBQUM7SUFDSixDQUFDOzs7O1lBbkZKLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsV0FBVztnQkFDckIsa1JBQXNDO2dCQUV0QyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTs7YUFDaEQ7OztZQVZnRCxpQkFBaUI7OzttQkFhL0QsS0FBSzttQkFFTCxLQUFLO29CQVNMLEtBQUs7b0JBQ0wsS0FBSzt1QkFDTCxLQUFLO29CQVNMLEtBQUs7MkJBU0wsS0FBSyxTQUFDLGFBQWE7MEJBS25CLE1BQU07dUJBQ04sTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE91dHB1dCwgRXZlbnRFbWl0dGVyLCBDaGFuZ2VEZXRlY3RvclJlZiwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQWJzdHJhY3RDb250cm9sLCBGb3JtQ29udHJvbCwgRm9ybUdyb3VwLCBOZ0Zvcm0sIFZhbGlkYXRvckZuIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBTdWJzY3JpcHRpb24gfSBmcm9tICdyeGpzJztcclxuaW1wb3J0ICogYXMgdXVpZCBmcm9tICd1dWlkJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnc2Qtc3dpdGNoJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vc3dpdGNoLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9zd2l0Y2guY29tcG9uZW50LnNjc3MnXSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2RTd2l0Y2gge1xyXG4gICNuYW1lID0gdXVpZC52NCgpO1xyXG4gIEBJbnB1dCgpIHNpemU6ICdzbScgfCAnbGcnO1xyXG4gICNmb3JtOiBGb3JtR3JvdXA7XHJcbiAgQElucHV0KCkgc2V0IGZvcm0odmFsOiBOZ0Zvcm0gfCBGb3JtR3JvdXApIHtcclxuICAgIGlmICh2YWwpIHtcclxuICAgICAgaWYgKHZhbCBpbnN0YW5jZW9mIE5nRm9ybSkge1xyXG4gICAgICAgIHRoaXMuI2Zvcm0gPSB2YWwuZm9ybTtcclxuICAgICAgfSBlbHNlIHtcclxuICAgICAgICB0aGlzLiNmb3JtID0gdmFsO1xyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgfVxyXG4gIEBJbnB1dCgpIGxhYmVsOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgY29sb3I6ICdwcmltYXJ5JyB8ICd3YXJuJyA9ICdwcmltYXJ5JztcclxuICBASW5wdXQoKSBzZXQgZGlzYWJsZWQodmFsOiBib29sZWFuIHwgJycpIHtcclxuICAgIHZhbCA9ICh2YWwgPT09ICcnKSB8fCB2YWw7XHJcbiAgICBpZiAodmFsKSB7XHJcbiAgICAgIHRoaXMuZm9ybUNvbnRyb2wuZGlzYWJsZSgpO1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgdGhpcy5mb3JtQ29udHJvbC5lbmFibGUoKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIEBJbnB1dCgpIHNldCBtb2RlbCh2YWx1ZTogYW55KSB7XHJcbiAgICBpZiAodGhpcy5mb3JtQ29udHJvbC52YWx1ZSAhPT0gdmFsdWUpIHtcclxuICAgICAgdGhpcy5mb3JtQ29udHJvbC5zZXRWYWx1ZSh2YWx1ZSwge1xyXG4gICAgICAgIGVtaXRFdmVudDogZmFsc2VcclxuICAgICAgfSk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBpbmxpbmVFcnJvcjogc3RyaW5nO1xyXG4gIEBJbnB1dCgnaW5saW5lRXJyb3InKSBzZXQgX2lubGluZUVycm9yKHZhbDogc3RyaW5nKSB7XHJcbiAgICB0aGlzLmlubGluZUVycm9yID0gdmFsO1xyXG4gICAgdGhpcy4jdXBkYXRlVmFsaWRhdG9yKCk7XHJcbiAgfVxyXG5cclxuICBAT3V0cHV0KCkgbW9kZWxDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcbiAgQE91dHB1dCgpIHNkQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG4gIGZvcm1Db250cm9sID0gbmV3IEZvcm1Db250cm9sKCk7XHJcbiAgI3N1YnNjcmlwdGlvbiA9IG5ldyBTdWJzY3JpcHRpb24oKTtcclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlZjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcclxuICB9XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gIH1cclxuICBuZ0FmdGVyVmlld0luaXQoKSB7XHJcbiAgICB0aGlzLiNzdWJzY3JpcHRpb24uYWRkKHRoaXMuZm9ybUNvbnRyb2wudmFsdWVDaGFuZ2VzLnN1YnNjcmliZSh0aGlzLiNvbkNoYW5nZSkpO1xyXG4gICAgdGhpcy4jZm9ybT8uYWRkQ29udHJvbCh0aGlzLiNuYW1lLCB0aGlzLmZvcm1Db250cm9sKTtcclxuICAgIHRoaXMucmVmLmRldGVjdENoYW5nZXMoKTtcclxuICB9XHJcblxyXG4gIG5nT25EZXN0cm95KCkge1xyXG4gICAgdGhpcy4jZm9ybT8ucmVtb3ZlQ29udHJvbCh0aGlzLiNuYW1lKTtcclxuICAgIHRoaXMuI3N1YnNjcmlwdGlvbi51bnN1YnNjcmliZSgpO1xyXG4gIH1cclxuXHJcbiAgI29uQ2hhbmdlID0gKHZhbHVlOiBhbnkpID0+IHtcclxuICAgIHRoaXMubW9kZWxDaGFuZ2UuZW1pdCh2YWx1ZSk7XHJcbiAgICB0aGlzLnNkQ2hhbmdlLmVtaXQodmFsdWUpO1xyXG4gIH1cclxuICAjdXBkYXRlVmFsaWRhdG9yID0gKCkgPT4ge1xyXG4gICAgdGhpcy5mb3JtQ29udHJvbC5jbGVhclZhbGlkYXRvcnMoKTtcclxuICAgIGNvbnN0IHZhbGlkYXRvcnM6IFZhbGlkYXRvckZuW10gPSBbXTtcclxuICAgIFxyXG4gICAgaWYgKHRoaXMuaW5saW5lRXJyb3IpIHtcclxuICAgICAgdmFsaWRhdG9ycy5wdXNoKHRoaXMuY3VzdG9tSW5saW5lRXJyb3JWYWxpZGF0b3IoKSk7XHJcbiAgICB9XHJcbiAgICB0aGlzLmZvcm1Db250cm9sLnNldFZhbGlkYXRvcnModmFsaWRhdG9ycyk7XHJcbiAgICB0aGlzLmZvcm1Db250cm9sLnVwZGF0ZVZhbHVlQW5kVmFsaWRpdHkoKTtcclxuICB9XHJcbiAgICAgLy8gSMOgbSB04bqhbyBWYWxpZGF0b3JzIHTDuXkgY2jhu4luaCBjaG8gaW5saW5lRXJyb3JcclxuICAgICBjdXN0b21JbmxpbmVFcnJvclZhbGlkYXRvcigpOiBWYWxpZGF0b3JGbiB7XHJcbiAgICAgIHJldHVybiAoY29udHJvbDogQWJzdHJhY3RDb250cm9sKTogeyBba2V5OiBzdHJpbmddOiBhbnkgfSB8IG51bGwgPT4ge1xyXG4gICAgICAgIHJldHVybiB7IGlubGluZUVycm9yOiB0cnVlIH07XHJcbiAgICAgIH07XHJcbiAgICB9XHJcbn1cclxuIl19
|
|
@@ -3,6 +3,7 @@ import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
|
3
3
|
import { CommonModule } from '@angular/common';
|
|
4
4
|
import { MatSlideToggleModule } from '@angular/material/slide-toggle';
|
|
5
5
|
import { SdSwitch } from './switch.component';
|
|
6
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
6
7
|
export class SdSwitchModule {
|
|
7
8
|
}
|
|
8
9
|
SdSwitchModule.decorators = [
|
|
@@ -12,6 +13,7 @@ SdSwitchModule.decorators = [
|
|
|
12
13
|
FormsModule,
|
|
13
14
|
ReactiveFormsModule,
|
|
14
15
|
MatSlideToggleModule,
|
|
16
|
+
MatFormFieldModule
|
|
15
17
|
],
|
|
16
18
|
declarations: [
|
|
17
19
|
SdSwitch
|
|
@@ -21,4 +23,4 @@ SdSwitchModule.decorators = [
|
|
|
21
23
|
]
|
|
22
24
|
},] }
|
|
23
25
|
];
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3dpdGNoLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJDOi9Vc2Vycy9uZ2hpYXR0MTVfb25lbW91bnQvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvc3dpdGNoLyIsInNvdXJjZXMiOlsic3JjL2xpYi9zd2l0Y2gubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN0RSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDOUMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFpQmxFLE1BQU0sT0FBTyxjQUFjOzs7WUFmMUIsUUFBUSxTQUFDO2dCQUNSLE9BQU8sRUFBRTtvQkFDUCxZQUFZO29CQUNaLFdBQVc7b0JBQ1gsbUJBQW1CO29CQUNuQixvQkFBb0I7b0JBQ3BCLGtCQUFrQjtpQkFDbkI7Z0JBQ0QsWUFBWSxFQUFFO29CQUNaLFFBQVE7aUJBQ1Q7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLFFBQVE7aUJBQ1Q7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBNYXRTbGlkZVRvZ2dsZU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NsaWRlLXRvZ2dsZSc7XHJcbmltcG9ydCB7IFNkU3dpdGNoIH0gZnJvbSAnLi9zd2l0Y2guY29tcG9uZW50JztcclxuaW1wb3J0IHsgTWF0Rm9ybUZpZWxkTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZm9ybS1maWVsZCc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcclxuICAgIE1hdFNsaWRlVG9nZ2xlTW9kdWxlLFxyXG4gICAgTWF0Rm9ybUZpZWxkTW9kdWxlXHJcbiAgXSxcclxuICBkZWNsYXJhdGlvbnM6IFtcclxuICAgIFNkU3dpdGNoXHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBTZFN3aXRjaFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFNkU3dpdGNoTW9kdWxlIHsgfVxyXG4iXX0=
|
|
@@ -7,7 +7,7 @@ import { __classPrivateFieldSet, __classPrivateFieldGet } from 'tslib';
|
|
|
7
7
|
import { Subscription } from 'rxjs';
|
|
8
8
|
import { v4 } from 'uuid';
|
|
9
9
|
|
|
10
|
-
var _name, _form, _subscription, _model, _onChange;
|
|
10
|
+
var _name, _form, _subscription, _model, _onChange, _updateValidator;
|
|
11
11
|
class SdCheckbox {
|
|
12
12
|
constructor(ref) {
|
|
13
13
|
this.ref = ref;
|
|
@@ -24,6 +24,17 @@ class SdCheckbox {
|
|
|
24
24
|
this.modelChange.emit(value);
|
|
25
25
|
this.sdChange.emit(value);
|
|
26
26
|
});
|
|
27
|
+
_updateValidator.set(this, () => {
|
|
28
|
+
this.formControl.clearValidators();
|
|
29
|
+
const validators = [];
|
|
30
|
+
if (this.inlineError) {
|
|
31
|
+
validators.push(this.customInlineErrorValidator());
|
|
32
|
+
}
|
|
33
|
+
this.formControl.setValidators(validators);
|
|
34
|
+
this.formControl.updateValueAndValidity();
|
|
35
|
+
}
|
|
36
|
+
// Hàm tạo Validators tùy chỉnh cho inlineError
|
|
37
|
+
);
|
|
27
38
|
}
|
|
28
39
|
set name(val) {
|
|
29
40
|
if (val) {
|
|
@@ -57,6 +68,10 @@ class SdCheckbox {
|
|
|
57
68
|
});
|
|
58
69
|
}
|
|
59
70
|
}
|
|
71
|
+
set _inlineError(val) {
|
|
72
|
+
this.inlineError = val;
|
|
73
|
+
__classPrivateFieldGet(this, _updateValidator).call(this);
|
|
74
|
+
}
|
|
60
75
|
ngOnInit() {
|
|
61
76
|
}
|
|
62
77
|
ngAfterViewInit() {
|
|
@@ -70,12 +85,18 @@ class SdCheckbox {
|
|
|
70
85
|
(_a = __classPrivateFieldGet(this, _form)) === null || _a === void 0 ? void 0 : _a.removeControl(__classPrivateFieldGet(this, _name));
|
|
71
86
|
__classPrivateFieldGet(this, _subscription).unsubscribe();
|
|
72
87
|
}
|
|
88
|
+
// Hàm tạo Validators tùy chỉnh cho inlineError
|
|
89
|
+
customInlineErrorValidator() {
|
|
90
|
+
return (control) => {
|
|
91
|
+
return { inlineError: true };
|
|
92
|
+
};
|
|
93
|
+
}
|
|
73
94
|
}
|
|
74
|
-
_name = new WeakMap(), _form = new WeakMap(), _subscription = new WeakMap(), _model = new WeakMap(), _onChange = new WeakMap();
|
|
95
|
+
_name = new WeakMap(), _form = new WeakMap(), _subscription = new WeakMap(), _model = new WeakMap(), _onChange = new WeakMap(), _updateValidator = new WeakMap();
|
|
75
96
|
SdCheckbox.decorators = [
|
|
76
97
|
{ type: Component, args: [{
|
|
77
98
|
selector: 'sd-checkbox',
|
|
78
|
-
template: "<mat-checkbox [formControl]=\"formControl\" [color]=\"color\">{{label}}</mat-checkbox>"
|
|
99
|
+
template: "<mat-checkbox [formControl]=\"formControl\" [color]=\"color\">{{label}}</mat-checkbox>\r\n<mat-error *ngIf=\"formControl.errors?.inlineError && formControl?.touched\">\r\n {{inlineError}}\r\n</mat-error>"
|
|
79
100
|
},] }
|
|
80
101
|
];
|
|
81
102
|
SdCheckbox.ctorParameters = () => [
|
|
@@ -88,6 +109,7 @@ SdCheckbox.propDecorators = {
|
|
|
88
109
|
color: [{ type: Input }],
|
|
89
110
|
disabled: [{ type: Input }],
|
|
90
111
|
model: [{ type: Input }],
|
|
112
|
+
_inlineError: [{ type: Input, args: ['inlineError',] }],
|
|
91
113
|
modelChange: [{ type: Output }],
|
|
92
114
|
sdChange: [{ type: Output }]
|
|
93
115
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sd-angular-core-checkbox.js","sources":["../../../../projects/sd-core/checkbox/src/lib/checkbox.component.ts","../../../../projects/sd-core/checkbox/src/lib/checkbox.module.ts","../../../../projects/sd-core/checkbox/sd-angular-core-checkbox.ts"],"sourcesContent":["import { Component, Input, Output, EventEmitter, ChangeDetectorRef, OnDestroy, OnInit, AfterViewInit } from '@angular/core';\r\nimport { FormControl, FormGroup, NgForm } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport * as uuid from 'uuid';\r\n\r\n@Component({\r\n selector: 'sd-checkbox',\r\n templateUrl: './checkbox.component.html'\r\n})\r\nexport class SdCheckbox implements OnDestroy, OnInit, AfterViewInit {\r\n id = `I${uuid.v4()}`;\r\n #name = uuid.v4();\r\n @Input() set name(val: string) {\r\n if (val) {\r\n this.#name = val;\r\n }\r\n }\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 formControl = new FormControl();\r\n #subscription = new Subscription();\r\n @Input() label: string;\r\n @Input() color: 'primary' | 'warn' = 'primary';\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 #model: any;\r\n @Input() set model(value: any) {\r\n if (this.#model !== value) {\r\n this.#model = value;\r\n this.formControl.setValue(value, {\r\n emitEvent: false\r\n });\r\n }\r\n }\r\n @Output() modelChange = new EventEmitter();\r\n @Output() sdChange = new EventEmitter<any>();\r\n constructor(\r\n private ref: ChangeDetectorRef) {\r\n }\r\n\r\n ngOnInit() {\r\n }\r\n\r\n ngAfterViewInit() {\r\n this.#subscription.add(this.formControl.valueChanges.subscribe(this.#onChange));\r\n this.#form?.addControl(this.#name, this.formControl);\r\n this.ref.detectChanges();\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 #onChange = (value: any) => {\r\n this.modelChange.emit(value);\r\n this.sdChange.emit(value);\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { SdCheckbox } from './checkbox.component';\r\n\r\n@NgModule({\r\n imports: [\r\n CommonModule,\r\n FormsModule,\r\n ReactiveFormsModule,\r\n MatFormFieldModule,\r\n MatCheckboxModule\r\n ],\r\n declarations: [\r\n SdCheckbox\r\n ],\r\n exports: [\r\n SdCheckbox\r\n ]\r\n})\r\nexport class SdCheckboxModule { }\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n\nexport {SdCheckbox as ɵa} from './src/lib/checkbox.component';"],"names":["uuid.v4"],"mappings":";;;;;;;;;;MASa,UAAU;
|
|
1
|
+
{"version":3,"file":"sd-angular-core-checkbox.js","sources":["../../../../projects/sd-core/checkbox/src/lib/checkbox.component.ts","../../../../projects/sd-core/checkbox/src/lib/checkbox.module.ts","../../../../projects/sd-core/checkbox/sd-angular-core-checkbox.ts"],"sourcesContent":["import { Component, Input, Output, EventEmitter, ChangeDetectorRef, OnDestroy, OnInit, AfterViewInit } from '@angular/core';\r\nimport { AbstractControl, FormControl, FormGroup, NgForm, ValidatorFn } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport * as uuid from 'uuid';\r\n\r\n@Component({\r\n selector: 'sd-checkbox',\r\n templateUrl: './checkbox.component.html'\r\n})\r\nexport class SdCheckbox implements OnDestroy, OnInit, AfterViewInit {\r\n id = `I${uuid.v4()}`;\r\n #name = uuid.v4();\r\n @Input() set name(val: string) {\r\n if (val) {\r\n this.#name = val;\r\n }\r\n }\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 formControl = new FormControl();\r\n #subscription = new Subscription();\r\n @Input() label: string;\r\n @Input() color: 'primary' | 'warn' = 'primary';\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 #model: any;\r\n @Input() set model(value: any) {\r\n if (this.#model !== value) {\r\n this.#model = value;\r\n this.formControl.setValue(value, {\r\n emitEvent: false\r\n });\r\n }\r\n }\r\n inlineError: string;\r\n @Input('inlineError') set _inlineError(val: string) {\r\n this.inlineError = val;\r\n this.#updateValidator();\r\n }\r\n\r\n @Output() modelChange = new EventEmitter();\r\n @Output() sdChange = new EventEmitter<any>();\r\n constructor(\r\n private ref: ChangeDetectorRef) {\r\n }\r\n\r\n ngOnInit() {\r\n }\r\n\r\n ngAfterViewInit() {\r\n this.#subscription.add(this.formControl.valueChanges.subscribe(this.#onChange));\r\n this.#form?.addControl(this.#name, this.formControl);\r\n this.ref.detectChanges();\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 #onChange = (value: any) => {\r\n this.modelChange.emit(value);\r\n this.sdChange.emit(value);\r\n }\r\n #updateValidator = () => {\r\n this.formControl.clearValidators();\r\n const validators: ValidatorFn[] = [];\r\n \r\n if (this.inlineError) {\r\n validators.push(this.customInlineErrorValidator());\r\n }\r\n this.formControl.setValidators(validators);\r\n this.formControl.updateValueAndValidity();\r\n }\r\n // Hàm tạo Validators tùy chỉnh cho inlineError\r\n customInlineErrorValidator(): ValidatorFn {\r\n return (control: AbstractControl): { [key: string]: any } | null => {\r\n return { inlineError: true };\r\n };\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MatCheckboxModule } from '@angular/material/checkbox';\r\nimport { MatFormFieldModule } from '@angular/material/form-field';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { SdCheckbox } from './checkbox.component';\r\n\r\n@NgModule({\r\n imports: [\r\n CommonModule,\r\n FormsModule,\r\n ReactiveFormsModule,\r\n MatFormFieldModule,\r\n MatCheckboxModule\r\n ],\r\n declarations: [\r\n SdCheckbox\r\n ],\r\n exports: [\r\n SdCheckbox\r\n ]\r\n})\r\nexport class SdCheckboxModule { }\r\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n\nexport {SdCheckbox as ɵa} from './src/lib/checkbox.component';"],"names":["uuid.v4"],"mappings":"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"}
|