ng-ipa-library 0.7.12 → 1.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/{esm2015/lib/core/components/loading/loading.component.js → esm2020/lib/core/components/loading/loading.component.mjs} +5 -9
- package/esm2020/lib/core/interceptors/error.interceptor.mjs +46 -0
- package/{esm2015/lib/core/interceptors/loading.interceptor.js → esm2020/lib/core/interceptors/loading.interceptor.mjs} +3 -3
- package/esm2020/lib/core/interceptors/token.interceptor.mjs +68 -0
- package/esm2020/lib/core/services/auth.service.mjs +47 -0
- package/{esm2015/lib/core/services/error.service.js → esm2020/lib/core/services/error.service.mjs} +3 -3
- package/{esm2015/lib/core/services/loader.service.js → esm2020/lib/core/services/loader.service.mjs} +3 -3
- package/esm2020/lib/generate-form/generate-form.component.mjs +116 -0
- package/esm2020/lib/ipa-form/datepicker/datepicker.component.mjs +66 -0
- package/esm2020/lib/ipa-form/datepicker/gregorian-datepicker/gregorian-datepicker.component.mjs +23 -0
- package/{esm2015/lib/ipa-form/datepicker/gregorian-datepicker/gregorian18n.js → esm2020/lib/ipa-form/datepicker/gregorian-datepicker/gregorian18n.mjs} +3 -3
- package/{esm2015/lib/ipa-form/datepicker/hijri-datepicker/IslamicI18n.js → esm2020/lib/ipa-form/datepicker/hijri-datepicker/IslamicI18n.mjs} +3 -3
- package/esm2020/lib/ipa-form/datepicker/hijri-datepicker/hijri-datepicker.component.mjs +23 -0
- package/esm2020/lib/ipa-form/dropdown-input/dropdown-input.component.mjs +77 -0
- package/{esm2015/lib/ipa-form/file-upload/file-upload.component.js → esm2020/lib/ipa-form/file-upload/file-upload.component.mjs} +5 -9
- package/esm2020/lib/ipa-form/ipa-form.service.mjs +254 -0
- package/esm2020/lib/ipa-form/recaptcha/recaptcha.component.mjs +55 -0
- package/esm2020/lib/ipa-form/text-input/text-input.component.mjs +72 -0
- package/esm2020/lib/ipa-form/textarea-input/textarea-input.component.mjs +69 -0
- package/{esm2015/lib/models/apiException.js → esm2020/lib/models/apiException.mjs} +0 -0
- package/{esm2015/lib/models/apiResponse.js → esm2020/lib/models/apiResponse.mjs} +0 -0
- package/{esm2015/lib/models/breadcrumbs.model.js → esm2020/lib/models/breadcrumbs.model.mjs} +0 -0
- package/{esm2015/lib/models/decodedToken.model.js → esm2020/lib/models/decodedToken.model.mjs} +0 -0
- package/{esm2015/lib/models/exceptionUrl.model.js → esm2020/lib/models/exceptionUrl.model.mjs} +0 -0
- package/{esm2015/lib/models/generateForm.model.js → esm2020/lib/models/generateForm.model.mjs} +0 -0
- package/{esm2015/lib/models/pagedResult.js → esm2020/lib/models/pagedResult.mjs} +0 -0
- package/{esm2015/lib/models/user.model.js → esm2020/lib/models/user.model.mjs} +0 -0
- package/{esm2015/lib/ng-ipa-library.module.js → esm2020/lib/ng-ipa-library.module.mjs} +4 -4
- package/{esm2015/lib/pipes/hijri-date.pipe.js → esm2020/lib/pipes/hijri-date.pipe.mjs} +3 -3
- package/{esm2015/lib/pipes/pipes.module.js → esm2020/lib/pipes/pipes.module.mjs} +4 -4
- package/esm2020/lib/services/breadcrumbs.service.mjs +149 -0
- package/esm2020/lib/services/common.service.mjs +65 -0
- package/{esm2015/lib/share-button/share-button.component.js → esm2020/lib/share-button/share-button.component.mjs} +5 -9
- package/{esm2015/lib/share-button/share-button.module.js → esm2020/lib/share-button/share-button.module.mjs} +4 -4
- package/{esm2015/ng-ipa-library.js → esm2020/ng-ipa-library.mjs} +0 -0
- package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
- package/fesm2015/{ng-ipa-library.js → ng-ipa-library.mjs} +122 -158
- package/fesm2015/ng-ipa-library.mjs.map +1 -0
- package/fesm2020/ng-ipa-library.mjs +1582 -0
- package/fesm2020/ng-ipa-library.mjs.map +1 -0
- package/package.json +32 -19
- package/src/lib/assets/ngIPAStyle.scss +2 -1
- package/bundles/ng-ipa-library.umd.js +0 -2098
- package/bundles/ng-ipa-library.umd.js.map +0 -1
- package/esm2015/lib/core/interceptors/error.interceptor.js +0 -46
- package/esm2015/lib/core/interceptors/token.interceptor.js +0 -69
- package/esm2015/lib/core/services/auth.service.js +0 -48
- package/esm2015/lib/generate-form/generate-form.component.js +0 -120
- package/esm2015/lib/ipa-form/datepicker/datepicker.component.js +0 -70
- package/esm2015/lib/ipa-form/datepicker/gregorian-datepicker/gregorian-datepicker.component.js +0 -28
- package/esm2015/lib/ipa-form/datepicker/hijri-datepicker/hijri-datepicker.component.js +0 -28
- package/esm2015/lib/ipa-form/dropdown-input/dropdown-input.component.js +0 -81
- package/esm2015/lib/ipa-form/ipa-form.service.js +0 -251
- package/esm2015/lib/ipa-form/recaptcha/recaptcha.component.js +0 -59
- package/esm2015/lib/ipa-form/text-input/text-input.component.js +0 -76
- package/esm2015/lib/ipa-form/textarea-input/textarea-input.component.js +0 -73
- package/esm2015/lib/services/breadcrumbs.service.js +0 -151
- package/esm2015/lib/services/common.service.js +0 -66
- package/fesm2015/ng-ipa-library.js.map +0 -1
|
@@ -30,9 +30,9 @@ export class Gregorian18n extends NgbDatepickerI18n {
|
|
|
30
30
|
return `${date.day}-${date.month}-${date.year}`;
|
|
31
31
|
}
|
|
32
32
|
}
|
|
33
|
-
Gregorian18n.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
34
|
-
Gregorian18n.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
35
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
33
|
+
Gregorian18n.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: Gregorian18n, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
|
|
34
|
+
Gregorian18n.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: Gregorian18n });
|
|
35
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: Gregorian18n, decorators: [{
|
|
36
36
|
type: Injectable
|
|
37
37
|
}] });
|
|
38
38
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JlZ29yaWFuMThuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctaXBhLWxpYnJhcnkvc3JjL2xpYi9pcGEtZm9ybS9kYXRlcGlja2VyL2dyZWdvcmlhbi1kYXRlcGlja2VyL2dyZWdvcmlhbjE4bi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxpQkFBaUIsRUFBaUIsTUFBTSw0QkFBNEIsQ0FBQzs7QUFFOUUsTUFBTSxRQUFRLEdBQUcsQ0FBQyxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLENBQUMsQ0FBQztBQUNyRCxNQUFNLE1BQU0sR0FBRztJQUNiLE9BQU87SUFDUCxRQUFRO0lBQ1IsTUFBTTtJQUNOLE9BQU87SUFDUCxNQUFNO0lBQ04sT0FBTztJQUNQLE9BQU87SUFDUCxPQUFPO0lBQ1AsUUFBUTtJQUNSLFFBQVE7SUFDUixRQUFRO0lBQ1IsUUFBUTtDQUNULENBQUM7QUFHRixNQUFNLE9BQU8sWUFBYSxTQUFRLGlCQUFpQjtJQUNqRCxpQkFBaUIsQ0FBQyxLQUFhO1FBQzdCLE9BQU8sTUFBTSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsQ0FBQztJQUMzQixDQUFDO0lBRUQsZ0JBQWdCLENBQUMsS0FBYTtRQUM1QixPQUFPLE1BQU0sQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDM0IsQ0FBQztJQUVELGVBQWUsQ0FBQyxPQUFlLEVBQUUsS0FBd0I7UUFDdkQsT0FBTyxRQUFRLENBQUMsT0FBTyxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFRCxlQUFlLENBQUMsSUFBbUI7UUFDakMsT0FBTyxHQUFHLElBQUksQ0FBQyxHQUFHLElBQUksSUFBSSxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDbEQsQ0FBQzs7eUdBZlUsWUFBWTs2R0FBWixZQUFZOzJGQUFaLFlBQVk7a0JBRHhCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUcmFuc2xhdGlvbldpZHRoIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBOZ2JEYXRlcGlja2VySTE4biwgTmdiRGF0ZVN0cnVjdCB9IGZyb20gJ0BuZy1ib290c3RyYXAvbmctYm9vdHN0cmFwJztcclxuXHJcbmNvbnN0IFdFRUtEQVlTID0gWyfZhicsICfYqycsICfYsScsICfYricsICfYrCcsICfYsycsICfYrSddO1xyXG5jb25zdCBNT05USFMgPSBbXHJcbiAgJ9mK2YbYp9mK2LEnLFxyXG4gICfZgdio2LHYp9mK2LEnLFxyXG4gICfZhdin2LHYsycsXHJcbiAgJ9ij2KjYsdmK2YQnLFxyXG4gICfZhdin2YrZiCcsXHJcbiAgJ9mK2YjZhtmK2YgnLFxyXG4gICfZitmI2YTZitmIJyxcclxuICAn2KfYutiz2LfYsycsXHJcbiAgJ9iz2KjYqtmF2KjYsScsXHJcbiAgJ9ij2YPYqtmI2KjYsScsXHJcbiAgJ9mG2YjZgdmF2KjYsScsXHJcbiAgJ9iv2YrYs9mF2KjYsScsXHJcbl07XHJcblxyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBHcmVnb3JpYW4xOG4gZXh0ZW5kcyBOZ2JEYXRlcGlja2VySTE4biB7XHJcbiAgZ2V0TW9udGhTaG9ydE5hbWUobW9udGg6IG51bWJlcikge1xyXG4gICAgcmV0dXJuIE1PTlRIU1ttb250aCAtIDFdO1xyXG4gIH1cclxuXHJcbiAgZ2V0TW9udGhGdWxsTmFtZShtb250aDogbnVtYmVyKSB7XHJcbiAgICByZXR1cm4gTU9OVEhTW21vbnRoIC0gMV07XHJcbiAgfVxyXG5cclxuICBnZXRXZWVrZGF5TGFiZWwod2Vla2RheTogbnVtYmVyLCB3aWR0aD86IFRyYW5zbGF0aW9uV2lkdGgpIHtcclxuICAgIHJldHVybiBXRUVLREFZU1t3ZWVrZGF5IC0gMV07XHJcbiAgfVxyXG5cclxuICBnZXREYXlBcmlhTGFiZWwoZGF0ZTogTmdiRGF0ZVN0cnVjdCk6IHN0cmluZyB7XHJcbiAgICByZXR1cm4gYCR7ZGF0ZS5kYXl9LSR7ZGF0ZS5tb250aH0tJHtkYXRlLnllYXJ9YDtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -30,9 +30,9 @@ export class IslamicI18n extends NgbDatepickerI18n {
|
|
|
30
30
|
return `${date.day}-${date.month}-${date.year}`;
|
|
31
31
|
}
|
|
32
32
|
}
|
|
33
|
-
IslamicI18n.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
34
|
-
IslamicI18n.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
35
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
33
|
+
IslamicI18n.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: IslamicI18n, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
|
|
34
|
+
IslamicI18n.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: IslamicI18n });
|
|
35
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: IslamicI18n, decorators: [{
|
|
36
36
|
type: Injectable
|
|
37
37
|
}] });
|
|
38
38
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiSXNsYW1pY0kxOG4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1pcGEtbGlicmFyeS9zcmMvbGliL2lwYS1mb3JtL2RhdGVwaWNrZXIvaGlqcmktZGF0ZXBpY2tlci9Jc2xhbWljSTE4bi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxpQkFBaUIsRUFBaUIsTUFBTSw0QkFBNEIsQ0FBQzs7QUFFOUUsTUFBTSxRQUFRLEdBQUcsQ0FBQyxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUcsRUFBRSxHQUFHLENBQUMsQ0FBQztBQUNyRCxNQUFNLE1BQU0sR0FBRztJQUNiLE1BQU07SUFDTixLQUFLO0lBQ0wsWUFBWTtJQUNaLFlBQVk7SUFDWixjQUFjO0lBQ2QsY0FBYztJQUNkLEtBQUs7SUFDTCxPQUFPO0lBQ1AsT0FBTztJQUNQLE1BQU07SUFDTixXQUFXO0lBQ1gsVUFBVTtDQUNYLENBQUM7QUFHRixNQUFNLE9BQU8sV0FBWSxTQUFRLGlCQUFpQjtJQUNoRCxpQkFBaUIsQ0FBQyxLQUFhO1FBQzdCLE9BQU8sTUFBTSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsQ0FBQztJQUMzQixDQUFDO0lBRUQsZ0JBQWdCLENBQUMsS0FBYTtRQUM1QixPQUFPLE1BQU0sQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFDM0IsQ0FBQztJQUVELGVBQWUsQ0FBQyxPQUFlLEVBQUUsS0FBd0I7UUFDdkQsT0FBTyxRQUFRLENBQUMsT0FBTyxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQy9CLENBQUM7SUFFRCxlQUFlLENBQUMsSUFBbUI7UUFDakMsT0FBTyxHQUFHLElBQUksQ0FBQyxHQUFHLElBQUksSUFBSSxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDbEQsQ0FBQzs7d0dBZlUsV0FBVzs0R0FBWCxXQUFXOzJGQUFYLFdBQVc7a0JBRHZCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUcmFuc2xhdGlvbldpZHRoIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBOZ2JEYXRlcGlja2VySTE4biwgTmdiRGF0ZVN0cnVjdCB9IGZyb20gJ0BuZy1ib290c3RyYXAvbmctYm9vdHN0cmFwJztcclxuXHJcbmNvbnN0IFdFRUtEQVlTID0gWyfZhicsICfYqycsICfYsScsICfYricsICfYrCcsICfYsycsICfYrSddO1xyXG5jb25zdCBNT05USFMgPSBbXHJcbiAgJ9mF2K3YsdmFJyxcclxuICAn2LXZgdixJyxcclxuICAn2LHYqNmK2Lkg2KfZhNij2YjZhCcsXHJcbiAgJ9ix2KjZiti5INin2YTYotiu2LEnLFxyXG4gICfYrNmF2KfYr9mJINin2YTYo9mI2YTZiScsXHJcbiAgJ9is2YXYp9iv2Ykg2KfZhNii2K7YsdipJyxcclxuICAn2LHYrNioJyxcclxuICAn2LTYudio2KfZhicsXHJcbiAgJ9ix2YXYttin2YYnLFxyXG4gICfYtNmI2KfZhCcsXHJcbiAgJ9iw2Ygg2KfZhNmC2LnYr9ipJyxcclxuICAn2LDZiCDYp9mE2K3YrNipJyxcclxuXTtcclxuXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIElzbGFtaWNJMThuIGV4dGVuZHMgTmdiRGF0ZXBpY2tlckkxOG4ge1xyXG4gIGdldE1vbnRoU2hvcnROYW1lKG1vbnRoOiBudW1iZXIpIHtcclxuICAgIHJldHVybiBNT05USFNbbW9udGggLSAxXTtcclxuICB9XHJcblxyXG4gIGdldE1vbnRoRnVsbE5hbWUobW9udGg6IG51bWJlcikge1xyXG4gICAgcmV0dXJuIE1PTlRIU1ttb250aCAtIDFdO1xyXG4gIH1cclxuXHJcbiAgZ2V0V2Vla2RheUxhYmVsKHdlZWtkYXk6IG51bWJlciwgd2lkdGg/OiBUcmFuc2xhdGlvbldpZHRoKSB7XHJcbiAgICByZXR1cm4gV0VFS0RBWVNbd2Vla2RheSAtIDFdO1xyXG4gIH1cclxuXHJcbiAgZ2V0RGF5QXJpYUxhYmVsKGRhdGU6IE5nYkRhdGVTdHJ1Y3QpOiBzdHJpbmcge1xyXG4gICAgcmV0dXJuIGAke2RhdGUuZGF5fS0ke2RhdGUubW9udGh9LSR7ZGF0ZS55ZWFyfWA7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { NgbCalendar, NgbCalendarIslamicUmalqura, NgbDatepickerI18n } from '@ng-bootstrap/ng-bootstrap';
|
|
3
|
+
import { DatepickerComponent } from '../datepicker.component';
|
|
4
|
+
import { IslamicI18n } from './IslamicI18n';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@ng-bootstrap/ng-bootstrap";
|
|
7
|
+
import * as i2 from "@angular/forms";
|
|
8
|
+
import * as i3 from "@angular/common";
|
|
9
|
+
export class HijriDatepickerComponent extends DatepickerComponent {
|
|
10
|
+
}
|
|
11
|
+
HijriDatepickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: HijriDatepickerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
12
|
+
HijriDatepickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: HijriDatepickerComponent, selector: "ipa-hijri-datepicker", providers: [
|
|
13
|
+
{ provide: NgbCalendar, useClass: NgbCalendarIslamicUmalqura },
|
|
14
|
+
{ provide: NgbDatepickerI18n, useClass: IslamicI18n },
|
|
15
|
+
], usesInheritance: true, ngImport: i0, template: "<div class=\"form-floating input-group {{containerClasses}}\">\r\n <input id=\"{{id}}\"\r\n [ngClass]=\"{'is-invalid is-invalid:focus': (controlDir.control?.invalid && (controlDir.control?.dirty || controlDir.control?.touched)) && errorMsg,'is-valid is-valid:focus': (controlDir.control?.valid && (controlDir.control?.dirty || controlDir.control?.touched) && (errorMsg || controlDir.value))}\"\r\n class=\"form-control {{classes}}\" [formControl]=\"formControl\" [firstDayOfWeek]=\"7\" ngbDatepicker\r\n #d=\"ngbDatepicker\" [maxDate]=\"maxDate\" [minDate]=\"minDate\" [footerTemplate]=\"footerTemplate\"\r\n [required]=\"required\" style=\"outline: unset; z-index: unset !important;\" autocomplete=\"off\" (blur)=\"onTouched()\" title=\"{{label}}\">\r\n <label for=\"{{id}}\">{{label}}</label>\r\n <span class=\"input-group-text calenderBtn\" (click)=\"d.toggle()\">\r\n <i class=\"far fa-calendar-alt fa-lg\"></i>\r\n </span>\r\n <div class=\"invalid-feedback\" *ngIf=\"errorMessage !== null\">\r\n {{errorMsg}}\r\n </div>\r\n <ng-template #footerTemplate style=\"text-align: center;\">\r\n <hr>\r\n <button type=\"button\" class=\"btn btn-primary btn-sm m-2 \" style=\"width: auto; float: right;\"\r\n (click)=\"formControl.patchValue(today);d.navigateTo(today);\">\u0627\u0644\u064A\u0648\u0645</button>\r\n <button type=\"button\" class=\"btn btn-secondary btn-sm m-2\" style=\"width: auto; float: left;\"\r\n (click)=\"formControl.patchValue(null);d.close()\">\u0645\u0633\u062D</button>\r\n </ng-template>\r\n</div>", styles: [".calenderBtn{cursor:pointer;background-color:transparent;color:#6c757d;border-top-left-radius:.25rem!important;border-bottom-left-radius:.25rem!important}.calenderBtn:hover{color:#fff;background-color:#6c757d;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}\n"], directives: [{ type: i1.NgbInputDatepicker, selector: "input[ngbDatepicker]", inputs: ["autoClose", "datepickerClass", "dayTemplate", "dayTemplateData", "displayMonths", "firstDayOfWeek", "footerTemplate", "markDisabled", "minDate", "maxDate", "navigation", "outsideDays", "placement", "restoreFocus", "showWeekNumbers", "startDate", "container", "positionTarget", "weekdays", "disabled"], outputs: ["dateSelect", "navigate", "closed"], exportAs: ["ngbDatepicker"] }, { type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: HijriDatepickerComponent, decorators: [{
|
|
17
|
+
type: Component,
|
|
18
|
+
args: [{ selector: 'ipa-hijri-datepicker', providers: [
|
|
19
|
+
{ provide: NgbCalendar, useClass: NgbCalendarIslamicUmalqura },
|
|
20
|
+
{ provide: NgbDatepickerI18n, useClass: IslamicI18n },
|
|
21
|
+
], template: "<div class=\"form-floating input-group {{containerClasses}}\">\r\n <input id=\"{{id}}\"\r\n [ngClass]=\"{'is-invalid is-invalid:focus': (controlDir.control?.invalid && (controlDir.control?.dirty || controlDir.control?.touched)) && errorMsg,'is-valid is-valid:focus': (controlDir.control?.valid && (controlDir.control?.dirty || controlDir.control?.touched) && (errorMsg || controlDir.value))}\"\r\n class=\"form-control {{classes}}\" [formControl]=\"formControl\" [firstDayOfWeek]=\"7\" ngbDatepicker\r\n #d=\"ngbDatepicker\" [maxDate]=\"maxDate\" [minDate]=\"minDate\" [footerTemplate]=\"footerTemplate\"\r\n [required]=\"required\" style=\"outline: unset; z-index: unset !important;\" autocomplete=\"off\" (blur)=\"onTouched()\" title=\"{{label}}\">\r\n <label for=\"{{id}}\">{{label}}</label>\r\n <span class=\"input-group-text calenderBtn\" (click)=\"d.toggle()\">\r\n <i class=\"far fa-calendar-alt fa-lg\"></i>\r\n </span>\r\n <div class=\"invalid-feedback\" *ngIf=\"errorMessage !== null\">\r\n {{errorMsg}}\r\n </div>\r\n <ng-template #footerTemplate style=\"text-align: center;\">\r\n <hr>\r\n <button type=\"button\" class=\"btn btn-primary btn-sm m-2 \" style=\"width: auto; float: right;\"\r\n (click)=\"formControl.patchValue(today);d.navigateTo(today);\">\u0627\u0644\u064A\u0648\u0645</button>\r\n <button type=\"button\" class=\"btn btn-secondary btn-sm m-2\" style=\"width: auto; float: left;\"\r\n (click)=\"formControl.patchValue(null);d.close()\">\u0645\u0633\u062D</button>\r\n </ng-template>\r\n</div>", styles: [".calenderBtn{cursor:pointer;background-color:transparent;color:#6c757d;border-top-left-radius:.25rem!important;border-bottom-left-radius:.25rem!important}.calenderBtn:hover{color:#fff;background-color:#6c757d;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}\n"] }]
|
|
22
|
+
}] });
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGlqcmktZGF0ZXBpY2tlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1pcGEtbGlicmFyeS9zcmMvbGliL2lwYS1mb3JtL2RhdGVwaWNrZXIvaGlqcmktZGF0ZXBpY2tlci9oaWpyaS1kYXRlcGlja2VyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLWlwYS1saWJyYXJ5L3NyYy9saWIvaXBhLWZvcm0vZGF0ZXBpY2tlci9kYXRlcGlja2VyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLFdBQVcsRUFBRSwwQkFBMEIsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3hHLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzlELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7O0FBVTVDLE1BQU0sT0FBTyx3QkFBeUIsU0FBUSxtQkFBbUI7O3FIQUFwRCx3QkFBd0I7eUdBQXhCLHdCQUF3QiwrQ0FMeEI7UUFDVCxFQUFFLE9BQU8sRUFBRSxXQUFXLEVBQUUsUUFBUSxFQUFFLDBCQUEwQixFQUFFO1FBQzlELEVBQUUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQUU7S0FDdEQsaURDWEgsa21EQW9CTTsyRkRQTyx3QkFBd0I7a0JBVHBDLFNBQVM7K0JBQ0Usc0JBQXNCLGFBR3JCO3dCQUNULEVBQUUsT0FBTyxFQUFFLFdBQVcsRUFBRSxRQUFRLEVBQUUsMEJBQTBCLEVBQUU7d0JBQzlELEVBQUUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQUU7cUJBQ3REIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE5nYkNhbGVuZGFyLCBOZ2JDYWxlbmRhcklzbGFtaWNVbWFscXVyYSwgTmdiRGF0ZXBpY2tlckkxOG4gfSBmcm9tICdAbmctYm9vdHN0cmFwL25nLWJvb3RzdHJhcCc7XHJcbmltcG9ydCB7IERhdGVwaWNrZXJDb21wb25lbnQgfSBmcm9tICcuLi9kYXRlcGlja2VyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IElzbGFtaWNJMThuIH0gZnJvbSAnLi9Jc2xhbWljSTE4bic7XHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnaXBhLWhpanJpLWRhdGVwaWNrZXInLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi4vZGF0ZXBpY2tlci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4uL2RhdGVwaWNrZXIuY29tcG9uZW50LnNjc3MnXSxcclxuICBwcm92aWRlcnM6IFtcclxuICAgIHsgcHJvdmlkZTogTmdiQ2FsZW5kYXIsIHVzZUNsYXNzOiBOZ2JDYWxlbmRhcklzbGFtaWNVbWFscXVyYSB9LFxyXG4gICAgeyBwcm92aWRlOiBOZ2JEYXRlcGlja2VySTE4biwgdXNlQ2xhc3M6IElzbGFtaWNJMThuIH0sXHJcbiAgXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIEhpanJpRGF0ZXBpY2tlckNvbXBvbmVudCBleHRlbmRzIERhdGVwaWNrZXJDb21wb25lbnQge31cclxuIiwiPGRpdiBjbGFzcz1cImZvcm0tZmxvYXRpbmcgaW5wdXQtZ3JvdXAge3tjb250YWluZXJDbGFzc2VzfX1cIj5cclxuICAgIDxpbnB1dCBpZD1cInt7aWR9fVwiXHJcbiAgICAgICAgW25nQ2xhc3NdPVwieydpcy1pbnZhbGlkIGlzLWludmFsaWQ6Zm9jdXMnOiAoY29udHJvbERpci5jb250cm9sPy5pbnZhbGlkICYmIChjb250cm9sRGlyLmNvbnRyb2w/LmRpcnR5IHx8IGNvbnRyb2xEaXIuY29udHJvbD8udG91Y2hlZCkpICYmIGVycm9yTXNnLCdpcy12YWxpZCBpcy12YWxpZDpmb2N1cyc6IChjb250cm9sRGlyLmNvbnRyb2w/LnZhbGlkICYmIChjb250cm9sRGlyLmNvbnRyb2w/LmRpcnR5IHx8IGNvbnRyb2xEaXIuY29udHJvbD8udG91Y2hlZCkgICYmIChlcnJvck1zZyB8fCBjb250cm9sRGlyLnZhbHVlKSl9XCJcclxuICAgICAgICBjbGFzcz1cImZvcm0tY29udHJvbCB7e2NsYXNzZXN9fVwiIFtmb3JtQ29udHJvbF09XCJmb3JtQ29udHJvbFwiIFtmaXJzdERheU9mV2Vla109XCI3XCIgbmdiRGF0ZXBpY2tlclxyXG4gICAgICAgICNkPVwibmdiRGF0ZXBpY2tlclwiIFttYXhEYXRlXT1cIm1heERhdGVcIiBbbWluRGF0ZV09XCJtaW5EYXRlXCIgW2Zvb3RlclRlbXBsYXRlXT1cImZvb3RlclRlbXBsYXRlXCJcclxuICAgICAgICBbcmVxdWlyZWRdPVwicmVxdWlyZWRcIiBzdHlsZT1cIm91dGxpbmU6IHVuc2V0OyB6LWluZGV4OiB1bnNldCAhaW1wb3J0YW50O1wiIGF1dG9jb21wbGV0ZT1cIm9mZlwiIChibHVyKT1cIm9uVG91Y2hlZCgpXCIgdGl0bGU9XCJ7e2xhYmVsfX1cIj5cclxuICAgIDxsYWJlbCBmb3I9XCJ7e2lkfX1cIj57e2xhYmVsfX08L2xhYmVsPlxyXG4gICAgPHNwYW4gY2xhc3M9XCJpbnB1dC1ncm91cC10ZXh0IGNhbGVuZGVyQnRuXCIgKGNsaWNrKT1cImQudG9nZ2xlKClcIj5cclxuICAgICAgICA8aSBjbGFzcz1cImZhciBmYS1jYWxlbmRhci1hbHQgZmEtbGdcIj48L2k+XHJcbiAgICA8L3NwYW4+XHJcbiAgICA8ZGl2IGNsYXNzPVwiaW52YWxpZC1mZWVkYmFja1wiICpuZ0lmPVwiZXJyb3JNZXNzYWdlICE9PSBudWxsXCI+XHJcbiAgICAgICAge3tlcnJvck1zZ319XHJcbiAgICA8L2Rpdj5cclxuICAgIDxuZy10ZW1wbGF0ZSAjZm9vdGVyVGVtcGxhdGUgc3R5bGU9XCJ0ZXh0LWFsaWduOiBjZW50ZXI7XCI+XHJcbiAgICAgICAgPGhyPlxyXG4gICAgICAgIDxidXR0b24gdHlwZT1cImJ1dHRvblwiIGNsYXNzPVwiYnRuIGJ0bi1wcmltYXJ5IGJ0bi1zbSBtLTIgXCIgc3R5bGU9XCJ3aWR0aDogYXV0bzsgZmxvYXQ6IHJpZ2h0O1wiXHJcbiAgICAgICAgICAgIChjbGljayk9XCJmb3JtQ29udHJvbC5wYXRjaFZhbHVlKHRvZGF5KTtkLm5hdmlnYXRlVG8odG9kYXkpO1wiPtin2YTZitmI2YU8L2J1dHRvbj5cclxuICAgICAgICA8YnV0dG9uIHR5cGU9XCJidXR0b25cIiBjbGFzcz1cImJ0biBidG4tc2Vjb25kYXJ5IGJ0bi1zbSBtLTJcIiBzdHlsZT1cIndpZHRoOiBhdXRvOyBmbG9hdDogbGVmdDtcIlxyXG4gICAgICAgICAgICAoY2xpY2spPVwiZm9ybUNvbnRyb2wucGF0Y2hWYWx1ZShudWxsKTtkLmNsb3NlKClcIj7Zhdiz2K08L2J1dHRvbj5cclxuICAgIDwvbmctdGVtcGxhdGU+XHJcbjwvZGl2PiJdfQ==
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
import { Component, Input, Self, ViewChild, } from '@angular/core';
|
|
2
|
+
import { FormControl } 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 "@ng-select/ng-select";
|
|
7
|
+
import * as i4 from "@angular/common";
|
|
8
|
+
import * as i5 from "@angular/cdk/bidi";
|
|
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.formControl = new FormControl('');
|
|
19
|
+
this.controlDir.valueAccessor = this;
|
|
20
|
+
}
|
|
21
|
+
ngOnInit() {
|
|
22
|
+
const control = this.controlDir.control;
|
|
23
|
+
const validators = control?.validator ? [control.validator] : [];
|
|
24
|
+
control?.setValidators(validators);
|
|
25
|
+
control?.updateValueAndValidity();
|
|
26
|
+
this.formControl = control;
|
|
27
|
+
this.formControl.patchValue(null);
|
|
28
|
+
}
|
|
29
|
+
onChange(event) { }
|
|
30
|
+
onTouched() { }
|
|
31
|
+
writeValue(obj) {
|
|
32
|
+
if (this.input)
|
|
33
|
+
this.input.value = obj || '';
|
|
34
|
+
}
|
|
35
|
+
registerOnChange(fn) {
|
|
36
|
+
this.onChange = fn;
|
|
37
|
+
}
|
|
38
|
+
registerOnTouched(fn) {
|
|
39
|
+
this.onTouched = fn;
|
|
40
|
+
}
|
|
41
|
+
get errorMessage() {
|
|
42
|
+
this.errorMsg = this.validationService.getErrorMessage(this.formControl);
|
|
43
|
+
return this.errorMsg;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
DropdownInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: DropdownInputComponent, deps: [{ token: i1.IPAFormService }, { token: i2.NgControl, self: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
47
|
+
DropdownInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: DropdownInputComponent, selector: "ipa-dropdown-input", inputs: { id: "id", label: "label", items: "items", textField: "textField", valueField: "valueField", required: "required", searchable: "searchable", notFoundText: "notFoundText", classes: "classes", containerClasses: "containerClasses" }, viewQueries: [{ propertyName: "input", first: true, predicate: ["select"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"form-floating {{containerClasses}}\"\r\n [ngClass]=\"{'was-validated': (controlDir.control?.dirty || controlDir.control?.touched) && required}\">\r\n\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 <option *ngFor=\"let item of items\" [value]=\"valueField ? item[valueField] : item\">\r\n {{textField ? item[textField] : item}}</option>\r\n </select>\r\n <label for=\"{{id}}\">{{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\" [bindValue]=\"valueField\"\r\n [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': (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: [""], components: [{ type: i3.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", "typeahead", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }], directives: [{ type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i5.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }] });
|
|
48
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: DropdownInputComponent, decorators: [{
|
|
49
|
+
type: Component,
|
|
50
|
+
args: [{ selector: 'ipa-dropdown-input', template: "<div class=\"form-floating {{containerClasses}}\"\r\n [ngClass]=\"{'was-validated': (controlDir.control?.dirty || controlDir.control?.touched) && required}\">\r\n\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 <option *ngFor=\"let item of items\" [value]=\"valueField ? item[valueField] : item\">\r\n {{textField ? item[textField] : item}}</option>\r\n </select>\r\n <label for=\"{{id}}\">{{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\" [bindValue]=\"valueField\"\r\n [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': (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: [""] }]
|
|
51
|
+
}], ctorParameters: function () { return [{ type: i1.IPAFormService }, { type: i2.NgControl, decorators: [{
|
|
52
|
+
type: Self
|
|
53
|
+
}] }]; }, propDecorators: { input: [{
|
|
54
|
+
type: ViewChild,
|
|
55
|
+
args: ['select', { static: true }]
|
|
56
|
+
}], id: [{
|
|
57
|
+
type: Input
|
|
58
|
+
}], label: [{
|
|
59
|
+
type: Input
|
|
60
|
+
}], items: [{
|
|
61
|
+
type: Input
|
|
62
|
+
}], textField: [{
|
|
63
|
+
type: Input
|
|
64
|
+
}], valueField: [{
|
|
65
|
+
type: Input
|
|
66
|
+
}], required: [{
|
|
67
|
+
type: Input
|
|
68
|
+
}], searchable: [{
|
|
69
|
+
type: Input
|
|
70
|
+
}], notFoundText: [{
|
|
71
|
+
type: Input
|
|
72
|
+
}], classes: [{
|
|
73
|
+
type: Input
|
|
74
|
+
}], containerClasses: [{
|
|
75
|
+
type: Input
|
|
76
|
+
}] } });
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24taW5wdXQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctaXBhLWxpYnJhcnkvc3JjL2xpYi9pcGEtZm9ybS9kcm9wZG93bi1pbnB1dC9kcm9wZG93bi1pbnB1dC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1pcGEtbGlicmFyeS9zcmMvbGliL2lwYS1mb3JtL2Ryb3Bkb3duLWlucHV0L2Ryb3Bkb3duLWlucHV0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBRVQsS0FBSyxFQUVMLElBQUksRUFDSixTQUFTLEdBQ1YsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFdBQVcsRUFBYSxNQUFNLGdCQUFnQixDQUFDOzs7Ozs7O0FBUXhELE1BQU0sT0FBTyxzQkFBc0I7SUFlakMsWUFDVSxpQkFBaUMsRUFDMUIsVUFBcUI7UUFENUIsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFnQjtRQUMxQixlQUFVLEdBQVYsVUFBVSxDQUFXO1FBZDdCLFVBQUssR0FBVyxZQUFZLENBQUM7UUFDN0IsVUFBSyxHQUFVLEVBQUUsQ0FBQztRQUdsQixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLGVBQVUsR0FBRyxLQUFLLENBQUM7UUFDbkIsaUJBQVksR0FBRyxnQkFBZ0IsQ0FBQztRQUd6QyxnQkFBVyxHQUFnQixJQUFJLFdBQVcsQ0FBQyxFQUFFLENBQUMsQ0FBQztRQU83QyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUM7SUFDdkMsQ0FBQztJQUVELFFBQVE7UUFDTixNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQztRQUN4QyxNQUFNLFVBQVUsR0FBRyxPQUFPLEVBQUUsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBRWpFLE9BQU8sRUFBRSxhQUFhLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDbkMsT0FBTyxFQUFFLHNCQUFzQixFQUFFLENBQUM7UUFDbEMsSUFBSSxDQUFDLFdBQVcsR0FBRyxPQUFzQixDQUFDO1FBQzFDLElBQUksQ0FBQyxXQUFXLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFRCxRQUFRLENBQUMsS0FBVSxJQUFTLENBQUM7SUFFN0IsU0FBUyxLQUFVLENBQUM7SUFDcEIsVUFBVSxDQUFDLEdBQVE7UUFDakIsSUFBSSxJQUFJLENBQUMsS0FBSztZQUFFLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxHQUFHLEdBQUcsSUFBSSxFQUFFLENBQUM7SUFDL0MsQ0FBQztJQUVELGdCQUFnQixDQUFDLEVBQU87UUFDdEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQU87UUFDdkIsSUFBSSxDQUFDLFNBQVMsR0FBRyxFQUFFLENBQUM7SUFDdEIsQ0FBQztJQUVELElBQUksWUFBWTtRQUNkLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDekUsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDO0lBQ3ZCLENBQUM7O21IQWxEVSxzQkFBc0I7dUdBQXRCLHNCQUFzQix5WkNoQm5DLCswQ0FxQk07MkZETE8sc0JBQXNCO2tCQUxsQyxTQUFTOytCQUNFLG9CQUFvQjs7MEJBcUIzQixJQUFJOzRDQWhCZ0MsS0FBSztzQkFBM0MsU0FBUzt1QkFBQyxRQUFRLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFO2dCQUM1QixFQUFFO3NCQUFWLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLGdCQUFnQjtzQkFBeEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50LFxyXG4gIEVsZW1lbnRSZWYsXHJcbiAgSW5wdXQsXHJcbiAgT25Jbml0LFxyXG4gIFNlbGYsXHJcbiAgVmlld0NoaWxkLFxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBGb3JtQ29udHJvbCwgTmdDb250cm9sIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBJUEFGb3JtU2VydmljZSB9IGZyb20gJy4uL2lwYS1mb3JtLnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdpcGEtZHJvcGRvd24taW5wdXQnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9kcm9wZG93bi1pbnB1dC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vZHJvcGRvd24taW5wdXQuY29tcG9uZW50LnNjc3MnXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIERyb3Bkb3duSW5wdXRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIEBWaWV3Q2hpbGQoJ3NlbGVjdCcsIHsgc3RhdGljOiB0cnVlIH0pIGlucHV0ITogSFRNTFNlbGVjdEVsZW1lbnQ7XHJcbiAgQElucHV0KCkgaWQhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgbGFiZWw6IHN0cmluZyA9ICd0ZXh0IGlucHV0JztcclxuICBASW5wdXQoKSBpdGVtczogYW55W10gPSBbXTtcclxuICBASW5wdXQoKSB0ZXh0RmllbGQhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgdmFsdWVGaWVsZCE6IHN0cmluZztcclxuICBASW5wdXQoKSByZXF1aXJlZCA9IGZhbHNlO1xyXG4gIEBJbnB1dCgpIHNlYXJjaGFibGUgPSBmYWxzZTtcclxuICBASW5wdXQoKSBub3RGb3VuZFRleHQgPSAn2YTYpyDZitmI2KzYryDYqNmK2KfZhtin2KonO1xyXG4gIEBJbnB1dCgpIGNsYXNzZXMhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgY29udGFpbmVyQ2xhc3NlcyE6IHN0cmluZztcclxuICBmb3JtQ29udHJvbDogRm9ybUNvbnRyb2wgPSBuZXcgRm9ybUNvbnRyb2woJycpO1xyXG4gIGVycm9yTXNnITogc3RyaW5nIHwgbnVsbDtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIHZhbGlkYXRpb25TZXJ2aWNlOiBJUEFGb3JtU2VydmljZSxcclxuICAgIEBTZWxmKCkgcHVibGljIGNvbnRyb2xEaXI6IE5nQ29udHJvbFxyXG4gICkge1xyXG4gICAgdGhpcy5jb250cm9sRGlyLnZhbHVlQWNjZXNzb3IgPSB0aGlzO1xyXG4gIH1cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICBjb25zdCBjb250cm9sID0gdGhpcy5jb250cm9sRGlyLmNvbnRyb2w7XHJcbiAgICBjb25zdCB2YWxpZGF0b3JzID0gY29udHJvbD8udmFsaWRhdG9yID8gW2NvbnRyb2wudmFsaWRhdG9yXSA6IFtdO1xyXG5cclxuICAgIGNvbnRyb2w/LnNldFZhbGlkYXRvcnModmFsaWRhdG9ycyk7XHJcbiAgICBjb250cm9sPy51cGRhdGVWYWx1ZUFuZFZhbGlkaXR5KCk7XHJcbiAgICB0aGlzLmZvcm1Db250cm9sID0gY29udHJvbCBhcyBGb3JtQ29udHJvbDtcclxuICAgIHRoaXMuZm9ybUNvbnRyb2wucGF0Y2hWYWx1ZShudWxsKTtcclxuICB9XHJcblxyXG4gIG9uQ2hhbmdlKGV2ZW50OiBhbnkpOiB2b2lkIHt9XHJcblxyXG4gIG9uVG91Y2hlZCgpOiB2b2lkIHt9XHJcbiAgd3JpdGVWYWx1ZShvYmo6IGFueSk6IHZvaWQge1xyXG4gICAgaWYgKHRoaXMuaW5wdXQpIHRoaXMuaW5wdXQudmFsdWUgPSBvYmogfHwgJyc7XHJcbiAgfVxyXG5cclxuICByZWdpc3Rlck9uQ2hhbmdlKGZuOiBhbnkpOiB2b2lkIHtcclxuICAgIHRoaXMub25DaGFuZ2UgPSBmbjtcclxuICB9XHJcblxyXG4gIHJlZ2lzdGVyT25Ub3VjaGVkKGZuOiBhbnkpOiB2b2lkIHtcclxuICAgIHRoaXMub25Ub3VjaGVkID0gZm47XHJcbiAgfVxyXG5cclxuICBnZXQgZXJyb3JNZXNzYWdlKCk6IHN0cmluZyB8IG51bGwge1xyXG4gICAgdGhpcy5lcnJvck1zZyA9IHRoaXMudmFsaWRhdGlvblNlcnZpY2UuZ2V0RXJyb3JNZXNzYWdlKHRoaXMuZm9ybUNvbnRyb2wpO1xyXG4gICAgcmV0dXJuIHRoaXMuZXJyb3JNc2c7XHJcbiAgfVxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJmb3JtLWZsb2F0aW5nIHt7Y29udGFpbmVyQ2xhc3Nlc319XCJcclxuICBbbmdDbGFzc109XCJ7J3dhcy12YWxpZGF0ZWQnOiAoY29udHJvbERpci5jb250cm9sPy5kaXJ0eSB8fCBjb250cm9sRGlyLmNvbnRyb2w/LnRvdWNoZWQpICYmIHJlcXVpcmVkfVwiPlxyXG5cclxuICA8IS0tIHNlYXJjaGFibGUgaXMgZmFsc2UgLS0+XHJcbiAgPG5nLWNvbnRhaW5lciAqbmdJZj1cIiFzZWFyY2hhYmxlXCI+XHJcbiAgICA8c2VsZWN0ICNzZWxlY3QgaWQ9XCJ7e2lkfX1cIiBjbGFzcz1cImZvcm0tc2VsZWN0IHt7Y2xhc3Nlc319XCIgW3JlcXVpcmVkXT1cInJlcXVpcmVkXCIgW2Zvcm1Db250cm9sXT1cImZvcm1Db250cm9sXCI+XHJcbiAgICAgIDxvcHRpb24gKm5nRm9yPVwibGV0IGl0ZW0gb2YgaXRlbXNcIiBbdmFsdWVdPVwidmFsdWVGaWVsZCA/IGl0ZW1bdmFsdWVGaWVsZF0gOiBpdGVtXCI+XHJcbiAgICAgICAge3t0ZXh0RmllbGQgPyBpdGVtW3RleHRGaWVsZF0gOiBpdGVtfX08L29wdGlvbj5cclxuICAgIDwvc2VsZWN0PlxyXG4gICAgPGxhYmVsIGZvcj1cInt7aWR9fVwiPnt7bGFiZWx9fTwvbGFiZWw+XHJcbiAgPC9uZy1jb250YWluZXI+XHJcblxyXG4gIDwhLS0gc2VhcmNoYWJsZSBpcyB0cnVlIC0tPlxyXG4gIDxuZy1zZWxlY3QgKm5nSWY9XCJzZWFyY2hhYmxlXCIgI3NlbGVjdCBkaXI9XCJydGxcIiBjbGFzcz1cInt7Y2xhc3Nlc319XCIgW2Zvcm1Db250cm9sXT1cImZvcm1Db250cm9sXCIgW2l0ZW1zXT1cIml0ZW1zXCJcclxuICAgIFtwbGFjZWhvbGRlcl09XCJsYWJlbFwiIFtub3RGb3VuZFRleHRdPVwibm90Rm91bmRUZXh0XCIgW3JlcXVpcmVkXT1cInJlcXVpcmVkXCIgW2JpbmRWYWx1ZV09XCJ2YWx1ZUZpZWxkXCJcclxuICAgIFtiaW5kTGFiZWxdPVwidGV4dEZpZWxkXCJcclxuICAgIFtuZ0NsYXNzXT1cInsnaXMtaW52YWxpZCBpcy1pbnZhbGlkOmZvY3VzJzogKGNvbnRyb2xEaXIuY29udHJvbD8uaW52YWxpZCAmJiAoY29udHJvbERpci5jb250cm9sPy5kaXJ0eSB8fCBjb250cm9sRGlyLmNvbnRyb2w/LnRvdWNoZWQpKSAmJiBlcnJvck1zZywnaXMtdmFsaWQgaXMtdmFsaWQ6Zm9jdXMnOiAoY29udHJvbERpci5jb250cm9sPy52YWxpZCAmJiAoY29udHJvbERpci5jb250cm9sPy5kaXJ0eSB8fCBjb250cm9sRGlyLmNvbnRyb2w/LnRvdWNoZWQpICAmJiAoZXJyb3JNc2cgfHwgY29udHJvbERpci52YWx1ZSkpfVwiPlxyXG4gIDwvbmctc2VsZWN0PlxyXG4gIDxkaXYgY2xhc3M9XCJpbnZhbGlkLWZlZWRiYWNrXCIgKm5nSWY9XCJlcnJvck1lc3NhZ2UgIT09IG51bGxcIj5cclxuICAgIHt7ZXJyb3JNc2d9fVxyXG4gIDwvZGl2PlxyXG48L2Rpdj4iXX0=
|
|
@@ -88,15 +88,11 @@ export class FileUploadComponent {
|
|
|
88
88
|
this.fileDeleted.emit();
|
|
89
89
|
}
|
|
90
90
|
}
|
|
91
|
-
FileUploadComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
92
|
-
FileUploadComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "
|
|
93
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
91
|
+
FileUploadComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: FileUploadComponent, deps: [{ token: i1.ToastrService }], target: i0.ɵɵFactoryTarget.Component });
|
|
92
|
+
FileUploadComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: FileUploadComponent, selector: "ipa-file-upload", inputs: { 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=\"required\">*</span>\r\n </div>\r\n <hr>\r\n <span style=\"font-size: 12px;\">\u0642\u0645 \u0628\u0633\u062D\u0628 \u0627\u0644\u0645\u0644\u0641 \u0623\u0648 \u0627\u0636\u063A\u0637 \u0647\u0646\u0627</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 \u0627\u0644\u0635\u064A\u063A\u0629 \u0627\u0644\u0645\u0633\u0645\u0648\u062D \u0628\u0647\u0627:\r\n <span class=\"extensions\">{{ acceptedFiles }}</span>\r\n </div>\r\n <div class=\"allowed-extensions\">\r\n \u0627\u0642\u0635\u0649 \u062D\u062C\u0645 \u0644\u0644\u0645\u0631\u0641\u0642:\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}.required{color:#dc3545;font-size:20px}\n"], directives: [{ type: i2.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"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
|
|
93
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: FileUploadComponent, decorators: [{
|
|
94
94
|
type: Component,
|
|
95
|
-
args: [{
|
|
96
|
-
selector: 'ipa-file-upload',
|
|
97
|
-
templateUrl: './file-upload.component.html',
|
|
98
|
-
styleUrls: ['./file-upload.component.scss']
|
|
99
|
-
}]
|
|
95
|
+
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=\"required\">*</span>\r\n </div>\r\n <hr>\r\n <span style=\"font-size: 12px;\">\u0642\u0645 \u0628\u0633\u062D\u0628 \u0627\u0644\u0645\u0644\u0641 \u0623\u0648 \u0627\u0636\u063A\u0637 \u0647\u0646\u0627</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 \u0627\u0644\u0635\u064A\u063A\u0629 \u0627\u0644\u0645\u0633\u0645\u0648\u062D \u0628\u0647\u0627:\r\n <span class=\"extensions\">{{ acceptedFiles }}</span>\r\n </div>\r\n <div class=\"allowed-extensions\">\r\n \u0627\u0642\u0635\u0649 \u062D\u062C\u0645 \u0644\u0644\u0645\u0631\u0641\u0642:\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}.required{color:#dc3545;font-size:20px}\n"] }]
|
|
100
96
|
}], ctorParameters: function () { return [{ type: i1.ToastrService }]; }, propDecorators: { dropzoneDir: [{
|
|
101
97
|
type: ViewChild,
|
|
102
98
|
args: [DropzoneDirective, { static: false }]
|
|
@@ -125,4 +121,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.9", ngImpor
|
|
|
125
121
|
}], fileDeleted: [{
|
|
126
122
|
type: Output
|
|
127
123
|
}] } });
|
|
128
|
-
//# 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 { Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { ToastrService } from 'ngx-toastr';\r\nimport { DropzoneConfigInterface, DropzoneDirective } from 'ngx-dropzone-wrapper';\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() 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\r\n  constructor(\r\n    // private authService: AuthService,\r\n    private toastrService: ToastrService\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.label = 'رفع ' + 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: 'صيغة الملف غير مسموح بها',\r\n      dictFileTooBig: 'الحجم تجاوز الحد المسموح',\r\n      dictMaxFilesExceeded:\r\n        'الرجاء حذف الملفات الموجودة حاليا لتتمكن من رفع هذا الملف',\r\n      acceptedFiles: this.acceptedFiles,\r\n      autoProcessQueue: this.autoUpload,\r\n      previewTemplate: '<span></span>',\r\n    };\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\r\n    this.toastrService.success('تم تحميل المرفقات بنجاح');\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","<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=\"required\">*</span>\r\n            </div>\r\n            <hr>\r\n            <span style=\"font-size: 12px;\">قم بسحب الملف أو اضغط هنا</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            الصيغة المسموح بها:\r\n            <span class=\"extensions\">{{ acceptedFiles }}</span>\r\n        </div>\r\n        <div class=\"allowed-extensions\">\r\n            اقصى حجم للمرفق:\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>"]}
|
|
124
|
+
//# 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 { Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { ToastrService } from 'ngx-toastr';\r\nimport { DropzoneConfigInterface, DropzoneDirective } from 'ngx-dropzone-wrapper';\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() 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\r\n  constructor(\r\n    // private authService: AuthService,\r\n    private toastrService: ToastrService\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.label = 'رفع ' + 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: 'صيغة الملف غير مسموح بها',\r\n      dictFileTooBig: 'الحجم تجاوز الحد المسموح',\r\n      dictMaxFilesExceeded:\r\n        'الرجاء حذف الملفات الموجودة حاليا لتتمكن من رفع هذا الملف',\r\n      acceptedFiles: this.acceptedFiles,\r\n      autoProcessQueue: this.autoUpload,\r\n      previewTemplate: '<span></span>',\r\n    };\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\r\n    this.toastrService.success('تم تحميل المرفقات بنجاح');\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","<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=\"required\">*</span>\r\n            </div>\r\n            <hr>\r\n            <span style=\"font-size: 12px;\">قم بسحب الملف أو اضغط هنا</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            الصيغة المسموح بها:\r\n            <span class=\"extensions\">{{ acceptedFiles }}</span>\r\n        </div>\r\n        <div class=\"allowed-extensions\">\r\n            اقصى حجم للمرفق:\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>"]}
|
|
@@ -0,0 +1,254 @@
|
|
|
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
|
+
getErrorMessage(control, patternErrorMsg = '') {
|
|
53
|
+
for (const propertyName in control?.errors) {
|
|
54
|
+
if (control?.errors.hasOwnProperty(propertyName) &&
|
|
55
|
+
(control.touched || control.dirty)) {
|
|
56
|
+
return this.getValidatorErrorMessage(propertyName, control.errors[propertyName], patternErrorMsg);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
return null;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* convert gregorian date to hijri date (Based on Umm al-Qura calculations).
|
|
63
|
+
* @param date: gregorian date
|
|
64
|
+
* @param format: iDD => day: ١٥, iMM => month: ٠٤, iMMM => month: ربيع ٢,
|
|
65
|
+
* iMMMM => ربيع الثاني, iYY => year: ٤٢, iYYYY => year: ١٤٤٢,
|
|
66
|
+
* dd => ن, ddd => إثنين, dddd => الإثنين
|
|
67
|
+
* @example 'iYYYY/iM/iDهـ الموافق YYYY/M/Dم'
|
|
68
|
+
* '١٤٤٢/٠٤/١٥هـ الموافق ٢٠٢٠/١١/٣٠'
|
|
69
|
+
*/
|
|
70
|
+
convertToHijriDate(date, format = 'iYYYY-iMM-iDD', lang = 'ar-SA') {
|
|
71
|
+
momentHijri.locale(lang);
|
|
72
|
+
return momentHijri(date).format(format);
|
|
73
|
+
}
|
|
74
|
+
convertToGregorianDate(date, format = 'YYYY-MM-DD', lang = 'en') {
|
|
75
|
+
momentHijri.locale(lang);
|
|
76
|
+
const m = momentHijri.iConvert.toGregorian(date.year(), date.month(), date.date());
|
|
77
|
+
return momentHijri(new Date(m.gy, m.gm, m.gd)).format(format);
|
|
78
|
+
}
|
|
79
|
+
getCurrentHijriDate() {
|
|
80
|
+
momentHijri.locale('en');
|
|
81
|
+
return momentHijri().format('iYYYY/iMM/iDD');
|
|
82
|
+
}
|
|
83
|
+
getValidatorErrorMessage(validatorName, validatorValue, patternErrorMsg) {
|
|
84
|
+
if (validatorName === 'pattern') {
|
|
85
|
+
validatorValue = this.addPatternMsg(validatorValue, patternErrorMsg);
|
|
86
|
+
}
|
|
87
|
+
const config = {
|
|
88
|
+
required: 'هذا الحقل مطلوب',
|
|
89
|
+
pattern: `${validatorValue.message}`,
|
|
90
|
+
Email: 'خطأ في البريد الالكتروني (example@ipa.edu.sa)',
|
|
91
|
+
maxlength: `تجاوز عدد الحقل المسموح بها (${validatorValue.requiredLength}) حرف`,
|
|
92
|
+
minlength: `على الأقل عدد ${validatorValue.requiredLength} حرف.`,
|
|
93
|
+
min: `رقم اكبر من أو يساوي ${validatorValue.min}`,
|
|
94
|
+
max: `رقم اصغر من أو يساوي ${validatorValue.max}`,
|
|
95
|
+
ngbDate: this.getNgbDatepickerErrorMsg(validatorValue),
|
|
96
|
+
checkId: 'رقم الهوية أو الاقامة غير صحيح',
|
|
97
|
+
link: 'الرابط غير صحيح (http://google.com)',
|
|
98
|
+
linkMP4: 'الرابط غير صحيح (http://example.com/a.mp4)',
|
|
99
|
+
mobileNo: 'خطأ في رقم الجوال (05xxxxxxxx)',
|
|
100
|
+
};
|
|
101
|
+
return config[validatorName];
|
|
102
|
+
}
|
|
103
|
+
addPatternMsg(validatorValue, patternErrorMsg) {
|
|
104
|
+
let pattern = {
|
|
105
|
+
...validatorValue,
|
|
106
|
+
message: patternErrorMsg,
|
|
107
|
+
};
|
|
108
|
+
return pattern;
|
|
109
|
+
}
|
|
110
|
+
getNgbDatepickerErrorMsg(validatorValue) {
|
|
111
|
+
let msg = '';
|
|
112
|
+
if (validatorValue.maxDate) {
|
|
113
|
+
msg = `التاريخ المدخل "${this.parserFormatter.format(validatorValue.maxDate.actual)}" اكبر من تاريخ اليوم "${this.parserFormatter.format(validatorValue.maxDate.maxDate)}"`;
|
|
114
|
+
}
|
|
115
|
+
else if (validatorValue.minDate) {
|
|
116
|
+
msg = `التاريخ المدخل "${this.parserFormatter.format(validatorValue.minDate.actual)}" يجب ان يكون اكبر من أو يساوي تاريخ البداية "${this.parserFormatter.format(validatorValue.minDate.minDate)}"`;
|
|
117
|
+
}
|
|
118
|
+
else if (validatorValue.invalid) {
|
|
119
|
+
msg = `التاريخ المدخل غير صحيح ${validatorValue.invalid}.`;
|
|
120
|
+
}
|
|
121
|
+
return msg;
|
|
122
|
+
}
|
|
123
|
+
static convertToEn(value) {
|
|
124
|
+
let newValue = '';
|
|
125
|
+
for (let i = 0; i < value.length; i++) {
|
|
126
|
+
let ch = value.charCodeAt(i);
|
|
127
|
+
if (ch >= 1584 && ch <= 1650) {
|
|
128
|
+
let newChar = ch - 1584;
|
|
129
|
+
newValue = newValue + String.fromCharCode(newChar);
|
|
130
|
+
}
|
|
131
|
+
else {
|
|
132
|
+
newValue = newValue + String.fromCharCode(ch);
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
return newValue;
|
|
136
|
+
}
|
|
137
|
+
static nationalIdValidate(civilId) {
|
|
138
|
+
if (civilId) {
|
|
139
|
+
let strID = this.convertToEn(civilId);
|
|
140
|
+
let digits = '';
|
|
141
|
+
let counter = 0;
|
|
142
|
+
while (counter < 9) {
|
|
143
|
+
if ((counter + 1) % 2 == 0) {
|
|
144
|
+
digits = digits + strID.substring(counter, counter + 1);
|
|
145
|
+
}
|
|
146
|
+
else {
|
|
147
|
+
digits =
|
|
148
|
+
digits + (+strID.substring(counter, counter + 1) * 2).toString();
|
|
149
|
+
}
|
|
150
|
+
counter++;
|
|
151
|
+
}
|
|
152
|
+
let intSum = 0;
|
|
153
|
+
let intSumTemp = 0;
|
|
154
|
+
let strSum;
|
|
155
|
+
let intOddSumDigit;
|
|
156
|
+
let CheckDigit;
|
|
157
|
+
counter = 0;
|
|
158
|
+
while (counter < digits.length) {
|
|
159
|
+
intSumTemp = +digits.charAt(counter) * 1;
|
|
160
|
+
intSum += intSumTemp;
|
|
161
|
+
counter++;
|
|
162
|
+
}
|
|
163
|
+
strSum = intSum.toString();
|
|
164
|
+
if (strSum.length == 1) {
|
|
165
|
+
intOddSumDigit = intSum;
|
|
166
|
+
}
|
|
167
|
+
else {
|
|
168
|
+
intOddSumDigit = strSum.substring(strSum.length, strSum.length - 1);
|
|
169
|
+
}
|
|
170
|
+
if (intOddSumDigit == 0) {
|
|
171
|
+
CheckDigit = 0;
|
|
172
|
+
}
|
|
173
|
+
else {
|
|
174
|
+
CheckDigit = (10 - +intOddSumDigit).toString();
|
|
175
|
+
}
|
|
176
|
+
let PublicID = this.convertToEn(civilId);
|
|
177
|
+
if (CheckDigit ==
|
|
178
|
+
PublicID.substring(PublicID.length - 1, PublicID.length) &&
|
|
179
|
+
strID.length == 10 &&
|
|
180
|
+
strID.substring(0, 1) == '1') {
|
|
181
|
+
return true;
|
|
182
|
+
}
|
|
183
|
+
else {
|
|
184
|
+
return false;
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
else {
|
|
188
|
+
return false;
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
static iqamaIdValidate(civilId) {
|
|
192
|
+
if (civilId) {
|
|
193
|
+
let strID = this.convertToEn(civilId);
|
|
194
|
+
let digits = '';
|
|
195
|
+
let counter = 0;
|
|
196
|
+
while (counter < 9) {
|
|
197
|
+
if ((counter + 1) % 2 == 0) {
|
|
198
|
+
digits = digits + strID.substring(counter, counter + 1);
|
|
199
|
+
}
|
|
200
|
+
else {
|
|
201
|
+
digits =
|
|
202
|
+
digits + (+strID.substring(counter, counter + 1) * 2).toString();
|
|
203
|
+
}
|
|
204
|
+
counter++;
|
|
205
|
+
}
|
|
206
|
+
let intSum = 0;
|
|
207
|
+
let intSumTemp = 0;
|
|
208
|
+
let strSum;
|
|
209
|
+
let intOddSumDigit;
|
|
210
|
+
let CheckDigit;
|
|
211
|
+
counter = 0;
|
|
212
|
+
while (counter < digits.length) {
|
|
213
|
+
intSumTemp = +digits.charAt(counter) * 1;
|
|
214
|
+
intSum += intSumTemp;
|
|
215
|
+
counter++;
|
|
216
|
+
}
|
|
217
|
+
strSum = intSum.toString();
|
|
218
|
+
if (strSum.length == 1) {
|
|
219
|
+
intOddSumDigit = intSum;
|
|
220
|
+
}
|
|
221
|
+
else {
|
|
222
|
+
intOddSumDigit = strSum.substring(strSum.length, strSum.length - 1);
|
|
223
|
+
}
|
|
224
|
+
if (intOddSumDigit == 0) {
|
|
225
|
+
CheckDigit = 0;
|
|
226
|
+
}
|
|
227
|
+
else {
|
|
228
|
+
CheckDigit = (10 - +intOddSumDigit).toString();
|
|
229
|
+
}
|
|
230
|
+
let PublicID = this.convertToEn(civilId);
|
|
231
|
+
if (CheckDigit ==
|
|
232
|
+
PublicID.substring(PublicID.length - 1, PublicID.length) &&
|
|
233
|
+
strID.length == 10 &&
|
|
234
|
+
strID.substring(0, 1) == '2') {
|
|
235
|
+
return true;
|
|
236
|
+
}
|
|
237
|
+
else {
|
|
238
|
+
return false;
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
else {
|
|
242
|
+
return false;
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
IPAFormService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: IPAFormService, deps: [{ token: i1.NgbDateParserFormatter }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
247
|
+
IPAFormService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: IPAFormService, providedIn: 'root' });
|
|
248
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: IPAFormService, decorators: [{
|
|
249
|
+
type: Injectable,
|
|
250
|
+
args: [{
|
|
251
|
+
providedIn: 'root',
|
|
252
|
+
}]
|
|
253
|
+
}], ctorParameters: function () { return [{ type: i1.NgbDateParserFormatter }]; } });
|
|
254
|
+
//# 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, FormControl, ValidationErrors } from '@angular/forms';\r\nimport momentHijri from 'moment-hijri';\r\nimport { Moment } from 'moment';\r\nimport { 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  getErrorMessage(control: FormControl, patternErrorMsg = ''): 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        );\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  ): string {\r\n    if (validatorName === 'pattern') {\r\n      validatorValue = this.addPatternMsg(validatorValue, patternErrorMsg);\r\n    }\r\n    const config: any = {\r\n      required: 'هذا الحقل مطلوب',\r\n      pattern: `${validatorValue.message}`,\r\n      Email: 'خطأ في البريد الالكتروني (example@ipa.edu.sa)',\r\n      maxlength: `تجاوز عدد الحقل المسموح بها (${validatorValue.requiredLength}) حرف`,\r\n      minlength: `على الأقل عدد ${validatorValue.requiredLength} حرف.`,\r\n      min: `رقم اكبر من أو يساوي ${validatorValue.min}`,\r\n      max: `رقم اصغر من أو يساوي ${validatorValue.max}`,\r\n      ngbDate: this.getNgbDatepickerErrorMsg(validatorValue),\r\n      checkId: 'رقم الهوية أو الاقامة غير صحيح',\r\n      link: 'الرابط غير صحيح (http://google.com)',\r\n      linkMP4: 'الرابط غير صحيح (http://example.com/a.mp4)',\r\n      mobileNo: 'خطأ في رقم الجوال (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 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"]}
|