ng-ipa-library 5.0.11 → 6.0.0
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/fesm2022/ng-ipa-library.mjs +117 -104
- package/fesm2022/ng-ipa-library.mjs.map +1 -1
- package/lib/core/interceptors/myIPAToken.interceptor.d.ts +4 -1
- package/package.json +11 -13
- package/src/lib/assets/ngIPAStyle.scss +6 -14
- package/esm2022/lib/core/components/loading/loading.component.mjs +0 -37
- package/esm2022/lib/core/interceptors/error.interceptor.mjs +0 -46
- package/esm2022/lib/core/interceptors/loading.interceptor.mjs +0 -58
- package/esm2022/lib/core/interceptors/myIPAToken.interceptor.mjs +0 -25
- package/esm2022/lib/core/interceptors/token.interceptor.mjs +0 -81
- package/esm2022/lib/core/services/auth.service.mjs +0 -62
- package/esm2022/lib/core/services/error.service.mjs +0 -55
- package/esm2022/lib/core/services/loader.service.mjs +0 -24
- package/esm2022/lib/core/services/token.service.mjs +0 -22
- package/esm2022/lib/generate-form/generate-form.component.mjs +0 -153
- package/esm2022/lib/ipa-form/datepicker/datepicker.component.mjs +0 -124
- package/esm2022/lib/ipa-form/datepicker/gregorian-datepicker/gregorian-datepicker.component.mjs +0 -27
- package/esm2022/lib/ipa-form/datepicker/gregorian-datepicker/gregorian18n.mjs +0 -38
- package/esm2022/lib/ipa-form/datepicker/hijri-datepicker/IslamicI18n.mjs +0 -38
- package/esm2022/lib/ipa-form/datepicker/hijri-datepicker/hijri-datepicker.component.mjs +0 -27
- package/esm2022/lib/ipa-form/dropdown-input/dropdown-input.component.mjs +0 -84
- package/esm2022/lib/ipa-form/file-upload/file-upload.component.mjs +0 -142
- package/esm2022/lib/ipa-form/ipa-form.service.mjs +0 -290
- package/esm2022/lib/ipa-form/recaptcha/recaptcha.component.mjs +0 -55
- package/esm2022/lib/ipa-form/text-input/text-input.component.mjs +0 -93
- package/esm2022/lib/ipa-form/textarea-input/textarea-input.component.mjs +0 -76
- package/esm2022/lib/models/apiException.mjs +0 -2
- package/esm2022/lib/models/apiResponse.mjs +0 -2
- package/esm2022/lib/models/breadcrumbs.model.mjs +0 -2
- package/esm2022/lib/models/decodedToken.model.mjs +0 -2
- package/esm2022/lib/models/exceptionUrl.model.mjs +0 -2
- package/esm2022/lib/models/generateForm.model.mjs +0 -2
- package/esm2022/lib/models/pagedResult.mjs +0 -2
- package/esm2022/lib/models/user.model.mjs +0 -2
- package/esm2022/lib/ng-ipa-library.module.mjs +0 -107
- package/esm2022/lib/pipes/hijri-date.pipe.mjs +0 -18
- package/esm2022/lib/pipes/pipes.module.mjs +0 -16
- package/esm2022/lib/services/breadcrumbs.service.mjs +0 -149
- package/esm2022/lib/services/common.service.mjs +0 -74
- package/esm2022/lib/share-button/share-button.component.mjs +0 -35
- package/esm2022/lib/share-button/share-button.module.mjs +0 -50
- package/esm2022/ng-ipa-library.mjs +0 -5
- package/esm2022/public-api.mjs +0 -43
|
@@ -1,84 +0,0 @@
|
|
|
1
|
-
import { Component, Input, Self, ViewChild, } from '@angular/core';
|
|
2
|
-
import { UntypedFormControl } from '@angular/forms';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "../ipa-form.service";
|
|
5
|
-
import * as i2 from "@angular/forms";
|
|
6
|
-
import * as i3 from "@angular/common";
|
|
7
|
-
import * as i4 from "@angular/cdk/bidi";
|
|
8
|
-
import * as i5 from "@ng-select/ng-select";
|
|
9
|
-
export class DropdownInputComponent {
|
|
10
|
-
constructor(validationService, controlDir) {
|
|
11
|
-
this.validationService = validationService;
|
|
12
|
-
this.controlDir = controlDir;
|
|
13
|
-
this.label = 'text input';
|
|
14
|
-
this.items = [];
|
|
15
|
-
this.required = false;
|
|
16
|
-
this.searchable = false;
|
|
17
|
-
this.notFoundText = 'لا يوجد بيانات';
|
|
18
|
-
this.isArabicForm = true;
|
|
19
|
-
this.fromGenerateForm = false;
|
|
20
|
-
this.formControl = new UntypedFormControl('');
|
|
21
|
-
this.controlDir.valueAccessor = this;
|
|
22
|
-
}
|
|
23
|
-
ngOnInit() {
|
|
24
|
-
const control = this.controlDir.control;
|
|
25
|
-
const validators = control?.validator ? [control.validator] : [];
|
|
26
|
-
control?.setValidators(validators);
|
|
27
|
-
control?.updateValueAndValidity();
|
|
28
|
-
this.formControl = control;
|
|
29
|
-
}
|
|
30
|
-
onChange(event) { }
|
|
31
|
-
onTouched() { }
|
|
32
|
-
writeValue(obj) {
|
|
33
|
-
if (this.input)
|
|
34
|
-
this.input.value = obj || '';
|
|
35
|
-
}
|
|
36
|
-
registerOnChange(fn) {
|
|
37
|
-
this.onChange = fn;
|
|
38
|
-
}
|
|
39
|
-
registerOnTouched(fn) {
|
|
40
|
-
this.onTouched = fn;
|
|
41
|
-
}
|
|
42
|
-
get errorMessage() {
|
|
43
|
-
this.errorMsg = this.validationService.getErrorMessage(this.formControl, '', this.isArabicForm);
|
|
44
|
-
return this.errorMsg;
|
|
45
|
-
}
|
|
46
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: DropdownInputComponent, deps: [{ token: i1.IPAFormService }, { token: i2.NgControl, self: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
47
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.0", type: DropdownInputComponent, selector: "ipa-dropdown-input", inputs: { id: "id", label: "label", items: "items", textField: "textField", valueField: "valueField", required: "required", firstItemLabel: "firstItemLabel", searchable: "searchable", notFoundText: "notFoundText", classes: "classes", containerClasses: "containerClasses", isArabicForm: "isArabicForm", fromGenerateForm: "fromGenerateForm" }, viewQueries: [{ propertyName: "input", first: true, predicate: ["select"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"form-floating {{containerClasses}}\">\r\n <!-- searchable is false -->\r\n <ng-container *ngIf=\"!searchable\">\r\n <select #select id=\"{{id}}\" class=\"form-select {{classes}}\" [required]=\"required\" [formControl]=\"formControl\"\r\n [ngClass]=\"{'is-invalid is-invalid:focus': (controlDir.control?.invalid && (controlDir.control?.dirty || controlDir.control?.touched)) && errorMsg,'is-valid is-valid:focus': \r\n (controlDir.control?.valid && (controlDir.control?.dirty || controlDir.control?.touched) && (errorMsg || controlDir.value))}\">\r\n <option *ngIf=\"firstItemLabel\" value=\"\">{{firstItemLabel}}</option>\r\n <option *ngFor=\"let item of items\"\r\n [value]=\"valueField ? fromGenerateForm ? item[textField] : item[valueField] : item\">\r\n {{textField ? item[textField] : item}}\r\n </option>\r\n </select>\r\n <label for=\"{{id}}\"><span *ngIf=\"required\" class=\"text-danger\">*</span> {{label}}</label>\r\n </ng-container>\r\n\r\n <!-- searchable is true -->\r\n <ng-select *ngIf=\"searchable\" #select dir=\"rtl\" class=\"{{classes}}\" [formControl]=\"formControl\" [items]=\"items\"\r\n [placeholder]=\"label\" [notFoundText]=\"notFoundText\" [required]=\"required\"\r\n [bindValue]=\"fromGenerateForm? textField : valueField\" [bindLabel]=\"textField\"\r\n [ngClass]=\"{'is-invalid is-invalid:focus': (controlDir.control?.invalid && (controlDir.control?.dirty || controlDir.control?.touched)) && errorMsg,'is-valid is-valid:focus': \r\n (controlDir.control?.valid && (controlDir.control?.dirty || controlDir.control?.touched) && (errorMsg || controlDir.value))}\">\r\n </ng-select>\r\n <div class=\"invalid-feedback\" *ngIf=\"errorMessage !== null\">\r\n {{errorMsg}}\r\n </div>\r\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }, { kind: "component", type: i5.NgSelectComponent, selector: "ng-select", inputs: ["bindLabel", "bindValue", "markFirst", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "appearance", "dropdownPosition", "appendTo", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "openOnEnter", "maxSelectedItems", "groupBy", "groupValue", "bufferAmount", "virtualScroll", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "tabIndex", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "ngClass", "typeahead", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "deselectOnClick"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }] }); }
|
|
48
|
-
}
|
|
49
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: DropdownInputComponent, decorators: [{
|
|
50
|
-
type: Component,
|
|
51
|
-
args: [{ selector: 'ipa-dropdown-input', template: "<div class=\"form-floating {{containerClasses}}\">\r\n <!-- searchable is false -->\r\n <ng-container *ngIf=\"!searchable\">\r\n <select #select id=\"{{id}}\" class=\"form-select {{classes}}\" [required]=\"required\" [formControl]=\"formControl\"\r\n [ngClass]=\"{'is-invalid is-invalid:focus': (controlDir.control?.invalid && (controlDir.control?.dirty || controlDir.control?.touched)) && errorMsg,'is-valid is-valid:focus': \r\n (controlDir.control?.valid && (controlDir.control?.dirty || controlDir.control?.touched) && (errorMsg || controlDir.value))}\">\r\n <option *ngIf=\"firstItemLabel\" value=\"\">{{firstItemLabel}}</option>\r\n <option *ngFor=\"let item of items\"\r\n [value]=\"valueField ? fromGenerateForm ? item[textField] : item[valueField] : item\">\r\n {{textField ? item[textField] : item}}\r\n </option>\r\n </select>\r\n <label for=\"{{id}}\"><span *ngIf=\"required\" class=\"text-danger\">*</span> {{label}}</label>\r\n </ng-container>\r\n\r\n <!-- searchable is true -->\r\n <ng-select *ngIf=\"searchable\" #select dir=\"rtl\" class=\"{{classes}}\" [formControl]=\"formControl\" [items]=\"items\"\r\n [placeholder]=\"label\" [notFoundText]=\"notFoundText\" [required]=\"required\"\r\n [bindValue]=\"fromGenerateForm? textField : valueField\" [bindLabel]=\"textField\"\r\n [ngClass]=\"{'is-invalid is-invalid:focus': (controlDir.control?.invalid && (controlDir.control?.dirty || controlDir.control?.touched)) && errorMsg,'is-valid is-valid:focus': \r\n (controlDir.control?.valid && (controlDir.control?.dirty || controlDir.control?.touched) && (errorMsg || controlDir.value))}\">\r\n </ng-select>\r\n <div class=\"invalid-feedback\" *ngIf=\"errorMessage !== null\">\r\n {{errorMsg}}\r\n </div>\r\n</div>" }]
|
|
52
|
-
}], ctorParameters: () => [{ type: i1.IPAFormService }, { type: i2.NgControl, decorators: [{
|
|
53
|
-
type: Self
|
|
54
|
-
}] }], propDecorators: { input: [{
|
|
55
|
-
type: ViewChild,
|
|
56
|
-
args: ['select', { static: true }]
|
|
57
|
-
}], id: [{
|
|
58
|
-
type: Input
|
|
59
|
-
}], label: [{
|
|
60
|
-
type: Input
|
|
61
|
-
}], items: [{
|
|
62
|
-
type: Input
|
|
63
|
-
}], textField: [{
|
|
64
|
-
type: Input
|
|
65
|
-
}], valueField: [{
|
|
66
|
-
type: Input
|
|
67
|
-
}], required: [{
|
|
68
|
-
type: Input
|
|
69
|
-
}], firstItemLabel: [{
|
|
70
|
-
type: Input
|
|
71
|
-
}], searchable: [{
|
|
72
|
-
type: Input
|
|
73
|
-
}], notFoundText: [{
|
|
74
|
-
type: Input
|
|
75
|
-
}], classes: [{
|
|
76
|
-
type: Input
|
|
77
|
-
}], containerClasses: [{
|
|
78
|
-
type: Input
|
|
79
|
-
}], isArabicForm: [{
|
|
80
|
-
type: Input
|
|
81
|
-
}], fromGenerateForm: [{
|
|
82
|
-
type: Input
|
|
83
|
-
}] } });
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-input.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-ipa-library/src/lib/ipa-form/dropdown-input/dropdown-input.component.ts","../../../../../../projects/ng-ipa-library/src/lib/ipa-form/dropdown-input/dropdown-input.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAET,KAAK,EAEL,IAAI,EACJ,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,kBAAkB,EAAa,MAAM,gBAAgB,CAAC;;;;;;;AAQ/D,MAAM,OAAO,sBAAsB;IAkBjC,YACU,iBAAiC,EAC1B,UAAqB;QAD5B,sBAAiB,GAAjB,iBAAiB,CAAgB;QAC1B,eAAU,GAAV,UAAU,CAAW;QAjB7B,UAAK,GAAW,YAAY,CAAC;QAC7B,UAAK,GAAU,EAAE,CAAC;QAGlB,aAAQ,GAAG,KAAK,CAAC;QAEjB,eAAU,GAAG,KAAK,CAAC;QACnB,iBAAY,GAAG,gBAAgB,CAAC;QAGhC,iBAAY,GAAG,IAAI,CAAC;QACpB,qBAAgB,GAAG,KAAK,CAAC;QAClC,gBAAW,GAAuB,IAAI,kBAAkB,CAAC,EAAE,CAAC,CAAC;QAO3D,IAAI,CAAC,UAAU,CAAC,aAAa,GAAG,IAAI,CAAC;IACvC,CAAC;IAED,QAAQ;QACN,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC;QACxC,MAAM,UAAU,GAAG,OAAO,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAEjE,OAAO,EAAE,aAAa,CAAC,UAAU,CAAC,CAAC;QACnC,OAAO,EAAE,sBAAsB,EAAE,CAAC;QAClC,IAAI,CAAC,WAAW,GAAG,OAA6B,CAAC;IACnD,CAAC;IAED,QAAQ,CAAC,KAAU,IAAS,CAAC;IAE7B,SAAS,KAAU,CAAC;IACpB,UAAU,CAAC,GAAQ;QACjB,IAAI,IAAI,CAAC,KAAK;YAAE,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,IAAI,EAAE,CAAC;IAC/C,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,IAAI,YAAY;QACd,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,eAAe,CACpD,IAAI,CAAC,WAAW,EAChB,EAAE,EACF,IAAI,CAAC,YAAY,CAClB,CAAC;QACF,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;8GAxDU,sBAAsB;kGAAtB,sBAAsB,+fChBnC,+1DAyBM;;2FDTO,sBAAsB;kBALlC,SAAS;+BACE,oBAAoB;;0BAwB3B,IAAI;yCAnBgC,KAAK;sBAA3C,SAAS;uBAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAC5B,EAAE;sBAAV,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  Input,\r\n  OnInit,\r\n  Self,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { UntypedFormControl, NgControl } from '@angular/forms';\r\nimport { IPAFormService } from '../ipa-form.service';\r\n\r\n@Component({\r\n  selector: 'ipa-dropdown-input',\r\n  templateUrl: './dropdown-input.component.html',\r\n  styleUrls: ['./dropdown-input.component.scss'],\r\n})\r\nexport class DropdownInputComponent implements OnInit {\r\n  @ViewChild('select', { static: true }) input!: HTMLSelectElement;\r\n  @Input() id!: string;\r\n  @Input() label: string = 'text input';\r\n  @Input() items: any[] = [];\r\n  @Input() textField!: string;\r\n  @Input() valueField!: string;\r\n  @Input() required = false;\r\n  @Input() firstItemLabel!: string;\r\n  @Input() searchable = false;\r\n  @Input() notFoundText = 'لا يوجد بيانات';\r\n  @Input() classes!: string;\r\n  @Input() containerClasses!: string;\r\n  @Input() isArabicForm = true;\r\n  @Input() fromGenerateForm = false;\r\n  formControl: UntypedFormControl = new UntypedFormControl('');\r\n  errorMsg!: string | null;\r\n\r\n  constructor(\r\n    private validationService: IPAFormService,\r\n    @Self() public controlDir: NgControl\r\n  ) {\r\n    this.controlDir.valueAccessor = this;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    const control = this.controlDir.control;\r\n    const validators = control?.validator ? [control.validator] : [];\r\n\r\n    control?.setValidators(validators);\r\n    control?.updateValueAndValidity();\r\n    this.formControl = control as UntypedFormControl;\r\n  }\r\n\r\n  onChange(event: any): void {}\r\n\r\n  onTouched(): void {}\r\n  writeValue(obj: any): void {\r\n    if (this.input) this.input.value = obj || '';\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  get errorMessage(): string | null {\r\n    this.errorMsg = this.validationService.getErrorMessage(\r\n      this.formControl,\r\n      '',\r\n      this.isArabicForm\r\n    );\r\n    return this.errorMsg;\r\n  }\r\n}\r\n","<div class=\"form-floating {{containerClasses}}\">\r\n  <!-- searchable is false -->\r\n  <ng-container *ngIf=\"!searchable\">\r\n    <select #select id=\"{{id}}\" class=\"form-select {{classes}}\" [required]=\"required\" [formControl]=\"formControl\"\r\n      [ngClass]=\"{'is-invalid is-invalid:focus': (controlDir.control?.invalid && (controlDir.control?.dirty || controlDir.control?.touched)) && errorMsg,'is-valid is-valid:focus': \r\n                                                 (controlDir.control?.valid && (controlDir.control?.dirty || controlDir.control?.touched)  && (errorMsg || controlDir.value))}\">\r\n      <option *ngIf=\"firstItemLabel\" value=\"\">{{firstItemLabel}}</option>\r\n      <option *ngFor=\"let item of items\"\r\n        [value]=\"valueField ? fromGenerateForm ? item[textField] : item[valueField] : item\">\r\n        {{textField ? item[textField] : item}}\r\n      </option>\r\n    </select>\r\n    <label for=\"{{id}}\"><span *ngIf=\"required\" class=\"text-danger\">*</span> {{label}}</label>\r\n  </ng-container>\r\n\r\n  <!-- searchable is true -->\r\n  <ng-select *ngIf=\"searchable\" #select dir=\"rtl\" class=\"{{classes}}\" [formControl]=\"formControl\" [items]=\"items\"\r\n    [placeholder]=\"label\" [notFoundText]=\"notFoundText\" [required]=\"required\"\r\n    [bindValue]=\"fromGenerateForm? textField : valueField\" [bindLabel]=\"textField\"\r\n    [ngClass]=\"{'is-invalid is-invalid:focus': (controlDir.control?.invalid && (controlDir.control?.dirty || controlDir.control?.touched)) && errorMsg,'is-valid is-valid:focus': \r\n                                               (controlDir.control?.valid && (controlDir.control?.dirty || controlDir.control?.touched)  && (errorMsg || controlDir.value))}\">\r\n  </ng-select>\r\n  <div class=\"invalid-feedback\" *ngIf=\"errorMessage !== null\">\r\n    {{errorMsg}}\r\n  </div>\r\n</div>"]}
|
|
@@ -1,142 +0,0 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
|
-
import { DropzoneDirective, } from 'ngx-dropzone-wrapper';
|
|
3
|
-
import { UntypedFormControl } from '@angular/forms';
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "ngx-toastr";
|
|
6
|
-
import * as i2 from "@angular/common";
|
|
7
|
-
import * as i3 from "ngx-dropzone-wrapper";
|
|
8
|
-
export class FileUploadComponent {
|
|
9
|
-
constructor(
|
|
10
|
-
// private authService: AuthService,
|
|
11
|
-
toastrService) {
|
|
12
|
-
this.toastrService = toastrService;
|
|
13
|
-
this.isArabicForm = true;
|
|
14
|
-
this.label = '';
|
|
15
|
-
this.required = false;
|
|
16
|
-
this.acceptedFiles = '';
|
|
17
|
-
this.multiple = 1; // set maxFiles (NOT uploadMultiple)in the config object,
|
|
18
|
-
this.maxFileSize = 2;
|
|
19
|
-
this.method = 'POST';
|
|
20
|
-
this.autoUpload = false;
|
|
21
|
-
this.apiUrl = 'apiUrl';
|
|
22
|
-
this.successUpload = new EventEmitter();
|
|
23
|
-
this.fileAdded = new EventEmitter();
|
|
24
|
-
this.fileDeleted = new EventEmitter();
|
|
25
|
-
this.dragEnter = false;
|
|
26
|
-
this.errors = [];
|
|
27
|
-
this.filesAdded = [];
|
|
28
|
-
this.currentFiles = [];
|
|
29
|
-
this.formControl = new UntypedFormControl('');
|
|
30
|
-
}
|
|
31
|
-
ngOnInit() {
|
|
32
|
-
this.setConfiguration();
|
|
33
|
-
}
|
|
34
|
-
operationCompleted(e) {
|
|
35
|
-
if (this.filesAdded.length > 0) {
|
|
36
|
-
this.successUpload.emit(this.filesAdded);
|
|
37
|
-
this.filesAdded = [];
|
|
38
|
-
}
|
|
39
|
-
this.dropzoneDir.reset();
|
|
40
|
-
}
|
|
41
|
-
onUploadSuccess(e) {
|
|
42
|
-
const file = e[0];
|
|
43
|
-
if (file.status === 'success') {
|
|
44
|
-
this.filesAdded.push(file);
|
|
45
|
-
}
|
|
46
|
-
const message = this.isArabicForm
|
|
47
|
-
? 'تم تحميل المرفقات بنجاح'
|
|
48
|
-
: 'Attachments uploaded successfully';
|
|
49
|
-
this.toastrService.success(message);
|
|
50
|
-
}
|
|
51
|
-
onUploadError(e) {
|
|
52
|
-
if (e[1]) {
|
|
53
|
-
this.errors = [];
|
|
54
|
-
this.errors.push(`${e[1]} (${e[0].name})`);
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
fileWasAdded(e) {
|
|
58
|
-
const myDropzone = this.dropzoneDir.dropzone();
|
|
59
|
-
if (this.multiple === 1) {
|
|
60
|
-
this.currentFiles = [];
|
|
61
|
-
this.filesAdded = [];
|
|
62
|
-
this.errors = [];
|
|
63
|
-
const files = myDropzone.files;
|
|
64
|
-
if (files.length > 1) {
|
|
65
|
-
myDropzone.removeFile(files[0]);
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
this.currentFiles.push(e);
|
|
69
|
-
this.fileAdded.emit(e);
|
|
70
|
-
}
|
|
71
|
-
sending(e) {
|
|
72
|
-
this.errors = [];
|
|
73
|
-
}
|
|
74
|
-
reset(e) { }
|
|
75
|
-
deleteFile(file) {
|
|
76
|
-
this.currentFiles = this.currentFiles.filter((x) => x.name !== file.name && x.size !== file.size);
|
|
77
|
-
this.errors = [];
|
|
78
|
-
this.fileDeleted.emit();
|
|
79
|
-
}
|
|
80
|
-
setConfiguration() {
|
|
81
|
-
this.label = (this.isArabicForm ? 'رفع ' : 'Upload ') + this.label;
|
|
82
|
-
this.config = {
|
|
83
|
-
url: this.apiUrl,
|
|
84
|
-
method: this.method,
|
|
85
|
-
headers: {
|
|
86
|
-
Authorization: 'Bearer ' + this.authorization,
|
|
87
|
-
},
|
|
88
|
-
maxFilesize: this.maxFileSize,
|
|
89
|
-
maxFiles: this.multiple,
|
|
90
|
-
uploadMultiple: this.multiple > 1,
|
|
91
|
-
dictInvalidFileType: this.isArabicForm
|
|
92
|
-
? 'صيغة الملف غير مسموح بها'
|
|
93
|
-
: 'the file format is not allowed',
|
|
94
|
-
dictFileTooBig: this.isArabicForm
|
|
95
|
-
? 'الحجم تجاوز الحد المسموح'
|
|
96
|
-
: `the file size must be less than or equal (${this.maxFileSize}) MB`,
|
|
97
|
-
dictMaxFilesExceeded: this.isArabicForm
|
|
98
|
-
? 'الرجاء حذف الملفات الموجودة حاليا لتتمكن من رفع هذا الملف'
|
|
99
|
-
: 'Please delete existing files to be able to upload this file',
|
|
100
|
-
acceptedFiles: this.acceptedFiles,
|
|
101
|
-
autoProcessQueue: this.autoUpload,
|
|
102
|
-
previewTemplate: '<span></span>',
|
|
103
|
-
dictRemoveFile: '',
|
|
104
|
-
};
|
|
105
|
-
}
|
|
106
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: FileUploadComponent, deps: [{ token: i1.ToastrService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
107
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.0", type: FileUploadComponent, selector: "ipa-file-upload", inputs: { isArabicForm: "isArabicForm", label: "label", required: "required", acceptedFiles: "acceptedFiles", multiple: "multiple", maxFileSize: "maxFileSize", method: "method", autoUpload: "autoUpload", apiUrl: "apiUrl", authorization: "authorization" }, outputs: { successUpload: "successUpload", fileAdded: "fileAdded", fileDeleted: "fileDeleted" }, viewQueries: [{ propertyName: "dropzoneDir", first: true, predicate: DropzoneDirective, descendants: true }], ngImport: i0, template: "<div class=\"file-upload\">\r\n <div class=\"upload-overlay\" [dropzone]=\"config\" (error)=\"onUploadError($event)\"\r\n (queueComplete)=\"operationCompleted($event)\" (success)=\"onUploadSuccess($event)\" (dragenter)=\"dragEnter = true\"\r\n (dragLeave)=\"dragEnter = false\" (drop)=\"dragEnter = false\" (dragEnd)=\"dragEnter = false\"\r\n [class.active-border]=\"dragEnter\" (sending)=\"sending($event)\" (reset)=\"reset($event)\"\r\n (addedFile)=\"fileWasAdded($event)\">\r\n </div>\r\n <div class=\"upload-btn-wrapper\">\r\n <div>\r\n <div class=\"subtitle mb-2\">\r\n {{label}}\r\n <span *ngIf=\"required\" class=\"text-danger\">*</span>\r\n </div>\r\n <hr>\r\n <span style=\"font-size: 12px;\">{{isArabicForm? '\u0642\u0645 \u0628\u0633\u062D\u0628 \u0627\u0644\u0645\u0644\u0641 \u0623\u0648 \u0627\u0636\u063A\u0637 \u0647\u0646\u0627' : 'drag or click here'}}</span>\r\n <i class=\"fas fa-upload upload-icon mr-2\"></i>\r\n </div>\r\n <div *ngIf=\"acceptedFiles.length > 0\" class=\"allowed-extensions\">\r\n {{isArabicForm? '\u0627\u0644\u0635\u064A\u063A\u0629 \u0627\u0644\u0645\u0633\u0645\u0648\u062D \u0628\u0647\u0627:' : 'Allowed format:'}} \r\n <span class=\"extensions\">{{ acceptedFiles }}</span>\r\n </div>\r\n <div class=\"allowed-extensions\">\r\n {{isArabicForm? '\u0627\u0642\u0635\u0649 \u062D\u062C\u0645 \u0644\u0644\u0645\u0631\u0641\u0642:' : 'Attachment Size:'}}\r\n <span class=\"extensions\">{{ maxFileSize }} MB</span>\r\n </div>\r\n </div>\r\n</div>\r\n<div id=\"attachment-status\" style=\"text-align: center; margin-top:10px;\">\r\n <span style=\"font-size: 14px; margin: auto; font-weight:bold;\" *ngFor=\"let file of currentFiles\">\r\n {{ file.name }} <i (click)=\"deleteFile(file)\" class=\"fas fa-trash\"\r\n style=\"color:firebrick; cursor: pointer;\"></i>\r\n <br>\r\n </span>\r\n <ul class=\"list-unstyled\">\r\n <li class=\"text-danger\" style=\"font-size: 12px;\" *ngFor=\"let error of errors\">{{error}}</li>\r\n </ul>\r\n</div>", styles: [".subtitle{border-bottom:none;display:block;line-height:2}.file-upload{border:dashed 1px #ccc;display:block;min-height:150px;border-radius:15px;width:350px;cursor:pointer;position:relative;margin:auto}.upload-overlay{position:absolute;width:100%;height:100%}.upload-btn-wrapper{text-align:center}.upload-icon{margin-right:5px}.list-unstyled{margin:10px!important;padding:14px!important;list-style:none}.allowed-extensions{color:#4d7297}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DropzoneDirective, selector: "[dropzone]", inputs: ["disabled", "dropzone"], outputs: ["init", "error", "success", "sending", "canceled", "complete", "processing", "drop", "dragStart", "dragEnd", "dragEnter", "dragOver", "dragLeave", "thumbnail", "addedFile", "addedFiles", "removedFile", "uploadProgress", "maxFilesReached", "maxFilesExceeded", "errorMultiple", "successMultiple", "sendingMultiple", "canceledMultiple", "completeMultiple", "processingMultiple", "reset", "queueComplete", "totalUploadProgress"], exportAs: ["ngxDropzone"] }] }); }
|
|
108
|
-
}
|
|
109
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: FileUploadComponent, decorators: [{
|
|
110
|
-
type: Component,
|
|
111
|
-
args: [{ selector: 'ipa-file-upload', template: "<div class=\"file-upload\">\r\n <div class=\"upload-overlay\" [dropzone]=\"config\" (error)=\"onUploadError($event)\"\r\n (queueComplete)=\"operationCompleted($event)\" (success)=\"onUploadSuccess($event)\" (dragenter)=\"dragEnter = true\"\r\n (dragLeave)=\"dragEnter = false\" (drop)=\"dragEnter = false\" (dragEnd)=\"dragEnter = false\"\r\n [class.active-border]=\"dragEnter\" (sending)=\"sending($event)\" (reset)=\"reset($event)\"\r\n (addedFile)=\"fileWasAdded($event)\">\r\n </div>\r\n <div class=\"upload-btn-wrapper\">\r\n <div>\r\n <div class=\"subtitle mb-2\">\r\n {{label}}\r\n <span *ngIf=\"required\" class=\"text-danger\">*</span>\r\n </div>\r\n <hr>\r\n <span style=\"font-size: 12px;\">{{isArabicForm? '\u0642\u0645 \u0628\u0633\u062D\u0628 \u0627\u0644\u0645\u0644\u0641 \u0623\u0648 \u0627\u0636\u063A\u0637 \u0647\u0646\u0627' : 'drag or click here'}}</span>\r\n <i class=\"fas fa-upload upload-icon mr-2\"></i>\r\n </div>\r\n <div *ngIf=\"acceptedFiles.length > 0\" class=\"allowed-extensions\">\r\n {{isArabicForm? '\u0627\u0644\u0635\u064A\u063A\u0629 \u0627\u0644\u0645\u0633\u0645\u0648\u062D \u0628\u0647\u0627:' : 'Allowed format:'}} \r\n <span class=\"extensions\">{{ acceptedFiles }}</span>\r\n </div>\r\n <div class=\"allowed-extensions\">\r\n {{isArabicForm? '\u0627\u0642\u0635\u0649 \u062D\u062C\u0645 \u0644\u0644\u0645\u0631\u0641\u0642:' : 'Attachment Size:'}}\r\n <span class=\"extensions\">{{ maxFileSize }} MB</span>\r\n </div>\r\n </div>\r\n</div>\r\n<div id=\"attachment-status\" style=\"text-align: center; margin-top:10px;\">\r\n <span style=\"font-size: 14px; margin: auto; font-weight:bold;\" *ngFor=\"let file of currentFiles\">\r\n {{ file.name }} <i (click)=\"deleteFile(file)\" class=\"fas fa-trash\"\r\n style=\"color:firebrick; cursor: pointer;\"></i>\r\n <br>\r\n </span>\r\n <ul class=\"list-unstyled\">\r\n <li class=\"text-danger\" style=\"font-size: 12px;\" *ngFor=\"let error of errors\">{{error}}</li>\r\n </ul>\r\n</div>", styles: [".subtitle{border-bottom:none;display:block;line-height:2}.file-upload{border:dashed 1px #ccc;display:block;min-height:150px;border-radius:15px;width:350px;cursor:pointer;position:relative;margin:auto}.upload-overlay{position:absolute;width:100%;height:100%}.upload-btn-wrapper{text-align:center}.upload-icon{margin-right:5px}.list-unstyled{margin:10px!important;padding:14px!important;list-style:none}.allowed-extensions{color:#4d7297}\n"] }]
|
|
112
|
-
}], ctorParameters: () => [{ type: i1.ToastrService }], propDecorators: { dropzoneDir: [{
|
|
113
|
-
type: ViewChild,
|
|
114
|
-
args: [DropzoneDirective, { static: false }]
|
|
115
|
-
}], isArabicForm: [{
|
|
116
|
-
type: Input
|
|
117
|
-
}], label: [{
|
|
118
|
-
type: Input
|
|
119
|
-
}], required: [{
|
|
120
|
-
type: Input
|
|
121
|
-
}], acceptedFiles: [{
|
|
122
|
-
type: Input
|
|
123
|
-
}], multiple: [{
|
|
124
|
-
type: Input
|
|
125
|
-
}], maxFileSize: [{
|
|
126
|
-
type: Input
|
|
127
|
-
}], method: [{
|
|
128
|
-
type: Input
|
|
129
|
-
}], autoUpload: [{
|
|
130
|
-
type: Input
|
|
131
|
-
}], apiUrl: [{
|
|
132
|
-
type: Input
|
|
133
|
-
}], authorization: [{
|
|
134
|
-
type: Input
|
|
135
|
-
}], successUpload: [{
|
|
136
|
-
type: Output
|
|
137
|
-
}], fileAdded: [{
|
|
138
|
-
type: Output
|
|
139
|
-
}], fileDeleted: [{
|
|
140
|
-
type: Output
|
|
141
|
-
}] } });
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-upload.component.js","sourceRoot":"","sources":["../../../../../../projects/ng-ipa-library/src/lib/ipa-form/file-upload/file-upload.component.ts","../../../../../../projects/ng-ipa-library/src/lib/ipa-form/file-upload/file-upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { ToastrService } from 'ngx-toastr';\r\nimport {\r\n  DropzoneConfigInterface,\r\n  DropzoneDirective,\r\n} from 'ngx-dropzone-wrapper';\r\nimport { UntypedFormControl } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'ipa-file-upload',\r\n  templateUrl: './file-upload.component.html',\r\n  styleUrls: ['./file-upload.component.scss'],\r\n})\r\nexport class FileUploadComponent implements OnInit {\r\n  @ViewChild(DropzoneDirective, { static: false })\r\n  dropzoneDir!: DropzoneDirective;\r\n  @Input() isArabicForm = true;\r\n  @Input() label = '';\r\n  @Input() required = false;\r\n  @Input() acceptedFiles = '';\r\n  @Input() multiple = 1; // set maxFiles (NOT uploadMultiple)in the config object,\r\n  @Input() maxFileSize = 2;\r\n  @Input() method = 'POST';\r\n  @Input() autoUpload = false;\r\n  @Input() apiUrl = 'apiUrl';\r\n  @Input() authorization!: string;\r\n  @Output() successUpload = new EventEmitter();\r\n  @Output() fileAdded = new EventEmitter();\r\n  @Output() fileDeleted = new EventEmitter();\r\n  dragEnter = false;\r\n  errors: string[] = [];\r\n  config!: DropzoneConfigInterface;\r\n  filesAdded: File[] = [];\r\n  currentFiles: File[] = [];\r\n  formControl: UntypedFormControl = new UntypedFormControl('');\r\n\r\n  constructor(\r\n    // private authService: AuthService,\r\n    private toastrService: ToastrService\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.setConfiguration();\r\n  }\r\n\r\n  operationCompleted(e: any): void {\r\n    if (this.filesAdded.length > 0) {\r\n      this.successUpload.emit(this.filesAdded);\r\n      this.filesAdded = [];\r\n    }\r\n    this.dropzoneDir.reset();\r\n  }\r\n\r\n  onUploadSuccess(e: any): void {\r\n    const file = e[0];\r\n    if (file.status === 'success') {\r\n      this.filesAdded.push(file);\r\n    }\r\n    const message = this.isArabicForm\r\n      ? 'تم تحميل المرفقات بنجاح'\r\n      : 'Attachments uploaded successfully';\r\n    this.toastrService.success(message);\r\n  }\r\n\r\n  onUploadError(e: any): void {\r\n    if (e[1]) {\r\n      this.errors = [];\r\n      this.errors.push(`${e[1]} (${e[0].name})`);\r\n    }\r\n  }\r\n\r\n  fileWasAdded(e: File): void {\r\n    const myDropzone = this.dropzoneDir.dropzone();\r\n    if (this.multiple === 1) {\r\n      this.currentFiles = [];\r\n      this.filesAdded = [];\r\n      this.errors = [];\r\n      const files = myDropzone.files;\r\n      if (files.length > 1) {\r\n        myDropzone.removeFile(files[0]);\r\n      }\r\n    }\r\n    this.currentFiles.push(e);\r\n    this.fileAdded.emit(e);\r\n  }\r\n\r\n  sending(e: any): void {\r\n    this.errors = [];\r\n  }\r\n\r\n  reset(e: any): void {}\r\n\r\n  deleteFile(file: any): void {\r\n    this.currentFiles = this.currentFiles.filter(\r\n      (x) => x.name !== file.name && x.size !== file.size\r\n    );\r\n    this.errors = [];\r\n    this.fileDeleted.emit();\r\n  }\r\n\r\n  private setConfiguration() {\r\n    this.label = (this.isArabicForm ? 'رفع ' : 'Upload ') + this.label;\r\n    this.config = {\r\n      url: this.apiUrl,\r\n      method: this.method,\r\n      headers: {\r\n        Authorization: 'Bearer ' + this.authorization,\r\n      },\r\n      maxFilesize: this.maxFileSize,\r\n      maxFiles: this.multiple,\r\n      uploadMultiple: this.multiple > 1,\r\n      dictInvalidFileType: this.isArabicForm\r\n        ? 'صيغة الملف غير مسموح بها'\r\n        : 'the file format is not allowed',\r\n      dictFileTooBig: this.isArabicForm\r\n        ? 'الحجم تجاوز الحد المسموح'\r\n        : `the file size must be less than or equal (${this.maxFileSize}) MB`,\r\n      dictMaxFilesExceeded: this.isArabicForm\r\n        ? 'الرجاء حذف الملفات الموجودة حاليا لتتمكن من رفع هذا الملف'\r\n        : 'Please delete existing files to be able to upload this file',\r\n      acceptedFiles: this.acceptedFiles,\r\n      autoProcessQueue: this.autoUpload,\r\n      previewTemplate: '<span></span>',\r\n      dictRemoveFile: '',\r\n    };\r\n  }\r\n}\r\n","<div class=\"file-upload\">\r\n    <div class=\"upload-overlay\" [dropzone]=\"config\" (error)=\"onUploadError($event)\"\r\n        (queueComplete)=\"operationCompleted($event)\" (success)=\"onUploadSuccess($event)\" (dragenter)=\"dragEnter = true\"\r\n        (dragLeave)=\"dragEnter = false\" (drop)=\"dragEnter = false\" (dragEnd)=\"dragEnter = false\"\r\n        [class.active-border]=\"dragEnter\" (sending)=\"sending($event)\" (reset)=\"reset($event)\"\r\n        (addedFile)=\"fileWasAdded($event)\">\r\n    </div>\r\n    <div class=\"upload-btn-wrapper\">\r\n        <div>\r\n            <div class=\"subtitle mb-2\">\r\n                {{label}}\r\n                <span *ngIf=\"required\" class=\"text-danger\">*</span>\r\n            </div>\r\n            <hr>\r\n            <span style=\"font-size: 12px;\">{{isArabicForm? 'قم بسحب الملف أو اضغط هنا' : 'drag or click here'}}</span>\r\n            <i class=\"fas fa-upload upload-icon mr-2\"></i>\r\n        </div>\r\n        <div *ngIf=\"acceptedFiles.length > 0\" class=\"allowed-extensions\">\r\n           {{isArabicForm? 'الصيغة المسموح بها:' : 'Allowed format:'}} \r\n            <span class=\"extensions\">{{ acceptedFiles }}</span>\r\n        </div>\r\n        <div class=\"allowed-extensions\">\r\n            {{isArabicForm? 'اقصى حجم للمرفق:' : 'Attachment Size:'}}\r\n            <span class=\"extensions\">{{ maxFileSize }} MB</span>\r\n        </div>\r\n    </div>\r\n</div>\r\n<div id=\"attachment-status\" style=\"text-align: center; margin-top:10px;\">\r\n    <span style=\"font-size: 14px; margin: auto; font-weight:bold;\" *ngFor=\"let file of currentFiles\">\r\n        {{ file.name }} <i (click)=\"deleteFile(file)\" class=\"fas fa-trash\"\r\n            style=\"color:firebrick; cursor: pointer;\"></i>\r\n        <br>\r\n    </span>\r\n    <ul class=\"list-unstyled\">\r\n        <li class=\"text-danger\" style=\"font-size: 12px;\" *ngFor=\"let error of errors\">{{error}}</li>\r\n    </ul>\r\n</div>"]}
|
|
@@ -1,290 +0,0 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import momentHijri from 'moment-hijri';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@ng-bootstrap/ng-bootstrap";
|
|
5
|
-
export class IPAFormService {
|
|
6
|
-
constructor(parserFormatter) {
|
|
7
|
-
this.parserFormatter = parserFormatter;
|
|
8
|
-
}
|
|
9
|
-
/**
|
|
10
|
-
* check link is valid.
|
|
11
|
-
*/
|
|
12
|
-
static linkValidation(control) {
|
|
13
|
-
const isValidLink = /^((https?:\/\/)[\w-]+(\.[a-z-]+)+\.?(:\d+)?(\/\S*)?)$/.test(control.value);
|
|
14
|
-
return isValidLink || !control.value ? null : { link: true };
|
|
15
|
-
}
|
|
16
|
-
/**
|
|
17
|
-
* check mp4 link is valid.
|
|
18
|
-
*/
|
|
19
|
-
static mp4LinkValidation(control) {
|
|
20
|
-
const isValidLink = /^((https?:\/\/)[\w-]+(\.[a-z-]+)+\.?(:\d+)?(\/\S*)?(\/[\w\u0600-\u06FF]+\.mp4))$/.test(control.value);
|
|
21
|
-
return isValidLink || !control.value ? null : { linkMP4: true };
|
|
22
|
-
}
|
|
23
|
-
/**
|
|
24
|
-
* check mobile number is valid.
|
|
25
|
-
*/
|
|
26
|
-
static mobileNo(control) {
|
|
27
|
-
const isValidLink = /^05\d{8}$/.test(control.value);
|
|
28
|
-
return isValidLink || !control.value ? null : { mobileNo: true };
|
|
29
|
-
}
|
|
30
|
-
/**
|
|
31
|
-
* check email is valid.
|
|
32
|
-
*/
|
|
33
|
-
static email(control) {
|
|
34
|
-
const isValidLink = /^(([^<>()[\]\.,;:\s@\"]+(\.[^<>()[\]\.,;:\s@\"]+)*)|(\".+\"))@(([^<>()[\]\.,;:\s@\"]+\.)+[^<>()[\]\.,;:\s@\"]{2,})$/.test(control.value);
|
|
35
|
-
return isValidLink || !control.value ? null : { Email: true };
|
|
36
|
-
}
|
|
37
|
-
/**
|
|
38
|
-
* check national ID or iqama ID is valid.
|
|
39
|
-
*/
|
|
40
|
-
static checkID(control) {
|
|
41
|
-
let isValid = false;
|
|
42
|
-
const value = control.value;
|
|
43
|
-
if (IPAFormService.nationalIdValidate(value) ||
|
|
44
|
-
IPAFormService.iqamaIdValidate(value)) {
|
|
45
|
-
isValid = true;
|
|
46
|
-
}
|
|
47
|
-
else {
|
|
48
|
-
isValid = false;
|
|
49
|
-
}
|
|
50
|
-
return isValid || !value ? null : { checkId: true };
|
|
51
|
-
}
|
|
52
|
-
static validHijriDate(control) {
|
|
53
|
-
const date = control.value;
|
|
54
|
-
const isValid = IPAFormService.checkHijriDateValid(date);
|
|
55
|
-
return isValid || !date
|
|
56
|
-
? null
|
|
57
|
-
: {
|
|
58
|
-
ngbDate: {
|
|
59
|
-
invalid: date?.year +
|
|
60
|
-
'-' +
|
|
61
|
-
(date?.month > 10 ? date?.month : '0' + date?.month) +
|
|
62
|
-
'-' +
|
|
63
|
-
(date?.day > 10 ? date?.day : '0' + date?.day),
|
|
64
|
-
},
|
|
65
|
-
};
|
|
66
|
-
}
|
|
67
|
-
getErrorMessage(control, patternErrorMsg = '', isArabic) {
|
|
68
|
-
for (const propertyName in control?.errors) {
|
|
69
|
-
if (control?.errors.hasOwnProperty(propertyName) &&
|
|
70
|
-
(control.touched || control.dirty)) {
|
|
71
|
-
return this.getValidatorErrorMessage(propertyName, control.errors[propertyName], patternErrorMsg, isArabic);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
return null;
|
|
75
|
-
}
|
|
76
|
-
/**
|
|
77
|
-
* convert gregorian date to hijri date (Based on Umm al-Qura calculations).
|
|
78
|
-
* @param date: gregorian date
|
|
79
|
-
* @param format: iDD => day: ١٥, iMM => month: ٠٤, iMMM => month: ربيع ٢,
|
|
80
|
-
* iMMMM => ربيع الثاني, iYY => year: ٤٢, iYYYY => year: ١٤٤٢,
|
|
81
|
-
* dd => ن, ddd => إثنين, dddd => الإثنين
|
|
82
|
-
* @example 'iYYYY/iM/iDهـ الموافق YYYY/M/Dم'
|
|
83
|
-
* '١٤٤٢/٠٤/١٥هـ الموافق ٢٠٢٠/١١/٣٠'
|
|
84
|
-
*/
|
|
85
|
-
convertToHijriDate(date, format = 'iYYYY-iMM-iDD', lang = 'ar-SA') {
|
|
86
|
-
momentHijri.locale(lang);
|
|
87
|
-
return momentHijri(date).format(format);
|
|
88
|
-
}
|
|
89
|
-
convertToGregorianDate(date, format = 'YYYY-MM-DD', lang = 'en') {
|
|
90
|
-
momentHijri.locale(lang);
|
|
91
|
-
const m = momentHijri.iConvert.toGregorian(date.year(), date.month(), date.date());
|
|
92
|
-
return momentHijri(new Date(m.gy, m.gm, m.gd)).format(format);
|
|
93
|
-
}
|
|
94
|
-
getCurrentHijriDate() {
|
|
95
|
-
momentHijri.locale('en');
|
|
96
|
-
return momentHijri().format('iYYYY/iMM/iDD');
|
|
97
|
-
}
|
|
98
|
-
getValidatorErrorMessage(validatorName, validatorValue, patternErrorMsg, isArabic) {
|
|
99
|
-
if (validatorName === 'pattern') {
|
|
100
|
-
validatorValue = this.addPatternMsg(validatorValue, patternErrorMsg);
|
|
101
|
-
}
|
|
102
|
-
const config = {
|
|
103
|
-
required: isArabic ? 'هذا الحقل مطلوب' : 'this field required',
|
|
104
|
-
pattern: `${validatorValue.message}`,
|
|
105
|
-
Email: (isArabic ? 'خطأ في البريد الالكتروني ' : 'Invalid email ') +
|
|
106
|
-
'(example@example.com)',
|
|
107
|
-
maxlength: isArabic
|
|
108
|
-
? `تجاوز عدد الحقل المسموح بها (${validatorValue.requiredLength}) حرف`
|
|
109
|
-
: `this field is more than (${validatorValue.requiredLength}) letter`,
|
|
110
|
-
minlength: isArabic
|
|
111
|
-
? `على الأقل عدد ${validatorValue.requiredLength} حرف`
|
|
112
|
-
: `this field is less than (${validatorValue.requiredLength}) letter`,
|
|
113
|
-
min: isArabic
|
|
114
|
-
? `رقم اكبر من أو يساوي ${validatorValue.min}`
|
|
115
|
-
: `number more than or equal (${validatorValue.min})`,
|
|
116
|
-
max: isArabic
|
|
117
|
-
? `رقم اصغر من أو يساوي ${validatorValue.max}`
|
|
118
|
-
: `number less than or equal (${validatorValue.min})`,
|
|
119
|
-
ngbDate: this.getNgbDatepickerErrorMsg(validatorValue),
|
|
120
|
-
checkId: isArabic
|
|
121
|
-
? 'رقم الهوية أو الاقامة غير صحيح'
|
|
122
|
-
: 'Wrong ID or Iqama number',
|
|
123
|
-
link: (isArabic ? 'الرابط غير صحيح ' : 'Wrong link ') +
|
|
124
|
-
'(http://example.com)',
|
|
125
|
-
linkMP4: (isArabic ? 'رابط MP4 غير صحيح ' : 'Wrong MP4 link ') +
|
|
126
|
-
'(http://example.com/example.mp4)',
|
|
127
|
-
mobileNo: (isArabic ? 'خطأ في رقم الجوال ' : 'Wrong mobile number ') +
|
|
128
|
-
'(05xxxxxxxx)',
|
|
129
|
-
};
|
|
130
|
-
return config[validatorName];
|
|
131
|
-
}
|
|
132
|
-
addPatternMsg(validatorValue, patternErrorMsg) {
|
|
133
|
-
let pattern = {
|
|
134
|
-
...validatorValue,
|
|
135
|
-
message: patternErrorMsg,
|
|
136
|
-
};
|
|
137
|
-
return pattern;
|
|
138
|
-
}
|
|
139
|
-
getNgbDatepickerErrorMsg(validatorValue) {
|
|
140
|
-
let msg = '';
|
|
141
|
-
if (validatorValue.maxDate) {
|
|
142
|
-
msg = `التاريخ المدخل "${this.parserFormatter.format(validatorValue.maxDate.actual)}" اكبر من تاريخ اليوم "${this.parserFormatter.format(validatorValue.maxDate.maxDate)}"`;
|
|
143
|
-
}
|
|
144
|
-
else if (validatorValue.minDate) {
|
|
145
|
-
msg = `التاريخ المدخل "${this.parserFormatter.format(validatorValue.minDate.actual)}" يجب ان يكون اكبر من أو يساوي تاريخ البداية "${this.parserFormatter.format(validatorValue.minDate.minDate)}"`;
|
|
146
|
-
}
|
|
147
|
-
else if (validatorValue.invalid) {
|
|
148
|
-
msg = `التاريخ المدخل غير صحيح ${validatorValue.invalid}.`;
|
|
149
|
-
}
|
|
150
|
-
return msg;
|
|
151
|
-
}
|
|
152
|
-
static checkHijriDateValid(date) {
|
|
153
|
-
return !(momentHijri.iDaysInMonth(date?.year, date?.month - 1) < date?.day ||
|
|
154
|
-
date?.day <= 0 ||
|
|
155
|
-
date?.month <= 0 ||
|
|
156
|
-
date?.month > 12 ||
|
|
157
|
-
date?.year?.toString().length !== 4);
|
|
158
|
-
}
|
|
159
|
-
static convertToEn(value) {
|
|
160
|
-
let newValue = '';
|
|
161
|
-
for (let i = 0; i < value.length; i++) {
|
|
162
|
-
let ch = value.charCodeAt(i);
|
|
163
|
-
if (ch >= 1584 && ch <= 1650) {
|
|
164
|
-
let newChar = ch - 1584;
|
|
165
|
-
newValue = newValue + String.fromCharCode(newChar);
|
|
166
|
-
}
|
|
167
|
-
else {
|
|
168
|
-
newValue = newValue + String.fromCharCode(ch);
|
|
169
|
-
}
|
|
170
|
-
}
|
|
171
|
-
return newValue;
|
|
172
|
-
}
|
|
173
|
-
static nationalIdValidate(civilId) {
|
|
174
|
-
if (civilId) {
|
|
175
|
-
let strID = this.convertToEn(civilId);
|
|
176
|
-
let digits = '';
|
|
177
|
-
let counter = 0;
|
|
178
|
-
while (counter < 9) {
|
|
179
|
-
if ((counter + 1) % 2 == 0) {
|
|
180
|
-
digits = digits + strID.substring(counter, counter + 1);
|
|
181
|
-
}
|
|
182
|
-
else {
|
|
183
|
-
digits =
|
|
184
|
-
digits + (+strID.substring(counter, counter + 1) * 2).toString();
|
|
185
|
-
}
|
|
186
|
-
counter++;
|
|
187
|
-
}
|
|
188
|
-
let intSum = 0;
|
|
189
|
-
let intSumTemp = 0;
|
|
190
|
-
let strSum;
|
|
191
|
-
let intOddSumDigit;
|
|
192
|
-
let CheckDigit;
|
|
193
|
-
counter = 0;
|
|
194
|
-
while (counter < digits.length) {
|
|
195
|
-
intSumTemp = +digits.charAt(counter) * 1;
|
|
196
|
-
intSum += intSumTemp;
|
|
197
|
-
counter++;
|
|
198
|
-
}
|
|
199
|
-
strSum = intSum.toString();
|
|
200
|
-
if (strSum.length == 1) {
|
|
201
|
-
intOddSumDigit = intSum;
|
|
202
|
-
}
|
|
203
|
-
else {
|
|
204
|
-
intOddSumDigit = strSum.substring(strSum.length, strSum.length - 1);
|
|
205
|
-
}
|
|
206
|
-
if (intOddSumDigit == 0) {
|
|
207
|
-
CheckDigit = 0;
|
|
208
|
-
}
|
|
209
|
-
else {
|
|
210
|
-
CheckDigit = (10 - +intOddSumDigit).toString();
|
|
211
|
-
}
|
|
212
|
-
let PublicID = this.convertToEn(civilId);
|
|
213
|
-
if (CheckDigit ==
|
|
214
|
-
PublicID.substring(PublicID.length - 1, PublicID.length) &&
|
|
215
|
-
strID.length == 10 &&
|
|
216
|
-
strID.substring(0, 1) == '1') {
|
|
217
|
-
return true;
|
|
218
|
-
}
|
|
219
|
-
else {
|
|
220
|
-
return false;
|
|
221
|
-
}
|
|
222
|
-
}
|
|
223
|
-
else {
|
|
224
|
-
return false;
|
|
225
|
-
}
|
|
226
|
-
}
|
|
227
|
-
static iqamaIdValidate(civilId) {
|
|
228
|
-
if (civilId) {
|
|
229
|
-
let strID = this.convertToEn(civilId);
|
|
230
|
-
let digits = '';
|
|
231
|
-
let counter = 0;
|
|
232
|
-
while (counter < 9) {
|
|
233
|
-
if ((counter + 1) % 2 == 0) {
|
|
234
|
-
digits = digits + strID.substring(counter, counter + 1);
|
|
235
|
-
}
|
|
236
|
-
else {
|
|
237
|
-
digits =
|
|
238
|
-
digits + (+strID.substring(counter, counter + 1) * 2).toString();
|
|
239
|
-
}
|
|
240
|
-
counter++;
|
|
241
|
-
}
|
|
242
|
-
let intSum = 0;
|
|
243
|
-
let intSumTemp = 0;
|
|
244
|
-
let strSum;
|
|
245
|
-
let intOddSumDigit;
|
|
246
|
-
let CheckDigit;
|
|
247
|
-
counter = 0;
|
|
248
|
-
while (counter < digits.length) {
|
|
249
|
-
intSumTemp = +digits.charAt(counter) * 1;
|
|
250
|
-
intSum += intSumTemp;
|
|
251
|
-
counter++;
|
|
252
|
-
}
|
|
253
|
-
strSum = intSum.toString();
|
|
254
|
-
if (strSum.length == 1) {
|
|
255
|
-
intOddSumDigit = intSum;
|
|
256
|
-
}
|
|
257
|
-
else {
|
|
258
|
-
intOddSumDigit = strSum.substring(strSum.length, strSum.length - 1);
|
|
259
|
-
}
|
|
260
|
-
if (intOddSumDigit == 0) {
|
|
261
|
-
CheckDigit = 0;
|
|
262
|
-
}
|
|
263
|
-
else {
|
|
264
|
-
CheckDigit = (10 - +intOddSumDigit).toString();
|
|
265
|
-
}
|
|
266
|
-
let PublicID = this.convertToEn(civilId);
|
|
267
|
-
if (CheckDigit ==
|
|
268
|
-
PublicID.substring(PublicID.length - 1, PublicID.length) &&
|
|
269
|
-
strID.length == 10 &&
|
|
270
|
-
strID.substring(0, 1) == '2') {
|
|
271
|
-
return true;
|
|
272
|
-
}
|
|
273
|
-
else {
|
|
274
|
-
return false;
|
|
275
|
-
}
|
|
276
|
-
}
|
|
277
|
-
else {
|
|
278
|
-
return false;
|
|
279
|
-
}
|
|
280
|
-
}
|
|
281
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: IPAFormService, deps: [{ token: i1.NgbDateParserFormatter }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
282
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: IPAFormService, providedIn: 'root' }); }
|
|
283
|
-
}
|
|
284
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: IPAFormService, decorators: [{
|
|
285
|
-
type: Injectable,
|
|
286
|
-
args: [{
|
|
287
|
-
providedIn: 'root',
|
|
288
|
-
}]
|
|
289
|
-
}], ctorParameters: () => [{ type: i1.NgbDateParserFormatter }] });
|
|
290
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ipa-form.service.js","sourceRoot":"","sources":["../../../../../projects/ng-ipa-library/src/lib/ipa-form/ipa-form.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { AbstractControl, UntypedFormControl, ValidationErrors } from '@angular/forms';\r\nimport momentHijri from 'moment-hijri';\r\nimport { Moment } from 'moment';\r\nimport { NgbDate, NgbDateParserFormatter } from '@ng-bootstrap/ng-bootstrap';\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class IPAFormService {\r\n  constructor(private parserFormatter: NgbDateParserFormatter) {}\r\n\r\n  /**\r\n   * check link is valid.\r\n   */\r\n  static linkValidation(control: AbstractControl): ValidationErrors | null {\r\n    const isValidLink =\r\n      /^((https?:\\/\\/)[\\w-]+(\\.[a-z-]+)+\\.?(:\\d+)?(\\/\\S*)?)$/.test(\r\n        control.value\r\n      );\r\n    return isValidLink || !control.value ? null : { link: true };\r\n  }\r\n\r\n  /**\r\n   * check mp4 link is valid.\r\n   */\r\n  static mp4LinkValidation(control: AbstractControl): ValidationErrors | null {\r\n    const isValidLink =\r\n      /^((https?:\\/\\/)[\\w-]+(\\.[a-z-]+)+\\.?(:\\d+)?(\\/\\S*)?(\\/[\\w\\u0600-\\u06FF]+\\.mp4))$/.test(\r\n        control.value\r\n      );\r\n    return isValidLink || !control.value ? null : { linkMP4: true };\r\n  }\r\n\r\n  /**\r\n   * check mobile number is valid.\r\n   */\r\n  static mobileNo(control: AbstractControl): ValidationErrors | null {\r\n    const isValidLink = /^05\\d{8}$/.test(control.value);\r\n    return isValidLink || !control.value ? null : { mobileNo: true };\r\n  }\r\n\r\n  /**\r\n   * check email is valid.\r\n   */\r\n  static email(control: AbstractControl): ValidationErrors | null {\r\n    const isValidLink =\r\n      /^(([^<>()[\\]\\.,;:\\s@\\\"]+(\\.[^<>()[\\]\\.,;:\\s@\\\"]+)*)|(\\\".+\\\"))@(([^<>()[\\]\\.,;:\\s@\\\"]+\\.)+[^<>()[\\]\\.,;:\\s@\\\"]{2,})$/.test(\r\n        control.value\r\n      );\r\n    return isValidLink || !control.value ? null : { Email: true };\r\n  }\r\n\r\n  /**\r\n   * check national ID or iqama ID is valid.\r\n   */\r\n  static checkID(control: AbstractControl): ValidationErrors | null {\r\n    let isValid = false;\r\n    const value = control.value;\r\n    if (\r\n      IPAFormService.nationalIdValidate(value) ||\r\n      IPAFormService.iqamaIdValidate(value)\r\n    ) {\r\n      isValid = true;\r\n    } else {\r\n      isValid = false;\r\n    }\r\n    return isValid || !value ? null : { checkId: true };\r\n  }\r\n\r\n  static validHijriDate(control: AbstractControl): ValidationErrors | null {\r\n    const date: NgbDate = control.value;\r\n    const isValid = IPAFormService.checkHijriDateValid(date);\r\n    return isValid || !date\r\n      ? null\r\n      : {\r\n          ngbDate: {\r\n            invalid:\r\n              date?.year +\r\n              '-' +\r\n              (date?.month > 10 ? date?.month : '0' + date?.month) +\r\n              '-' +\r\n              (date?.day > 10 ? date?.day : '0' + date?.day),\r\n          },\r\n        };\r\n  }\r\n\r\n  getErrorMessage(\r\n    control: UntypedFormControl,\r\n    patternErrorMsg = '',\r\n    isArabic: boolean\r\n  ): string | null {\r\n    for (const propertyName in control?.errors) {\r\n      if (\r\n        control?.errors.hasOwnProperty(propertyName) &&\r\n        (control.touched || control.dirty)\r\n      ) {\r\n        return this.getValidatorErrorMessage(\r\n          propertyName,\r\n          control.errors[propertyName],\r\n          patternErrorMsg,\r\n          isArabic\r\n        );\r\n      }\r\n    }\r\n    return null;\r\n  }\r\n\r\n  /**\r\n   * convert gregorian date to hijri date (Based on Umm al-Qura calculations).\r\n   * @param date: gregorian date\r\n   * @param format: iDD => day: ١٥, iMM => month: ٠٤, iMMM => month: ربيع ٢,\r\n   *               iMMMM => ربيع الثاني,  iYY => year: ٤٢, iYYYY => year: ١٤٤٢,\r\n   *               dd => ن, ddd => إثنين, dddd => الإثنين\r\n   * @example 'iYYYY/iM/iDهـ الموافق YYYY/M/Dم'\r\n   *           '١٤٤٢/٠٤/١٥هـ الموافق ٢٠٢٠/١١/٣٠'\r\n   */\r\n  convertToHijriDate(\r\n    date: string,\r\n    format = 'iYYYY-iMM-iDD',\r\n    lang = 'ar-SA'\r\n  ): string {\r\n    momentHijri.locale(lang);\r\n    return momentHijri(date).format(format);\r\n  }\r\n\r\n  convertToGregorianDate(\r\n    date: Moment,\r\n    format = 'YYYY-MM-DD',\r\n    lang = 'en'\r\n  ): string {\r\n    momentHijri.locale(lang);\r\n    const m = momentHijri.iConvert.toGregorian(\r\n      date.year(),\r\n      date.month(),\r\n      date.date()\r\n    );\r\n    return momentHijri(new Date(m.gy, m.gm, m.gd)).format(format);\r\n  }\r\n\r\n  getCurrentHijriDate() {\r\n    momentHijri.locale('en');\r\n    return momentHijri().format('iYYYY/iMM/iDD');\r\n  }\r\n\r\n  private getValidatorErrorMessage(\r\n    validatorName: string,\r\n    validatorValue: any,\r\n    patternErrorMsg: string,\r\n    isArabic: boolean\r\n  ): string {\r\n    if (validatorName === 'pattern') {\r\n      validatorValue = this.addPatternMsg(validatorValue, patternErrorMsg);\r\n    }\r\n    const config: any = {\r\n      required: isArabic ? 'هذا الحقل مطلوب' : 'this field required',\r\n      pattern: `${validatorValue.message}`,\r\n      Email:\r\n        (isArabic ? 'خطأ في البريد الالكتروني ' : 'Invalid email ') +\r\n        '(example@example.com)',\r\n      maxlength: isArabic\r\n        ? `تجاوز عدد الحقل المسموح بها (${validatorValue.requiredLength}) حرف`\r\n        : `this field is more than (${validatorValue.requiredLength}) letter`,\r\n      minlength: isArabic\r\n        ? `على الأقل عدد ${validatorValue.requiredLength} حرف`\r\n        : `this field is less than (${validatorValue.requiredLength}) letter`,\r\n      min: isArabic\r\n        ? `رقم اكبر من أو يساوي ${validatorValue.min}`\r\n        : `number more than or equal (${validatorValue.min})`,\r\n      max: isArabic\r\n        ? `رقم اصغر من أو يساوي ${validatorValue.max}`\r\n        : `number less than or equal (${validatorValue.min})`,\r\n      ngbDate: this.getNgbDatepickerErrorMsg(validatorValue),\r\n      checkId: isArabic\r\n        ? 'رقم الهوية أو الاقامة غير صحيح'\r\n        : 'Wrong ID or Iqama number',\r\n      link:\r\n        (isArabic ? 'الرابط غير صحيح ' : 'Wrong link ') +\r\n        '(http://example.com)',\r\n      linkMP4:\r\n        (isArabic ? 'رابط MP4 غير صحيح ' : 'Wrong MP4 link ') +\r\n        '(http://example.com/example.mp4)',\r\n      mobileNo:\r\n        (isArabic ? 'خطأ في رقم الجوال ' : 'Wrong mobile number ') +\r\n        '(05xxxxxxxx)',\r\n    };\r\n    return config[validatorName];\r\n  }\r\n\r\n  private addPatternMsg(validatorValue: any, patternErrorMsg: string) {\r\n    let pattern = {\r\n      ...validatorValue,\r\n      message: patternErrorMsg,\r\n    };\r\n    return pattern;\r\n  }\r\n\r\n  private getNgbDatepickerErrorMsg(validatorValue: any): string {\r\n    let msg = '';\r\n    if (validatorValue.maxDate) {\r\n      msg = `التاريخ المدخل \"${this.parserFormatter.format(\r\n        validatorValue.maxDate.actual\r\n      )}\" اكبر من تاريخ اليوم \"${this.parserFormatter.format(\r\n        validatorValue.maxDate.maxDate\r\n      )}\"`;\r\n    } else if (validatorValue.minDate) {\r\n      msg = `التاريخ المدخل \"${this.parserFormatter.format(\r\n        validatorValue.minDate.actual\r\n      )}\" يجب ان يكون اكبر من أو يساوي تاريخ البداية \"${this.parserFormatter.format(\r\n        validatorValue.minDate.minDate\r\n      )}\"`;\r\n    } else if (validatorValue.invalid) {\r\n      msg = `التاريخ المدخل غير صحيح ${validatorValue.invalid}.`;\r\n    }\r\n    return msg;\r\n  }\r\n\r\n  private static checkHijriDateValid(date: NgbDate): boolean {\r\n    return !(\r\n      momentHijri.iDaysInMonth(date?.year, date?.month - 1) < date?.day ||\r\n      date?.day <= 0 ||\r\n      date?.month <= 0 ||\r\n      date?.month > 12 ||\r\n      date?.year?.toString().length !== 4\r\n    );\r\n  }\r\n\r\n  private static convertToEn(value: string) {\r\n    let newValue = '';\r\n    for (let i = 0; i < value.length; i++) {\r\n      let ch = value.charCodeAt(i);\r\n      if (ch >= 1584 && ch <= 1650) {\r\n        let newChar = ch - 1584;\r\n        newValue = newValue + String.fromCharCode(newChar);\r\n      } else {\r\n        newValue = newValue + String.fromCharCode(ch);\r\n      }\r\n    }\r\n    return newValue;\r\n  }\r\n\r\n  private static nationalIdValidate(civilId: string): boolean {\r\n    if (civilId) {\r\n      let strID = this.convertToEn(civilId);\r\n      let digits = '';\r\n      let counter = 0;\r\n      while (counter < 9) {\r\n        if ((counter + 1) % 2 == 0) {\r\n          digits = digits + strID.substring(counter, counter + 1);\r\n        } else {\r\n          digits =\r\n            digits + (+strID.substring(counter, counter + 1) * 2).toString();\r\n        }\r\n        counter++;\r\n      }\r\n      let intSum = 0;\r\n      let intSumTemp = 0;\r\n      let strSum;\r\n      let intOddSumDigit;\r\n      let CheckDigit;\r\n      counter = 0;\r\n      while (counter < digits.length) {\r\n        intSumTemp = +digits.charAt(counter) * 1;\r\n        intSum += intSumTemp;\r\n        counter++;\r\n      }\r\n      strSum = intSum.toString();\r\n      if (strSum.length == 1) {\r\n        intOddSumDigit = intSum;\r\n      } else {\r\n        intOddSumDigit = strSum.substring(strSum.length, strSum.length - 1);\r\n      }\r\n      if (intOddSumDigit == 0) {\r\n        CheckDigit = 0;\r\n      } else {\r\n        CheckDigit = (10 - +intOddSumDigit).toString();\r\n      }\r\n      let PublicID = this.convertToEn(civilId);\r\n      if (\r\n        CheckDigit ==\r\n          PublicID.substring(PublicID.length - 1, PublicID.length) &&\r\n        strID.length == 10 &&\r\n        strID.substring(0, 1) == '1'\r\n      ) {\r\n        return true;\r\n      } else {\r\n        return false;\r\n      }\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  private static iqamaIdValidate(civilId: string): boolean {\r\n    if (civilId) {\r\n      let strID = this.convertToEn(civilId);\r\n      let digits = '';\r\n      let counter = 0;\r\n      while (counter < 9) {\r\n        if ((counter + 1) % 2 == 0) {\r\n          digits = digits + strID.substring(counter, counter + 1);\r\n        } else {\r\n          digits =\r\n            digits + (+strID.substring(counter, counter + 1) * 2).toString();\r\n        }\r\n        counter++;\r\n      }\r\n      let intSum = 0;\r\n      let intSumTemp = 0;\r\n      let strSum;\r\n      let intOddSumDigit;\r\n      let CheckDigit;\r\n      counter = 0;\r\n      while (counter < digits.length) {\r\n        intSumTemp = +digits.charAt(counter) * 1;\r\n        intSum += intSumTemp;\r\n        counter++;\r\n      }\r\n      strSum = intSum.toString();\r\n      if (strSum.length == 1) {\r\n        intOddSumDigit = intSum;\r\n      } else {\r\n        intOddSumDigit = strSum.substring(strSum.length, strSum.length - 1);\r\n      }\r\n      if (intOddSumDigit == 0) {\r\n        CheckDigit = 0;\r\n      } else {\r\n        CheckDigit = (10 - +intOddSumDigit).toString();\r\n      }\r\n      let PublicID = this.convertToEn(civilId);\r\n      if (\r\n        CheckDigit ==\r\n          PublicID.substring(PublicID.length - 1, PublicID.length) &&\r\n        strID.length == 10 &&\r\n        strID.substring(0, 1) == '2'\r\n      ) {\r\n        return true;\r\n      } else {\r\n        return false;\r\n      }\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n}\r\n"]}
|