jconsumer-shared 0.0.3 → 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/esm2022/lib/account-service.mjs +156 -7
- package/esm2022/lib/auth-service.mjs +9 -1
- package/esm2022/lib/booking-service.mjs +480 -0
- package/esm2022/lib/common.service.mjs +155 -5
- package/esm2022/lib/confirm/confirm-box.component.mjs +159 -0
- package/esm2022/lib/confirm/confirm-box.module.mjs +62 -0
- package/esm2022/lib/consumer-service.mjs +780 -0
- package/esm2022/lib/currency-service.mjs +12 -0
- package/esm2022/lib/environment.service.mjs +23 -0
- package/esm2022/lib/error-message.module.mjs +23 -0
- package/esm2022/lib/file-service.mjs +23 -17
- package/esm2022/lib/form-message/field-error-display/field-error-display.component.mjs +21 -0
- package/esm2022/lib/form-message/form-message-display.module.mjs +35 -0
- package/esm2022/lib/form-message/form-message-display.service.mjs +44 -0
- package/esm2022/lib/form-message/form-success-display/form-success-display.component.mjs +18 -0
- package/esm2022/lib/injector-resolver.mjs +28 -0
- package/esm2022/lib/media-service.mjs +49 -0
- package/esm2022/lib/order.service.mjs +16 -1
- package/esm2022/lib/payment/modes/payment-modes.component.mjs +35 -0
- package/esm2022/lib/payment/modes/payment-modes.module.mjs +24 -0
- package/esm2022/lib/payment/payment.module.mjs +26 -0
- package/esm2022/lib/paytm.service.mjs +131 -0
- package/esm2022/lib/phone-input/phone-input.component.mjs +48 -44
- package/esm2022/lib/pipes/autolink/autolink.module.mjs +20 -0
- package/esm2022/lib/pipes/date-format/date-format.module.mjs +19 -0
- package/esm2022/lib/pipes/date-format/date-format.pipe.mjs +42 -0
- package/esm2022/lib/project-constants.mjs +310 -0
- package/esm2022/lib/questionaire/edit/questionnaire.component.mjs +20 -15
- package/esm2022/lib/questionaire/edit/questionnaire.module.mjs +5 -4
- package/esm2022/lib/razorpay.service.mjs +157 -0
- package/esm2022/lib/request-dialog/request-dialog.component.mjs +29 -0
- package/esm2022/lib/request-dialog/request-dialog.module.mjs +24 -0
- package/esm2022/lib/shared-account.guard.mjs +41 -0
- package/esm2022/lib/shared-account.resolver.mjs +22 -0
- package/esm2022/lib/shared.service.mjs +85 -10
- package/esm2022/lib/showuploadfile/showuploadfile.component.mjs +3 -3
- package/esm2022/lib/theme.service.mjs +30 -0
- package/esm2022/lib/timezone-converter.mjs +49 -0
- package/esm2022/lib/toast.service.mjs +2 -2
- package/esm2022/lib/twilio-service.mjs +466 -0
- package/esm2022/public-api.mjs +32 -1
- package/fesm2022/jconsumer-shared.mjs +3852 -398
- package/fesm2022/jconsumer-shared.mjs.map +1 -1
- package/jconsumer-shared-1.0.0.tgz +0 -0
- package/lib/account-service.d.ts +41 -2
- package/lib/auth-service.d.ts +1 -0
- package/lib/booking-service.d.ts +101 -0
- package/lib/common.service.d.ts +12 -1
- package/lib/confirm/confirm-box.component.d.ts +43 -0
- package/lib/confirm/confirm-box.module.d.ts +16 -0
- package/lib/consumer-service.d.ts +178 -0
- package/lib/currency-service.d.ts +4 -0
- package/lib/environment.service.d.ts +9 -0
- package/lib/error-message.module.d.ts +7 -0
- package/lib/file-service.d.ts +5 -2
- package/lib/form-message/field-error-display/field-error-display.component.d.ts +8 -0
- package/lib/form-message/form-message-display.module.d.ts +10 -0
- package/lib/form-message/form-message-display.service.d.ts +13 -0
- package/lib/form-message/form-success-display/form-success-display.component.d.ts +7 -0
- package/lib/injector-resolver.d.ts +2 -0
- package/lib/media-service.d.ts +9 -0
- package/lib/order.service.d.ts +4 -0
- package/lib/payment/modes/payment-modes.component.d.ts +15 -0
- package/lib/payment/modes/payment-modes.module.d.ts +9 -0
- package/lib/payment/payment.module.d.ts +7 -0
- package/lib/paytm.service.d.ts +13 -0
- package/lib/phone-input/phone-input.component.d.ts +5 -3
- package/lib/pipes/autolink/autolink.module.d.ts +8 -0
- package/lib/pipes/date-format/date-format.module.d.ts +8 -0
- package/lib/pipes/date-format/date-format.pipe.d.ts +12 -0
- package/lib/project-constants.d.ts +227 -0
- package/lib/questionaire/edit/questionnaire.component.d.ts +4 -1
- package/lib/questionaire/edit/questionnaire.module.d.ts +3 -2
- package/lib/razorpay.service.d.ts +26 -0
- package/lib/request-dialog/request-dialog.component.d.ts +11 -0
- package/lib/request-dialog/request-dialog.module.d.ts +9 -0
- package/lib/shared-account.guard.d.ts +11 -0
- package/lib/shared-account.resolver.d.ts +10 -0
- package/lib/shared.service.d.ts +31 -4
- package/lib/theme.service.d.ts +10 -0
- package/lib/timezone-converter.d.ts +8 -0
- package/lib/twilio-service.d.ts +60 -0
- package/package.json +1 -1
- package/public-api.d.ts +31 -0
- package/jconsumer-shared-0.0.3.tgz +0 -0
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../../shared.service";
|
|
4
|
+
import * as i2 from "@angular/common";
|
|
5
|
+
import * as i3 from "@angular/material/radio";
|
|
6
|
+
export class PaymentModesComponent {
|
|
7
|
+
sharedService;
|
|
8
|
+
cashPay;
|
|
9
|
+
paymentModes;
|
|
10
|
+
modeSelected = new EventEmitter();
|
|
11
|
+
constructor(sharedService) {
|
|
12
|
+
this.sharedService = sharedService;
|
|
13
|
+
}
|
|
14
|
+
ngOnInit() {
|
|
15
|
+
}
|
|
16
|
+
getImageSrc(mode) {
|
|
17
|
+
return this.sharedService.getCDNPath() + 'assets/images/payment-modes/' + mode + '.png';
|
|
18
|
+
}
|
|
19
|
+
paymentModeSelected(event) {
|
|
20
|
+
this.modeSelected.emit(event);
|
|
21
|
+
}
|
|
22
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: PaymentModesComponent, deps: [{ token: i1.SharedService }], target: i0.ɵɵFactoryTarget.Component });
|
|
23
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: PaymentModesComponent, selector: "app-payment-modes", inputs: { cashPay: "cashPay", paymentModes: "paymentModes" }, outputs: { modeSelected: "modeSelected" }, ngImport: i0, template: "<mat-radio-group class=\"text-center mx-auto payment-mode-fw\" name=\"paymentMode\" (change)=\"paymentModeSelected($event)\">\r\n <div *ngFor=\"let modes of paymentModes\">\r\n <mat-radio-button class=\"pay-rad mt-1 ml-auto\" [value]=\"modes.mode\" >\r\n <div>\r\n <div>\r\n <img class=\"pay-icons\" [src]=\"getImageSrc(modes.mode)\" alt=\"\">\r\n </div>\r\n <div class=\"modeName\">\r\n <div *ngIf=\"modes.modeDisplayName === 'UPI'\"> \r\n <div>{{modes.modeDisplayName |uppercase }}</div>\r\n </div>\r\n <div *ngIf=\"modes.modeDisplayName === 'Credit Card'\">\r\n <div>{{modes.modeDisplayName |uppercase }}</div>\r\n </div>\r\n <div *ngIf=\"modes.modeDisplayName === 'Debit Card'\">\r\n <div> {{modes.modeDisplayName |uppercase }}</div>\r\n </div>\r\n <div *ngIf=\"modes.modeDisplayName === 'Net Banking'\">\r\n <div> {{modes.modeDisplayName |uppercase }}</div>\r\n </div>\r\n <div *ngIf=\"modes.modeDisplayName === 'Wallet'\">\r\n <div> {{modes.modeDisplayName |uppercase }} </div>\r\n </div>\r\n <div *ngIf=\"modes.mode === 'PAYLATER'\">\r\n <div> {{modes.modeDisplayName |uppercase }} </div>\r\n </div> \r\n </div>\r\n </div>\r\n </mat-radio-button> \r\n </div>\r\n <div>\r\n <mat-radio-button class=\"pay-rad mt-1 ml-auto\" [value]=\"'cash'\" *ngIf=\"cashPay\">\r\n <div class=\"clearfix\"></div>\r\n <div class=\"col-12 p-0 pay-mode \">\r\n <div class=\"d-flex\">\r\n <img class=\"pay-icons\" [src]=\"getImageSrc('PAYCASH')\" alt=\"\">\r\n </div>\r\n <div class=\"col-12 p-0 text-center\">\r\n Pay by Cash\r\n </div>\r\n </div>\r\n </mat-radio-button>\r\n </div>\r\n</mat-radio-group>", styles: [".pay-rad{width:26.5%;height:100px;float:left;border:1px solid #ddd;border-radius:10px;margin:5px;font-size:10px}.pay-icons{height:50px;object-fit:scale-down!important;margin-top:5px;width:100%}::ng-deep mat-radio-button.pay-rad .mat-mdc-radio-checked{box-shadow:0 4px 8px #0000001a,0 6px 20px #0000!important;background:#f1ffff!important;border:1.25px solid #45C3D3!important;border-radius:5px!important}@media (max-width: 768px){.pay-rad{width:30%;height:100%}}@media (min-width: 768px) and (max-width: 856px){.pay-rad{width:30%;height:120px}}.font-weight-normal{font-weight:400!important}@media (max-width: 768px){.font-weight-normal{font-weight:400!important;font-size:13px!important}}::ng-deep .pay-rad .mat-radio-outer-circle,::ng-deep .pay-rad .mat-radio-inner-circle{height:15px!important;width:15px!important}::ng-deep .pay-rad .mat-radio-label{display:block!important}::ng-deep .pay-rad .mat-radio-container{display:block!important;top:5px!important;right:5px;float:right}.modeName{font-size:12px;font-weight:600}::ng-deep .payment-mode-fw .mdc-form-field{flex-direction:row-reverse}@media (max-width: 575px){::ng-deep .payment-mode-fw mat-radio-button.pay-rad .mdc-form-field{flex-direction:column!important}.pay-icons{margin-top:-5px!important}}@media (max-width: 575px){::ng-deep .payment-mode-fw .mat-mdc-radio-button .mdc-radio{margin-right:-70px!important}}@media (min-width: 576px) and (max-width: 767px){::ng-deep .payment-mode-fw .mat-mdc-radio-button .mdc-radio{margin-right:-35px!important}}\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.MatRadioGroup, selector: "mat-radio-group", inputs: ["color", "name", "labelPosition", "value", "selected", "disabled", "required", "disabledInteractive"], outputs: ["change"], exportAs: ["matRadioGroup"] }, { kind: "component", type: i3.MatRadioButton, selector: "mat-radio-button", inputs: ["id", "name", "aria-label", "aria-labelledby", "aria-describedby", "disableRipple", "tabIndex", "checked", "value", "labelPosition", "disabled", "required", "color", "disabledInteractive"], outputs: ["change"], exportAs: ["matRadioButton"] }, { kind: "pipe", type: i2.UpperCasePipe, name: "uppercase" }] });
|
|
24
|
+
}
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: PaymentModesComponent, decorators: [{
|
|
26
|
+
type: Component,
|
|
27
|
+
args: [{ selector: 'app-payment-modes', template: "<mat-radio-group class=\"text-center mx-auto payment-mode-fw\" name=\"paymentMode\" (change)=\"paymentModeSelected($event)\">\r\n <div *ngFor=\"let modes of paymentModes\">\r\n <mat-radio-button class=\"pay-rad mt-1 ml-auto\" [value]=\"modes.mode\" >\r\n <div>\r\n <div>\r\n <img class=\"pay-icons\" [src]=\"getImageSrc(modes.mode)\" alt=\"\">\r\n </div>\r\n <div class=\"modeName\">\r\n <div *ngIf=\"modes.modeDisplayName === 'UPI'\"> \r\n <div>{{modes.modeDisplayName |uppercase }}</div>\r\n </div>\r\n <div *ngIf=\"modes.modeDisplayName === 'Credit Card'\">\r\n <div>{{modes.modeDisplayName |uppercase }}</div>\r\n </div>\r\n <div *ngIf=\"modes.modeDisplayName === 'Debit Card'\">\r\n <div> {{modes.modeDisplayName |uppercase }}</div>\r\n </div>\r\n <div *ngIf=\"modes.modeDisplayName === 'Net Banking'\">\r\n <div> {{modes.modeDisplayName |uppercase }}</div>\r\n </div>\r\n <div *ngIf=\"modes.modeDisplayName === 'Wallet'\">\r\n <div> {{modes.modeDisplayName |uppercase }} </div>\r\n </div>\r\n <div *ngIf=\"modes.mode === 'PAYLATER'\">\r\n <div> {{modes.modeDisplayName |uppercase }} </div>\r\n </div> \r\n </div>\r\n </div>\r\n </mat-radio-button> \r\n </div>\r\n <div>\r\n <mat-radio-button class=\"pay-rad mt-1 ml-auto\" [value]=\"'cash'\" *ngIf=\"cashPay\">\r\n <div class=\"clearfix\"></div>\r\n <div class=\"col-12 p-0 pay-mode \">\r\n <div class=\"d-flex\">\r\n <img class=\"pay-icons\" [src]=\"getImageSrc('PAYCASH')\" alt=\"\">\r\n </div>\r\n <div class=\"col-12 p-0 text-center\">\r\n Pay by Cash\r\n </div>\r\n </div>\r\n </mat-radio-button>\r\n </div>\r\n</mat-radio-group>", styles: [".pay-rad{width:26.5%;height:100px;float:left;border:1px solid #ddd;border-radius:10px;margin:5px;font-size:10px}.pay-icons{height:50px;object-fit:scale-down!important;margin-top:5px;width:100%}::ng-deep mat-radio-button.pay-rad .mat-mdc-radio-checked{box-shadow:0 4px 8px #0000001a,0 6px 20px #0000!important;background:#f1ffff!important;border:1.25px solid #45C3D3!important;border-radius:5px!important}@media (max-width: 768px){.pay-rad{width:30%;height:100%}}@media (min-width: 768px) and (max-width: 856px){.pay-rad{width:30%;height:120px}}.font-weight-normal{font-weight:400!important}@media (max-width: 768px){.font-weight-normal{font-weight:400!important;font-size:13px!important}}::ng-deep .pay-rad .mat-radio-outer-circle,::ng-deep .pay-rad .mat-radio-inner-circle{height:15px!important;width:15px!important}::ng-deep .pay-rad .mat-radio-label{display:block!important}::ng-deep .pay-rad .mat-radio-container{display:block!important;top:5px!important;right:5px;float:right}.modeName{font-size:12px;font-weight:600}::ng-deep .payment-mode-fw .mdc-form-field{flex-direction:row-reverse}@media (max-width: 575px){::ng-deep .payment-mode-fw mat-radio-button.pay-rad .mdc-form-field{flex-direction:column!important}.pay-icons{margin-top:-5px!important}}@media (max-width: 575px){::ng-deep .payment-mode-fw .mat-mdc-radio-button .mdc-radio{margin-right:-70px!important}}@media (min-width: 576px) and (max-width: 767px){::ng-deep .payment-mode-fw .mat-mdc-radio-button .mdc-radio{margin-right:-35px!important}}\n"] }]
|
|
28
|
+
}], ctorParameters: () => [{ type: i1.SharedService }], propDecorators: { cashPay: [{
|
|
29
|
+
type: Input
|
|
30
|
+
}], paymentModes: [{
|
|
31
|
+
type: Input
|
|
32
|
+
}], modeSelected: [{
|
|
33
|
+
type: Output
|
|
34
|
+
}] } });
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF5bWVudC1tb2Rlcy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9qY29uc3VtZXItc2hhcmVkL3NyYy9saWIvcGF5bWVudC9tb2Rlcy9wYXltZW50LW1vZGVzLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2pjb25zdW1lci1zaGFyZWQvc3JjL2xpYi9wYXltZW50L21vZGVzL3BheW1lbnQtbW9kZXMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFRL0UsTUFBTSxPQUFPLHFCQUFxQjtJQU1aO0lBSlgsT0FBTyxDQUFDO0lBQ1IsWUFBWSxDQUFDO0lBQ1osWUFBWSxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7SUFFakQsWUFBb0IsYUFBNEI7UUFBNUIsa0JBQWEsR0FBYixhQUFhLENBQWU7SUFBSSxDQUFDO0lBRXJELFFBQVE7SUFDUixDQUFDO0lBRUQsV0FBVyxDQUFDLElBQUk7UUFDZCxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsVUFBVSxFQUFFLEdBQUcsOEJBQThCLEdBQUcsSUFBSSxHQUFHLE1BQU0sQ0FBQztJQUMxRixDQUFDO0lBRUQsbUJBQW1CLENBQUMsS0FBSztRQUN2QixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNoQyxDQUFDO3VHQWpCVSxxQkFBcUI7MkZBQXJCLHFCQUFxQixrS0NSbEMsZ3VFQTJDa0I7OzJGRG5DTCxxQkFBcUI7a0JBTGpDLFNBQVM7K0JBQ0UsbUJBQW1CO2tGQU1wQixPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csWUFBWTtzQkFBcEIsS0FBSztnQkFDSSxZQUFZO3NCQUFyQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBTaGFyZWRTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2hhcmVkLnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdhcHAtcGF5bWVudC1tb2RlcycsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL3BheW1lbnQtbW9kZXMuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3BheW1lbnQtbW9kZXMuY29tcG9uZW50LmNzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBQYXltZW50TW9kZXNDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG5cclxuICBASW5wdXQoKSBjYXNoUGF5O1xyXG4gIEBJbnB1dCgpIHBheW1lbnRNb2RlcztcclxuICBAT3V0cHV0KCkgbW9kZVNlbGVjdGVkID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc2hhcmVkU2VydmljZTogU2hhcmVkU2VydmljZSkgeyB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gIH1cclxuXHJcbiAgZ2V0SW1hZ2VTcmMobW9kZSkge1xyXG4gICAgcmV0dXJuIHRoaXMuc2hhcmVkU2VydmljZS5nZXRDRE5QYXRoKCkgKyAnYXNzZXRzL2ltYWdlcy9wYXltZW50LW1vZGVzLycgKyBtb2RlICsgJy5wbmcnO1xyXG4gIH1cclxuXHJcbiAgcGF5bWVudE1vZGVTZWxlY3RlZChldmVudCkge1xyXG4gICAgdGhpcy5tb2RlU2VsZWN0ZWQuZW1pdChldmVudCk7XHJcbiAgfVxyXG5cclxufVxyXG4iLCI8bWF0LXJhZGlvLWdyb3VwIGNsYXNzPVwidGV4dC1jZW50ZXIgbXgtYXV0byBwYXltZW50LW1vZGUtZndcIiBuYW1lPVwicGF5bWVudE1vZGVcIiAoY2hhbmdlKT1cInBheW1lbnRNb2RlU2VsZWN0ZWQoJGV2ZW50KVwiPlxyXG4gICAgPGRpdiAqbmdGb3I9XCJsZXQgbW9kZXMgb2YgcGF5bWVudE1vZGVzXCI+XHJcbiAgICAgICAgPG1hdC1yYWRpby1idXR0b24gY2xhc3M9XCJwYXktcmFkIG10LTEgbWwtYXV0b1wiIFt2YWx1ZV09XCJtb2Rlcy5tb2RlXCIgPlxyXG4gICAgICAgICAgICA8ZGl2PlxyXG4gICAgICAgICAgICAgICAgPGRpdj5cclxuICAgICAgICAgICAgICAgICAgICA8aW1nIGNsYXNzPVwicGF5LWljb25zXCIgW3NyY109XCJnZXRJbWFnZVNyYyhtb2Rlcy5tb2RlKVwiIGFsdD1cIlwiPlxyXG4gICAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwibW9kZU5hbWVcIj5cclxuICAgICAgICAgICAgICAgICAgICA8ZGl2ICpuZ0lmPVwibW9kZXMubW9kZURpc3BsYXlOYW1lID09PSAnVVBJJ1wiPiAgICAgICAgICAgICAgICAgICAgICBcclxuICAgICAgICAgICAgICAgICAgICAgICAgPGRpdj57e21vZGVzLm1vZGVEaXNwbGF5TmFtZSB8dXBwZXJjYXNlIH19PC9kaXY+XHJcbiAgICAgICAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgICAgICAgICAgPGRpdiAqbmdJZj1cIm1vZGVzLm1vZGVEaXNwbGF5TmFtZSA9PT0gJ0NyZWRpdCBDYXJkJ1wiPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICA8ZGl2Pnt7bW9kZXMubW9kZURpc3BsYXlOYW1lIHx1cHBlcmNhc2UgfX08L2Rpdj5cclxuICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgICAgICAgICA8ZGl2ICpuZ0lmPVwibW9kZXMubW9kZURpc3BsYXlOYW1lID09PSAnRGViaXQgQ2FyZCdcIj5cclxuICAgICAgICAgICAgICAgICAgICAgICA8ZGl2PiB7e21vZGVzLm1vZGVEaXNwbGF5TmFtZSB8dXBwZXJjYXNlIH19PC9kaXY+XHJcbiAgICAgICAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgICAgICAgICAgPGRpdiAqbmdJZj1cIm1vZGVzLm1vZGVEaXNwbGF5TmFtZSA9PT0gJ05ldCBCYW5raW5nJ1wiPlxyXG4gICAgICAgICAgICAgICAgICAgICAgIDxkaXY+IHt7bW9kZXMubW9kZURpc3BsYXlOYW1lIHx1cHBlcmNhc2UgfX08L2Rpdj5cclxuICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgICAgICAgICA8ZGl2ICpuZ0lmPVwibW9kZXMubW9kZURpc3BsYXlOYW1lID09PSAnV2FsbGV0J1wiPlxyXG4gICAgICAgICAgICAgICAgICAgICAgIDxkaXY+IHt7bW9kZXMubW9kZURpc3BsYXlOYW1lIHx1cHBlcmNhc2UgfX0gPC9kaXY+XHJcbiAgICAgICAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgICAgICAgICAgPGRpdiAqbmdJZj1cIm1vZGVzLm1vZGUgPT09ICdQQVlMQVRFUidcIj5cclxuICAgICAgICAgICAgICAgICAgICAgICA8ZGl2PiB7e21vZGVzLm1vZGVEaXNwbGF5TmFtZSB8dXBwZXJjYXNlIH19IDwvZGl2PlxyXG4gICAgICAgICAgICAgICAgICAgIDwvZGl2PiAgICAgICAgICAgICAgICAgICBcclxuICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8L21hdC1yYWRpby1idXR0b24+ICAgICAgICBcclxuICAgIDwvZGl2PlxyXG4gICAgPGRpdj5cclxuICAgICAgICA8bWF0LXJhZGlvLWJ1dHRvbiBjbGFzcz1cInBheS1yYWQgbXQtMSBtbC1hdXRvXCIgW3ZhbHVlXT1cIidjYXNoJ1wiICpuZ0lmPVwiY2FzaFBheVwiPlxyXG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiY2xlYXJmaXhcIj48L2Rpdj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNvbC0xMiBwLTAgcGF5LW1vZGUgXCI+XHJcbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwiZC1mbGV4XCI+XHJcbiAgICAgICAgICAgICAgICAgICAgPGltZyBjbGFzcz1cInBheS1pY29uc1wiIFtzcmNdPVwiZ2V0SW1hZ2VTcmMoJ1BBWUNBU0gnKVwiIGFsdD1cIlwiPlxyXG4gICAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLTEyIHAtMCB0ZXh0LWNlbnRlclwiPlxyXG4gICAgICAgICAgICAgICAgICAgIFBheSBieSBDYXNoXHJcbiAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPC9tYXQtcmFkaW8tYnV0dG9uPlxyXG4gICAgPC9kaXY+XHJcbjwvbWF0LXJhZGlvLWdyb3VwPiJdfQ==
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { MatRadioModule } from '@angular/material/radio';
|
|
4
|
+
import { PaymentModesComponent } from './payment-modes.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class PaymentModesModule {
|
|
7
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: PaymentModesModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
8
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.9", ngImport: i0, type: PaymentModesModule, declarations: [PaymentModesComponent], imports: [CommonModule,
|
|
9
|
+
MatRadioModule], exports: [PaymentModesComponent] });
|
|
10
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: PaymentModesModule, imports: [CommonModule,
|
|
11
|
+
MatRadioModule] });
|
|
12
|
+
}
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: PaymentModesModule, decorators: [{
|
|
14
|
+
type: NgModule,
|
|
15
|
+
args: [{
|
|
16
|
+
declarations: [PaymentModesComponent],
|
|
17
|
+
exports: [PaymentModesComponent],
|
|
18
|
+
imports: [
|
|
19
|
+
CommonModule,
|
|
20
|
+
MatRadioModule
|
|
21
|
+
]
|
|
22
|
+
}]
|
|
23
|
+
}] });
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF5bWVudC1tb2Rlcy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9qY29uc3VtZXItc2hhcmVkL3NyYy9saWIvcGF5bWVudC9tb2Rlcy9wYXltZW50LW1vZGVzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7O0FBVWxFLE1BQU0sT0FBTyxrQkFBa0I7dUdBQWxCLGtCQUFrQjt3R0FBbEIsa0JBQWtCLGlCQVBkLHFCQUFxQixhQUdsQyxZQUFZO1lBQ1osY0FBYyxhQUhOLHFCQUFxQjt3R0FNcEIsa0JBQWtCLFlBSjNCLFlBQVk7WUFDWixjQUFjOzsyRkFHTCxrQkFBa0I7a0JBUjlCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMscUJBQXFCLENBQUM7b0JBQ3JDLE9BQU8sRUFBRSxDQUFDLHFCQUFxQixDQUFDO29CQUNoQyxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixjQUFjO3FCQUNmO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTWF0UmFkaW9Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9yYWRpbyc7XHJcbmltcG9ydCB7IFBheW1lbnRNb2Rlc0NvbXBvbmVudCB9IGZyb20gJy4vcGF5bWVudC1tb2Rlcy5jb21wb25lbnQnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtQYXltZW50TW9kZXNDb21wb25lbnRdLFxyXG4gIGV4cG9ydHM6IFtQYXltZW50TW9kZXNDb21wb25lbnRdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIE1hdFJhZGlvTW9kdWxlXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgUGF5bWVudE1vZGVzTW9kdWxlIHt9XHJcbiJdfQ==
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { PaytmService } from '../paytm.service';
|
|
4
|
+
import { RazorpayService } from '../razorpay.service';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class PaymentsModule {
|
|
7
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: PaymentsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
8
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.9", ngImport: i0, type: PaymentsModule, imports: [CommonModule] });
|
|
9
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: PaymentsModule, providers: [
|
|
10
|
+
PaytmService,
|
|
11
|
+
RazorpayService
|
|
12
|
+
], imports: [CommonModule] });
|
|
13
|
+
}
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: PaymentsModule, decorators: [{
|
|
15
|
+
type: NgModule,
|
|
16
|
+
args: [{
|
|
17
|
+
declarations: [],
|
|
18
|
+
imports: [CommonModule],
|
|
19
|
+
exports: [],
|
|
20
|
+
providers: [
|
|
21
|
+
PaytmService,
|
|
22
|
+
RazorpayService
|
|
23
|
+
]
|
|
24
|
+
}]
|
|
25
|
+
}] });
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF5bWVudC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9qY29uc3VtZXItc2hhcmVkL3NyYy9saWIvcGF5bWVudC9wYXltZW50Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDaEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDOztBQWF0RCxNQUFNLE9BQU8sY0FBYzt1R0FBZCxjQUFjO3dHQUFkLGNBQWMsWUFQZCxZQUFZO3dHQU9aLGNBQWMsYUFMZDtZQUNULFlBQVk7WUFDWixlQUFlO1NBQ2hCLFlBTFUsWUFBWTs7MkZBT1osY0FBYztrQkFUMUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsRUFBRTtvQkFDaEIsT0FBTyxFQUFFLENBQUUsWUFBWSxDQUFFO29CQUN6QixPQUFPLEVBQUUsRUFBRTtvQkFDWCxTQUFTLEVBQUU7d0JBQ1QsWUFBWTt3QkFDWixlQUFlO3FCQUNoQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IFBheXRtU2VydmljZSB9IGZyb20gJy4uL3BheXRtLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBSYXpvcnBheVNlcnZpY2UgfSBmcm9tICcuLi9yYXpvcnBheS5zZXJ2aWNlJztcclxuXHJcblxyXG5cclxuQE5nTW9kdWxlKHtcclxuICBkZWNsYXJhdGlvbnM6IFtdLFxyXG4gIGltcG9ydHM6IFsgQ29tbW9uTW9kdWxlIF0sXHJcbiAgZXhwb3J0czogW10sXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICBQYXl0bVNlcnZpY2UsXHJcbiAgICBSYXpvcnBheVNlcnZpY2VcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBQYXltZW50c01vZHVsZSB7IH1cclxuIl19
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
import { Injectable } from "@angular/core";
|
|
2
|
+
import { projectConstantsLocal } from "./project-constants";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "./service-meta";
|
|
5
|
+
export class PaytmService {
|
|
6
|
+
servicemeta;
|
|
7
|
+
paymentModes = [
|
|
8
|
+
'NB', 'CC', 'DC', 'UPI', 'PPI', 'CARD'
|
|
9
|
+
];
|
|
10
|
+
constructor(servicemeta) {
|
|
11
|
+
this.servicemeta = servicemeta;
|
|
12
|
+
}
|
|
13
|
+
initializePayment(pData, accountId, referrer) {
|
|
14
|
+
let response = JSON.parse(pData.response);
|
|
15
|
+
if (pData.paymentMode === 'CC' || pData.paymentMode === 'DC') {
|
|
16
|
+
pData.paymentMode = 'CARD';
|
|
17
|
+
}
|
|
18
|
+
const paymentModesHidden = this.paymentModes.filter(obj => obj !== pData.paymentMode);
|
|
19
|
+
const paytm_payload = {
|
|
20
|
+
"paymentId": pData.txnid,
|
|
21
|
+
"orderId": pData.orderId,
|
|
22
|
+
"siganature": response.signature
|
|
23
|
+
};
|
|
24
|
+
console.log('response' + JSON.stringify(response));
|
|
25
|
+
this.loadPayTMScript(pData, referrer).onload = () => {
|
|
26
|
+
var config = {
|
|
27
|
+
"root": "",
|
|
28
|
+
"flow": "DEFAULT",
|
|
29
|
+
"data": {
|
|
30
|
+
"orderId": pData.orderId, /* update order id */
|
|
31
|
+
"token": response.body.txnToken, /* update token value */
|
|
32
|
+
"tokenType": "TXN_TOKEN",
|
|
33
|
+
"amount": pData.amount
|
|
34
|
+
},
|
|
35
|
+
"merchant": {
|
|
36
|
+
"mid": pData.merchantId,
|
|
37
|
+
"redirect": false,
|
|
38
|
+
"multipleWindowWebview": true
|
|
39
|
+
},
|
|
40
|
+
"payMode": {
|
|
41
|
+
"filter": {
|
|
42
|
+
'exclude': paymentModesHidden
|
|
43
|
+
}
|
|
44
|
+
},
|
|
45
|
+
"handler": {
|
|
46
|
+
"notifyMerchant": function (eventName, data) {
|
|
47
|
+
console.log("notifyMerchant handler function called");
|
|
48
|
+
console.log("eventName => ", eventName);
|
|
49
|
+
console.log("data => ", data);
|
|
50
|
+
referrer.closeloading();
|
|
51
|
+
},
|
|
52
|
+
"transactionStatus": function (data) {
|
|
53
|
+
console.log("payment status ", data);
|
|
54
|
+
console.log(paytm_payload);
|
|
55
|
+
window['Paytm'].CheckoutJS.close();
|
|
56
|
+
if (data) {
|
|
57
|
+
referrer.transactionCompleted(data, paytm_payload, accountId);
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
referrer.transactionCompleted({ STATUS: 'TXN_SUCCESS' }, paytm_payload, accountId);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
};
|
|
65
|
+
console.log(JSON.stringify(config));
|
|
66
|
+
if (window['Paytm'] && window['Paytm'].CheckoutJS) {
|
|
67
|
+
window['Paytm'].CheckoutJS.onLoad(function excecuteAfterCompleteLoad() {
|
|
68
|
+
// initialze configuration using init method
|
|
69
|
+
window['Paytm'].CheckoutJS.init(config).then(function onSuccess() {
|
|
70
|
+
// after successfully updating configuration, invoke JS Checkout
|
|
71
|
+
window['Paytm'].CheckoutJS.invoke();
|
|
72
|
+
}).catch(function onError(error) {
|
|
73
|
+
console.log("error => ", error);
|
|
74
|
+
window['Paytm'].CheckoutJS.close();
|
|
75
|
+
referrer.closeloading();
|
|
76
|
+
});
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
};
|
|
80
|
+
setTimeout(() => {
|
|
81
|
+
window['Paytm'].CheckoutJS.close();
|
|
82
|
+
referrer.closeloading();
|
|
83
|
+
}, 600000);
|
|
84
|
+
}
|
|
85
|
+
loadPayTMScript(pData, isfrom) {
|
|
86
|
+
let payTmurl;
|
|
87
|
+
if (pData.paymentEnv == 'production') {
|
|
88
|
+
payTmurl = projectConstantsLocal.PAYTM_URL;
|
|
89
|
+
}
|
|
90
|
+
else {
|
|
91
|
+
payTmurl = projectConstantsLocal.PAYTMLOCAL_URL;
|
|
92
|
+
}
|
|
93
|
+
const url = payTmurl + '/merchantpgpui/checkoutjs/merchants/' + pData.merchantId + '.js';
|
|
94
|
+
console.log('preparing to load...');
|
|
95
|
+
let script = document.createElement('script');
|
|
96
|
+
script.id = pData.orderId;
|
|
97
|
+
script.src = url;
|
|
98
|
+
script.type = 'text/javascript';
|
|
99
|
+
script.async = true;
|
|
100
|
+
script['crossorigin'] = "anonymous";
|
|
101
|
+
// node.charset = 'utf-8';
|
|
102
|
+
// this.renderer.appendChild(document.body, script);
|
|
103
|
+
console.log(isfrom.paytmview);
|
|
104
|
+
// document.getElementById('consumer_donation').appendChild(script);
|
|
105
|
+
isfrom.paytmview.nativeElement.appendChild(script);
|
|
106
|
+
return script;
|
|
107
|
+
}
|
|
108
|
+
updateResult(payload, accountId) {
|
|
109
|
+
let url = 'provider/payment/paytm/update';
|
|
110
|
+
if (accountId) {
|
|
111
|
+
url += '?account=' + accountId;
|
|
112
|
+
}
|
|
113
|
+
return this.servicemeta.httpPost(url, payload);
|
|
114
|
+
}
|
|
115
|
+
updatePaytmPay(payload, accountId) {
|
|
116
|
+
const self = this;
|
|
117
|
+
return new Promise((resolve, reject) => {
|
|
118
|
+
self.updateResult(payload, accountId).subscribe((result) => {
|
|
119
|
+
resolve(result);
|
|
120
|
+
}, (error) => {
|
|
121
|
+
reject(false);
|
|
122
|
+
});
|
|
123
|
+
});
|
|
124
|
+
}
|
|
125
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: PaytmService, deps: [{ token: i1.ServiceMeta }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
126
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: PaytmService });
|
|
127
|
+
}
|
|
128
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: PaytmService, decorators: [{
|
|
129
|
+
type: Injectable
|
|
130
|
+
}], ctorParameters: () => [{ type: i1.ServiceMeta }] });
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paytm.service.js","sourceRoot":"","sources":["../../../../projects/jconsumer-shared/src/lib/paytm.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from \"@angular/core\";\r\nimport { ServiceMeta } from \"./service-meta\";\r\nimport { projectConstantsLocal } from \"./project-constants\";\r\n\r\n\r\n@Injectable()\r\nexport class PaytmService {\r\n    paymentModes = [\r\n        'NB', 'CC', 'DC', 'UPI', 'PPI', 'CARD'\r\n    ];\r\n    constructor(\r\n        private servicemeta: ServiceMeta\r\n    ) { }\r\n    initializePayment(pData: any, accountId: any, referrer: any) {\r\n        let response = JSON.parse(pData.response);\r\n        if (pData.paymentMode === 'CC' || pData.paymentMode === 'DC') {\r\n            pData.paymentMode = 'CARD';\r\n        }\r\n        const paymentModesHidden = this.paymentModes.filter(obj => obj !== pData.paymentMode);\r\n        const paytm_payload = {\r\n            \"paymentId\": pData.txnid,\r\n            \"orderId\": pData.orderId,\r\n            \"siganature\": response.signature\r\n\r\n        };\r\n        console.log('response' + JSON.stringify(response));\r\n        this.loadPayTMScript(pData, referrer).onload = () => {\r\n            var config = {\r\n                \"root\": \"\",\r\n                \"flow\": \"DEFAULT\",\r\n                \"data\": {\r\n                    \"orderId\": pData.orderId, /* update order id */\r\n                    \"token\": response.body.txnToken, /* update token value */\r\n                    \"tokenType\": \"TXN_TOKEN\",\r\n                    \"amount\": pData.amount\r\n                },\r\n                \"merchant\": {\r\n                    \"mid\": pData.merchantId,\r\n                    \"redirect\": false,\r\n                    \"multipleWindowWebview\": true\r\n                },\r\n                \"payMode\": {\r\n                    \"filter\": {\r\n                        'exclude': paymentModesHidden\r\n                    }\r\n                },\r\n                \"handler\": {\r\n                    \"notifyMerchant\": function (eventName: any, data: any) {\r\n                        console.log(\"notifyMerchant handler function called\");\r\n                        console.log(\"eventName => \", eventName);\r\n                        console.log(\"data => \", data);\r\n                        referrer.closeloading();\r\n                    },\r\n                    \"transactionStatus\": function (data: any) {\r\n                        console.log(\"payment status \", data);\r\n                        console.log(paytm_payload);\r\n                        window['Paytm'].CheckoutJS.close();\r\n                        if (data) {\r\n                            referrer.transactionCompleted(data, paytm_payload, accountId);\r\n                        } else {\r\n                            referrer.transactionCompleted({ STATUS: 'TXN_SUCCESS' }, paytm_payload, accountId);\r\n                        }\r\n                    }\r\n                }\r\n            };\r\n            console.log(JSON.stringify(config));\r\n            if (window['Paytm'] && window['Paytm'].CheckoutJS) {\r\n                window['Paytm'].CheckoutJS.onLoad(function excecuteAfterCompleteLoad() {\r\n                    // initialze configuration using init method \r\n                    window['Paytm'].CheckoutJS.init(config).then(function onSuccess() {\r\n                        // after successfully updating configuration, invoke JS Checkout\r\n                        window['Paytm'].CheckoutJS.invoke();\r\n                    }).catch(function onError(error: any) {\r\n                        console.log(\"error => \", error);\r\n                        window['Paytm'].CheckoutJS.close();\r\n                        referrer.closeloading();\r\n                    });\r\n                });\r\n            }\r\n        };\r\n\r\n        setTimeout(() => {\r\n            window['Paytm'].CheckoutJS.close();\r\n            referrer.closeloading();\r\n        }, 600000);\r\n    }\r\n\r\n    public loadPayTMScript(pData: any, isfrom: any): HTMLScriptElement {\r\n        let payTmurl;\r\n        if (pData.paymentEnv == 'production') {\r\n            payTmurl = projectConstantsLocal.PAYTM_URL;\r\n        } else {\r\n            payTmurl = projectConstantsLocal.PAYTMLOCAL_URL;\r\n        }\r\n        const url = payTmurl + '/merchantpgpui/checkoutjs/merchants/' + pData.merchantId + '.js';\r\n        console.log('preparing to load...');\r\n        let script: any = document.createElement('script');\r\n        script.id = pData.orderId;\r\n        script.src = url;\r\n        script.type = 'text/javascript';\r\n        script.async = true;\r\n        script['crossorigin'] = \"anonymous\"\r\n        // node.charset = 'utf-8';\r\n        // this.renderer.appendChild(document.body, script);\r\n        console.log(isfrom.paytmview);\r\n        // document.getElementById('consumer_donation').appendChild(script);\r\n        isfrom.paytmview.nativeElement.appendChild(script);\r\n        return script;\r\n    }\r\n    updateResult(payload: any, accountId?: any) {\r\n        let url = 'provider/payment/paytm/update';\r\n        if (accountId) {\r\n            url += '?account=' + accountId;\r\n        }\r\n        return this.servicemeta.httpPost(url, payload);\r\n    }\r\n\r\n    updatePaytmPay(payload: any, accountId?: any) {\r\n        const self = this;\r\n        return new Promise((resolve, reject) => {\r\n            self.updateResult(payload, accountId).subscribe((result: any) => {\r\n                resolve(result);\r\n            }, (error: any) => {\r\n                reject(false);\r\n            })\r\n        })\r\n    }\r\n}\r\n"]}
|
|
@@ -1,103 +1,102 @@
|
|
|
1
|
-
import { Component, forwardRef, Input,
|
|
2
|
-
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
1
|
+
import { Component, forwardRef, Input, Output, EventEmitter, ViewChild } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR, NgModel } from '@angular/forms';
|
|
3
3
|
import intlTelInput from 'intl-tel-input';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "@angular/common";
|
|
6
6
|
import * as i2 from "@angular/forms";
|
|
7
7
|
export class PhoneInputComponent {
|
|
8
|
-
initialCountry = 'us';
|
|
9
|
-
preferredCountries = [];
|
|
10
|
-
nationalMode = true;
|
|
11
|
-
separateDialCode = true;
|
|
12
|
-
otherOptions = {};
|
|
8
|
+
initialCountry = 'us';
|
|
9
|
+
preferredCountries = [];
|
|
10
|
+
nationalMode = true;
|
|
11
|
+
separateDialCode = true;
|
|
12
|
+
otherOptions = {};
|
|
13
13
|
phoneInput;
|
|
14
|
-
|
|
15
|
-
phoneInputInstance;
|
|
16
|
-
// Output Event to send the phone number value to the parent component
|
|
14
|
+
ngModelRef; // Reference to NgModel instance
|
|
17
15
|
phoneNumberChange = new EventEmitter();
|
|
18
|
-
|
|
16
|
+
ngModelChange = new EventEmitter();
|
|
17
|
+
phoneNumber = { dialCode: '', countryCode: '', e164Number: '', number: '' };
|
|
18
|
+
phoneInputInstance;
|
|
19
19
|
onChange = (value) => { };
|
|
20
20
|
onTouched = () => { };
|
|
21
21
|
ngAfterViewInit() {
|
|
22
22
|
if (this.phoneInput && this.phoneInput.nativeElement) {
|
|
23
23
|
this.initializePhoneInput();
|
|
24
24
|
}
|
|
25
|
+
if (this.phoneInputInstance) {
|
|
26
|
+
this.phoneInputInstance.setNumber(this.phoneNumber.e164Number || ''); // Set initial value if available
|
|
27
|
+
}
|
|
25
28
|
}
|
|
26
|
-
// Initialize intl-tel-input for the phone input field
|
|
27
29
|
initializePhoneInput() {
|
|
28
30
|
const options = {
|
|
29
31
|
initialCountry: this.initialCountry,
|
|
30
32
|
preferredCountries: this.preferredCountries,
|
|
31
|
-
nationalMode: this.nationalMode,
|
|
32
|
-
separateDialCode: this.separateDialCode,
|
|
33
|
+
nationalMode: this.nationalMode,
|
|
34
|
+
separateDialCode: this.separateDialCode,
|
|
33
35
|
utilsScript: 'https://cdnjs.cloudflare.com/ajax/libs/intl-tel-input/17.0.8/js/utils.js',
|
|
34
|
-
...this.otherOptions
|
|
36
|
+
...this.otherOptions
|
|
35
37
|
};
|
|
36
|
-
// Initialize intl-tel-input
|
|
37
38
|
this.phoneInputInstance = intlTelInput(this.phoneInput.nativeElement, options);
|
|
38
|
-
// Capture the country change event to track the selected country code and dial code
|
|
39
39
|
this.phoneInput.nativeElement.addEventListener('countrychange', () => {
|
|
40
40
|
this.updatePhoneNumber();
|
|
41
41
|
});
|
|
42
|
-
// Capture input event to update phone number in E.164 format
|
|
43
42
|
this.phoneInput.nativeElement.addEventListener('input', () => {
|
|
44
43
|
this.updatePhoneNumber();
|
|
45
44
|
});
|
|
46
|
-
// Set the initial value if available (without showing the dial code)
|
|
47
45
|
if (this.phoneNumber.e164Number) {
|
|
48
|
-
this.phoneInputInstance.setNumber(this.phoneNumber.e164Number);
|
|
46
|
+
this.phoneInputInstance.setNumber(this.phoneNumber.e164Number);
|
|
49
47
|
}
|
|
50
48
|
}
|
|
51
|
-
// Method to update the phone number object
|
|
52
49
|
updatePhoneNumber() {
|
|
53
50
|
const dialCode = '+' + this.phoneInputInstance.getSelectedCountryData().dialCode;
|
|
54
51
|
const countryCode = this.phoneInputInstance.getSelectedCountryData().iso2;
|
|
55
|
-
const e164Number = this.phoneInputInstance.getNumber();
|
|
52
|
+
const e164Number = this.phoneInputInstance.getNumber();
|
|
56
53
|
const number = e164Number.split(dialCode)[1];
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
number
|
|
63
|
-
};
|
|
64
|
-
// Emit the updated value to the parent component
|
|
65
|
-
this.phoneNumberChange.emit(this.phoneNumber); // Sending the value to parent
|
|
54
|
+
this.phoneNumber = { dialCode, countryCode, e164Number, number };
|
|
55
|
+
// Emit changes for FormControl and ngModel
|
|
56
|
+
this.phoneNumberChange.emit(this.phoneNumber);
|
|
57
|
+
this.ngModelChange.emit(this.phoneNumber); // For ngModel two-way binding
|
|
58
|
+
this.onChange(this.phoneNumber); // For reactive form support
|
|
66
59
|
}
|
|
67
|
-
// Implement the writeValue method for ControlValueAccessor
|
|
68
60
|
writeValue(value) {
|
|
61
|
+
console.log("In Write Value:", value);
|
|
69
62
|
if (value && value.e164Number) {
|
|
70
63
|
this.phoneNumber = value;
|
|
71
|
-
|
|
72
|
-
this.
|
|
73
|
-
|
|
64
|
+
setTimeout(() => {
|
|
65
|
+
if (this.phoneInput && this.phoneInput.nativeElement) {
|
|
66
|
+
// Set the number in intl-tel-input, which will automatically set the country
|
|
67
|
+
// If you need to get the selected country code after setting the number
|
|
68
|
+
const countryData = this.phoneInputInstance.getSelectedCountryData();
|
|
69
|
+
this.phoneNumber.countryCode = countryData.iso2;
|
|
70
|
+
this.phoneNumber.dialCode = `+${countryData.dialCode}`;
|
|
71
|
+
this.phoneNumber.number = value.e164Number.split(this.phoneNumber.dialCode)[1];
|
|
72
|
+
this.phoneNumber.e164Number = value.e164Number;
|
|
73
|
+
// this.phoneInputInstance.setNumber(value.e164Number);
|
|
74
|
+
console.log("Phone:", this.phoneInput);
|
|
75
|
+
}
|
|
76
|
+
}, 0);
|
|
74
77
|
}
|
|
75
78
|
}
|
|
76
|
-
// Implement the registerOnChange method for ControlValueAccessor
|
|
77
79
|
registerOnChange(fn) {
|
|
78
80
|
this.onChange = fn;
|
|
79
81
|
}
|
|
80
|
-
// Implement the registerOnTouched method for ControlValueAccessor
|
|
81
82
|
registerOnTouched(fn) {
|
|
82
83
|
this.onTouched = fn;
|
|
83
84
|
}
|
|
84
|
-
// Custom Validation Method: Validate the phone number
|
|
85
85
|
validatePhoneNumber() {
|
|
86
86
|
if (this.phoneInputInstance) {
|
|
87
|
-
|
|
88
|
-
const isValid = this.phoneInputInstance.isValidNumber() || this.phoneNumber.number.startsWith('555');
|
|
87
|
+
const isValid = this.phoneInputInstance.isValidNumber() || this.phoneNumber?.number?.startsWith('555');
|
|
89
88
|
return isValid;
|
|
90
89
|
}
|
|
91
90
|
return false;
|
|
92
91
|
}
|
|
93
92
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: PhoneInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
94
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: PhoneInputComponent, selector: "app-phone-input", inputs: { initialCountry: "initialCountry", preferredCountries: "preferredCountries", nationalMode: "nationalMode", separateDialCode: "separateDialCode", otherOptions: "otherOptions" }, outputs: { phoneNumberChange: "phoneNumberChange" }, providers: [
|
|
93
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: PhoneInputComponent, selector: "app-phone-input", inputs: { initialCountry: "initialCountry", preferredCountries: "preferredCountries", nationalMode: "nationalMode", separateDialCode: "separateDialCode", otherOptions: "otherOptions" }, outputs: { phoneNumberChange: "phoneNumberChange", ngModelChange: "ngModelChange" }, providers: [
|
|
95
94
|
{
|
|
96
95
|
provide: NG_VALUE_ACCESSOR,
|
|
97
96
|
useExisting: forwardRef(() => PhoneInputComponent),
|
|
98
97
|
multi: true
|
|
99
98
|
}
|
|
100
|
-
], viewQueries: [{ propertyName: "phoneInput", first: true, predicate: ["phoneInput"], descendants: true }], ngImport: i0, template: "<div class=\"phone-input-wrapper\">\r\n <input #phoneInput type=\"tel\" [(ngModel)]=\"phoneNumber.
|
|
99
|
+
], viewQueries: [{ propertyName: "phoneInput", first: true, predicate: ["phoneInput"], descendants: true }, { propertyName: "ngModelRef", first: true, predicate: NgModel, descendants: true }], ngImport: i0, template: "<div class=\"phone-input-wrapper tel-input-container\">\r\n <input #phoneInput type=\"tel\" [(ngModel)]=\"phoneNumber.number\"\r\n name=\"phoneNumber\" [required]=\"true\" #phone=\"ngModel\"\r\n [ngClass]=\"{'is-invalid': !validatePhoneNumber() && phone.touched}\">\r\n\r\n <!-- Validation feedback -->\r\n <!-- <div *ngIf=\"!validatePhoneNumber() && phone.touched\" class=\"text-danger\">\r\n Invalid phone number.\r\n </div> -->\r\n</div>", styles: ["::ng-deep .tel-input-container .iti{width:100%!important}::ng-deep .tel-input-container .iti--separate-dial-code .iti__selected-flag{background-color:transparent}::ng-deep .tel-input-container input::-webkit-input-placeholder{color:#ddd}::ng-deep .tel-input-container input:focus{outline:none;border-color:#e1e2e3}::ng-deep .tel-input-container input{height:40px;width:100%;background:#fff;border:1.39032px solid #E1E2E3;border-radius:4px;padding:15px;font-size:15px}::ng-deep .tel-input-container input.is-invalid{border:1.39032px solid #ff0000}::ng-deep .tel-input-container input::placeholder{color:#ddd}::ng-deep .tel-input-container input.custom:focus{color:#495057;background-color:#fff;border-color:#3c8dbc;outline:0;box-shadow:0 0 #fff}::ng-deep .tel-input-container .iti__country-list{z-index:3}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", 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]" }, { 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.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
|
101
100
|
}
|
|
102
101
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: PhoneInputComponent, decorators: [{
|
|
103
102
|
type: Component,
|
|
@@ -107,7 +106,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
107
106
|
useExisting: forwardRef(() => PhoneInputComponent),
|
|
108
107
|
multi: true
|
|
109
108
|
}
|
|
110
|
-
], template: "<div class=\"phone-input-wrapper\">\r\n <input #phoneInput type=\"tel\" [(ngModel)]=\"phoneNumber.
|
|
109
|
+
], template: "<div class=\"phone-input-wrapper tel-input-container\">\r\n <input #phoneInput type=\"tel\" [(ngModel)]=\"phoneNumber.number\"\r\n name=\"phoneNumber\" [required]=\"true\" #phone=\"ngModel\"\r\n [ngClass]=\"{'is-invalid': !validatePhoneNumber() && phone.touched}\">\r\n\r\n <!-- Validation feedback -->\r\n <!-- <div *ngIf=\"!validatePhoneNumber() && phone.touched\" class=\"text-danger\">\r\n Invalid phone number.\r\n </div> -->\r\n</div>", styles: ["::ng-deep .tel-input-container .iti{width:100%!important}::ng-deep .tel-input-container .iti--separate-dial-code .iti__selected-flag{background-color:transparent}::ng-deep .tel-input-container input::-webkit-input-placeholder{color:#ddd}::ng-deep .tel-input-container input:focus{outline:none;border-color:#e1e2e3}::ng-deep .tel-input-container input{height:40px;width:100%;background:#fff;border:1.39032px solid #E1E2E3;border-radius:4px;padding:15px;font-size:15px}::ng-deep .tel-input-container input.is-invalid{border:1.39032px solid #ff0000}::ng-deep .tel-input-container input::placeholder{color:#ddd}::ng-deep .tel-input-container input.custom:focus{color:#495057;background-color:#fff;border-color:#3c8dbc;outline:0;box-shadow:0 0 #fff}::ng-deep .tel-input-container .iti__country-list{z-index:3}\n"] }]
|
|
111
110
|
}], propDecorators: { initialCountry: [{
|
|
112
111
|
type: Input
|
|
113
112
|
}], preferredCountries: [{
|
|
@@ -121,7 +120,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
121
120
|
}], phoneInput: [{
|
|
122
121
|
type: ViewChild,
|
|
123
122
|
args: ['phoneInput', { static: false }]
|
|
123
|
+
}], ngModelRef: [{
|
|
124
|
+
type: ViewChild,
|
|
125
|
+
args: [NgModel]
|
|
124
126
|
}], phoneNumberChange: [{
|
|
125
127
|
type: Output
|
|
128
|
+
}], ngModelChange: [{
|
|
129
|
+
type: Output
|
|
126
130
|
}] } });
|
|
127
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"phone-input.component.js","sourceRoot":"","sources":["../../../../../projects/jconsumer-shared/src/lib/phone-input/phone-input.component.ts","../../../../../projects/jconsumer-shared/src/lib/phone-input/phone-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, forwardRef, Input, ViewChild, Output, EventEmitter } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\r\nimport intlTelInput from 'intl-tel-input';\r\n\r\n@Component({\r\n  selector: 'app-phone-input',\r\n  templateUrl: './phone-input.component.html',\r\n  styleUrls: ['./phone-input.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => PhoneInputComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class PhoneInputComponent implements AfterViewInit, ControlValueAccessor {\r\n  @Input() initialCountry: string = 'us'; // Default to 'us'\r\n  @Input() preferredCountries: string[] = []; // List of preferred countries\r\n  @Input() nationalMode: boolean = true; // Use national mode so dial code is hidden in input box\r\n  @Input() separateDialCode: boolean = true; // Whether to separate dial code (controls formatting)\r\n  @Input() otherOptions: any = {}; // Any other options for intl-tel-input\r\n\r\n  @ViewChild('phoneInput', { static: false }) phoneInput: ElementRef;\r\n  phoneNumber: any = { dialCode: '', countryCode: '', e164Number: '', number: '' }; // Structured phone number object\r\n  phoneInputInstance: any;\r\n\r\n  // Output Event to send the phone number value to the parent component\r\n  @Output() phoneNumberChange = new EventEmitter<any>();\r\n\r\n  // Function to handle form control value changes\r\n  onChange = (value: any) => {};\r\n  onTouched = () => {};\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.phoneInput && this.phoneInput.nativeElement) {\r\n      this.initializePhoneInput();\r\n    }\r\n  }\r\n\r\n  // Initialize intl-tel-input for the phone input field\r\n  initializePhoneInput(): void {\r\n    const options = {\r\n      initialCountry: this.initialCountry,\r\n      preferredCountries: this.preferredCountries,\r\n      nationalMode: this.nationalMode, // Use national mode to hide dial code\r\n      separateDialCode: this.separateDialCode, // Keep separate dial code for processing\r\n      utilsScript: 'https://cdnjs.cloudflare.com/ajax/libs/intl-tel-input/17.0.8/js/utils.js',\r\n      ...this.otherOptions // Merge any additional options provided\r\n    };\r\n\r\n    // Initialize intl-tel-input\r\n    this.phoneInputInstance = intlTelInput(this.phoneInput.nativeElement, options);\r\n\r\n    // Capture the country change event to track the selected country code and dial code\r\n    this.phoneInput.nativeElement.addEventListener('countrychange', () => {\r\n      this.updatePhoneNumber();\r\n    });\r\n\r\n    // Capture input event to update phone number in E.164 format\r\n    this.phoneInput.nativeElement.addEventListener('input', () => {\r\n      this.updatePhoneNumber();\r\n    });\r\n\r\n    // Set the initial value if available (without showing the dial code)\r\n    if (this.phoneNumber.e164Number) {\r\n      this.phoneInputInstance.setNumber(this.phoneNumber.e164Number); // Set the E.164 formatted number\r\n    }\r\n  }\r\n\r\n  // Method to update the phone number object\r\n  updatePhoneNumber(): void {\r\n    const dialCode = '+' + this.phoneInputInstance.getSelectedCountryData().dialCode;\r\n    const countryCode = this.phoneInputInstance.getSelectedCountryData().iso2;\r\n    const e164Number = this.phoneInputInstance.getNumber(); // Full number in E.164 format\r\n    const number = e164Number.split(dialCode)[1];\r\n\r\n    // Update the phoneNumber object with the full details\r\n    this.phoneNumber = {\r\n      dialCode,\r\n      countryCode,\r\n      e164Number,\r\n      number\r\n    };\r\n\r\n    // Emit the updated value to the parent component\r\n    this.phoneNumberChange.emit(this.phoneNumber);  // Sending the value to parent\r\n  }\r\n\r\n  // Implement the writeValue method for ControlValueAccessor\r\n  writeValue(value: any): void {\r\n    if (value && value.e164Number) {\r\n      this.phoneNumber = value;\r\n      if (this.phoneInput && this.phoneInput.nativeElement) {\r\n        this.phoneInputInstance.setNumber(value.e164Number); // Set the E.164 formatted number\r\n      }\r\n    }\r\n  }\r\n\r\n  // Implement the registerOnChange method for ControlValueAccessor\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  // Implement the registerOnTouched method for ControlValueAccessor\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  // Custom Validation Method: Validate the phone number\r\n  validatePhoneNumber(): boolean {\r\n    if (this.phoneInputInstance) {\r\n      // Check if the current phone number is valid according to the selected country\r\n      const isValid = this.phoneInputInstance.isValidNumber() || this.phoneNumber.number.startsWith('555');\r\n      return isValid;\r\n    }\r\n    return false;\r\n  }\r\n}","<div class=\"phone-input-wrapper\">\r\n    <input #phoneInput type=\"tel\" [(ngModel)]=\"phoneNumber.phoneNumber\"\r\n        name=\"phoneNumber\" [required]=\"true\" #phone=\"ngModel\"\r\n        [ngClass]=\"{'is-invalid': !validatePhoneNumber() && phone.touched}\">\r\n\r\n    <!-- Validation feedback -->\r\n    <!-- <div *ngIf=\"!validatePhoneNumber() && phone.touched\" class=\"text-danger\">\r\n        Invalid phone number.\r\n    </div> -->\r\n    <!-- <input #phoneInput [(ngModel)]=\"phoneNumber.number\" /> -->\r\n</div>"]}
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"phone-input.component.js","sourceRoot":"","sources":["../../../../../projects/jconsumer-shared/src/lib/phone-input/phone-input.component.ts","../../../../../projects/jconsumer-shared/src/lib/phone-input/phone-input.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAc,UAAU,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACzH,OAAO,EAAE,iBAAiB,EAAwB,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAClF,OAAO,YAAY,MAAM,gBAAgB,CAAC;;;;AAc1C,MAAM,OAAO,mBAAmB;IACrB,cAAc,GAAW,IAAI,CAAC;IAC9B,kBAAkB,GAAa,EAAE,CAAC;IAClC,YAAY,GAAY,IAAI,CAAC;IAC7B,gBAAgB,GAAY,IAAI,CAAC;IACjC,YAAY,GAAQ,EAAE,CAAC;IAEY,UAAU,CAAa;IAC/C,UAAU,CAAU,CAAC,gCAAgC;IAE/D,iBAAiB,GAAG,IAAI,YAAY,EAAO,CAAC;IAC5C,aAAa,GAAG,IAAI,YAAY,EAAO,CAAC;IAElD,WAAW,GAAQ,EAAE,QAAQ,EAAE,EAAE,EAAE,WAAW,EAAE,EAAE,EAAE,UAAU,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC;IACjF,kBAAkB,CAAM;IAExB,QAAQ,GAAG,CAAC,KAAU,EAAE,EAAE,GAAE,CAAC,CAAC;IAC9B,SAAS,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;IAErB,eAAe;QACb,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC;YACrD,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC9B,CAAC;QACD,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC5B,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC,CAAC,iCAAiC;QACzG,CAAC;IACH,CAAC;IAED,oBAAoB;QAClB,MAAM,OAAO,GAAG;YACd,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,kBAAkB,EAAE,IAAI,CAAC,kBAAkB;YAC3C,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,WAAW,EAAE,0EAA0E;YACvF,GAAG,IAAI,CAAC,YAAY;SACrB,CAAC;QAEF,IAAI,CAAC,kBAAkB,GAAG,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QAE/E,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,eAAe,EAAE,GAAG,EAAE;YACnE,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;YAC3D,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;QAEH,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,CAAC;YAChC,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;QACjE,CAAC;IACH,CAAC;IAED,iBAAiB;QACf,MAAM,QAAQ,GAAG,GAAG,GAAG,IAAI,CAAC,kBAAkB,CAAC,sBAAsB,EAAE,CAAC,QAAQ,CAAC;QACjF,MAAM,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,sBAAsB,EAAE,CAAC,IAAI,CAAC;QAC1E,MAAM,UAAU,GAAG,IAAI,CAAC,kBAAkB,CAAC,SAAS,EAAE,CAAC;QACvD,MAAM,MAAM,GAAG,UAAU,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;QAE7C,IAAI,CAAC,WAAW,GAAG,EAAE,QAAQ,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC;QAEjE,2CAA2C;QAC3C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC9C,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAE,8BAA8B;QAC1E,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAY,4BAA4B;IAC1E,CAAC;IAED,UAAU,CAAC,KAAU;QACnB,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE,KAAK,CAAC,CAAC;QAEtC,IAAI,KAAK,IAAI,KAAK,CAAC,UAAU,EAAE,CAAC;YAC9B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;YACzB,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC;oBACrD,6EAA6E;oBAC7E,wEAAwE;oBACxE,MAAM,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,sBAAsB,EAAE,CAAC;oBACrE,IAAI,CAAC,WAAW,CAAC,WAAW,GAAG,WAAW,CAAC,IAAI,CAAC;oBAChD,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,IAAI,WAAW,CAAC,QAAQ,EAAE,CAAC;oBACvD,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,KAAK,CAAC,UAAU,CAAC,KAAK,CAAE,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;oBAChF,IAAI,CAAC,WAAW,CAAC,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC;oBAC/C,uDAAuD;oBACvD,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAG,IAAI,CAAC,UAAU,CAAC,CAAC;gBAC1C,CAAC;YACH,CAAC,EAAE,CAAC,CAAC,CAAC;QACR,CAAC;IAGH,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,mBAAmB;QACjB,IAAI,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC5B,MAAM,OAAO,GAAG,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,IAAI,IAAI,CAAC,WAAW,EAAE,MAAM,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;YACvG,OAAO,OAAO,CAAC;QACjB,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;uGAxGU,mBAAmB;2FAAnB,mBAAmB,yTARnB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,mBAAmB,CAAC;gBAClD,KAAK,EAAE,IAAI;aACZ;SACF,iKAUU,OAAO,gDCxBpB,2dASM;;2FDOO,mBAAmB;kBAZ/B,SAAS;+BACE,iBAAiB,aAGhB;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,oBAAoB,CAAC;4BAClD,KAAK,EAAE,IAAI;yBACZ;qBACF;8BAGQ,cAAc;sBAAtB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBAEsC,UAAU;sBAArD,SAAS;uBAAC,YAAY,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBACtB,UAAU;sBAA7B,SAAS;uBAAC,OAAO;gBAER,iBAAiB;sBAA1B,MAAM;gBACG,aAAa;sBAAtB,MAAM","sourcesContent":["import { AfterViewInit, Component, ElementRef, forwardRef, Input, Output, EventEmitter, ViewChild } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor, NgModel } from '@angular/forms';\r\nimport intlTelInput from 'intl-tel-input';\r\n\r\n@Component({\r\n  selector: 'app-phone-input',\r\n  templateUrl: './phone-input.component.html',\r\n  styleUrls: ['./phone-input.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => PhoneInputComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class PhoneInputComponent implements AfterViewInit, ControlValueAccessor {\r\n  @Input() initialCountry: string = 'us';\r\n  @Input() preferredCountries: string[] = [];\r\n  @Input() nationalMode: boolean = true;\r\n  @Input() separateDialCode: boolean = true;\r\n  @Input() otherOptions: any = {};\r\n\r\n  @ViewChild('phoneInput', { static: false }) phoneInput: ElementRef;\r\n  @ViewChild(NgModel) ngModelRef: NgModel; // Reference to NgModel instance\r\n\r\n  @Output() phoneNumberChange = new EventEmitter<any>();\r\n  @Output() ngModelChange = new EventEmitter<any>();\r\n\r\n  phoneNumber: any = { dialCode: '', countryCode: '', e164Number: '', number: '' };\r\n  phoneInputInstance: any;\r\n\r\n  onChange = (value: any) => {};\r\n  onTouched = () => {};\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.phoneInput && this.phoneInput.nativeElement) {\r\n      this.initializePhoneInput();\r\n    }\r\n    if (this.phoneInputInstance) {\r\n      this.phoneInputInstance.setNumber(this.phoneNumber.e164Number || ''); // Set initial value if available\r\n    }\r\n  }\r\n\r\n  initializePhoneInput(): void {\r\n    const options = {\r\n      initialCountry: this.initialCountry,\r\n      preferredCountries: this.preferredCountries,\r\n      nationalMode: this.nationalMode,\r\n      separateDialCode: this.separateDialCode,\r\n      utilsScript: 'https://cdnjs.cloudflare.com/ajax/libs/intl-tel-input/17.0.8/js/utils.js',\r\n      ...this.otherOptions\r\n    };\r\n\r\n    this.phoneInputInstance = intlTelInput(this.phoneInput.nativeElement, options);\r\n\r\n    this.phoneInput.nativeElement.addEventListener('countrychange', () => {\r\n      this.updatePhoneNumber();\r\n    });\r\n\r\n    this.phoneInput.nativeElement.addEventListener('input', () => {\r\n      this.updatePhoneNumber();\r\n    });\r\n\r\n    if (this.phoneNumber.e164Number) {\r\n      this.phoneInputInstance.setNumber(this.phoneNumber.e164Number);\r\n    }\r\n  }\r\n\r\n  updatePhoneNumber(): void {\r\n    const dialCode = '+' + this.phoneInputInstance.getSelectedCountryData().dialCode;\r\n    const countryCode = this.phoneInputInstance.getSelectedCountryData().iso2;\r\n    const e164Number = this.phoneInputInstance.getNumber();\r\n    const number = e164Number.split(dialCode)[1];\r\n\r\n    this.phoneNumber = { dialCode, countryCode, e164Number, number };\r\n\r\n    // Emit changes for FormControl and ngModel\r\n    this.phoneNumberChange.emit(this.phoneNumber);\r\n    this.ngModelChange.emit(this.phoneNumber);  // For ngModel two-way binding\r\n    this.onChange(this.phoneNumber);            // For reactive form support\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    console.log(\"In Write Value:\", value);\r\n    \r\n    if (value && value.e164Number) {\r\n      this.phoneNumber = value;\r\n      setTimeout(() => {\r\n        if (this.phoneInput && this.phoneInput.nativeElement) {\r\n          // Set the number in intl-tel-input, which will automatically set the country\r\n          // If you need to get the selected country code after setting the number\r\n          const countryData = this.phoneInputInstance.getSelectedCountryData();\r\n          this.phoneNumber.countryCode = countryData.iso2;\r\n          this.phoneNumber.dialCode = `+${countryData.dialCode}`;\r\n          this.phoneNumber.number = value.e164Number.split( this.phoneNumber.dialCode)[1];\r\n          this.phoneNumber.e164Number = value.e164Number;\r\n          // this.phoneInputInstance.setNumber(value.e164Number);\r\n          console.log(\"Phone:\",  this.phoneInput);    \r\n        }\r\n      }, 0);\r\n    }\r\n    \r\n    \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  validatePhoneNumber(): boolean {\r\n    if (this.phoneInputInstance) {\r\n      const isValid = this.phoneInputInstance.isValidNumber() || this.phoneNumber?.number?.startsWith('555');\r\n      return isValid;\r\n    }\r\n    return false;\r\n  }\r\n}","<div class=\"phone-input-wrapper tel-input-container\">\r\n    <input #phoneInput type=\"tel\" [(ngModel)]=\"phoneNumber.number\"\r\n        name=\"phoneNumber\" [required]=\"true\" #phone=\"ngModel\"\r\n        [ngClass]=\"{'is-invalid': !validatePhoneNumber() && phone.touched}\">\r\n\r\n    <!-- Validation feedback -->\r\n    <!-- <div *ngIf=\"!validatePhoneNumber() && phone.touched\" class=\"text-danger\">\r\n        Invalid phone number.\r\n    </div> -->\r\n</div>"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { AutolinkPipe } from './autolink.pipe';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class AutolinkPipeModule {
|
|
6
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: AutolinkPipeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
7
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.9", ngImport: i0, type: AutolinkPipeModule, declarations: [AutolinkPipe], imports: [CommonModule], exports: [AutolinkPipe] });
|
|
8
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: AutolinkPipeModule, imports: [CommonModule] });
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: AutolinkPipeModule, decorators: [{
|
|
11
|
+
type: NgModule,
|
|
12
|
+
args: [{
|
|
13
|
+
imports: [
|
|
14
|
+
CommonModule
|
|
15
|
+
],
|
|
16
|
+
declarations: [AutolinkPipe],
|
|
17
|
+
exports: [AutolinkPipe]
|
|
18
|
+
}]
|
|
19
|
+
}] });
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2xpbmsubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvamNvbnN1bWVyLXNoYXJlZC9zcmMvbGliL3BpcGVzL2F1dG9saW5rL2F1dG9saW5rLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7O0FBUy9DLE1BQU0sT0FBTyxrQkFBa0I7dUdBQWxCLGtCQUFrQjt3R0FBbEIsa0JBQWtCLGlCQUhaLFlBQVksYUFGdkIsWUFBWSxhQUdOLFlBQVk7d0dBRWIsa0JBQWtCLFlBTHZCLFlBQVk7OzJGQUtQLGtCQUFrQjtrQkFQOUIsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUU7d0JBQ0wsWUFBWTtxQkFDZjtvQkFDRCxZQUFZLEVBQUUsQ0FBQyxZQUFZLENBQUM7b0JBQzVCLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztpQkFDMUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBBdXRvbGlua1BpcGUgfSBmcm9tICcuL2F1dG9saW5rLnBpcGUnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICAgIGltcG9ydHM6IFtcclxuICAgICAgICBDb21tb25Nb2R1bGVcclxuICAgIF0sXHJcbiAgICBkZWNsYXJhdGlvbnM6IFtBdXRvbGlua1BpcGVdLFxyXG4gICAgZXhwb3J0czogW0F1dG9saW5rUGlwZV1cclxufSlcclxuZXhwb3J0IGNsYXNzIEF1dG9saW5rUGlwZU1vZHVsZSB7fSJdfQ==
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { DateFormatPipe } from './date-format.pipe';
|
|
3
|
+
import { CommonModule } from '@angular/common';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class DateFormatPipeModule {
|
|
6
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DateFormatPipeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
7
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.9", ngImport: i0, type: DateFormatPipeModule, declarations: [DateFormatPipe], imports: [CommonModule], exports: [DateFormatPipe] });
|
|
8
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DateFormatPipeModule, providers: [DateFormatPipe], imports: [CommonModule] });
|
|
9
|
+
}
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DateFormatPipeModule, decorators: [{
|
|
11
|
+
type: NgModule,
|
|
12
|
+
args: [{
|
|
13
|
+
imports: [CommonModule],
|
|
14
|
+
declarations: [DateFormatPipe],
|
|
15
|
+
exports: [DateFormatPipe],
|
|
16
|
+
providers: [DateFormatPipe]
|
|
17
|
+
}]
|
|
18
|
+
}] });
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1mb3JtYXQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvamNvbnN1bWVyLXNoYXJlZC9zcmMvbGliL3BpcGVzL2RhdGUtZm9ybWF0L2RhdGUtZm9ybWF0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNwRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7O0FBUS9DLE1BQU0sT0FBTyxvQkFBb0I7dUdBQXBCLG9CQUFvQjt3R0FBcEIsb0JBQW9CLGlCQUpkLGNBQWMsYUFEbkIsWUFBWSxhQUVaLGNBQWM7d0dBR2Ysb0JBQW9CLGFBRmxCLENBQUMsY0FBYyxDQUFDLFlBSGpCLFlBQVk7OzJGQUtiLG9CQUFvQjtrQkFOaEMsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7b0JBQ3ZCLFlBQVksRUFBRSxDQUFDLGNBQWMsQ0FBQztvQkFDOUIsT0FBTyxFQUFFLENBQUMsY0FBYyxDQUFDO29CQUN6QixTQUFTLEVBQUUsQ0FBQyxjQUFjLENBQUM7aUJBQzlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRGF0ZUZvcm1hdFBpcGUgfSBmcm9tICcuL2RhdGUtZm9ybWF0LnBpcGUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxyXG4gICAgZGVjbGFyYXRpb25zOiBbRGF0ZUZvcm1hdFBpcGVdLFxyXG4gICAgZXhwb3J0czogW0RhdGVGb3JtYXRQaXBlXSxcclxuICAgIHByb3ZpZGVyczogW0RhdGVGb3JtYXRQaXBlXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRGF0ZUZvcm1hdFBpcGVNb2R1bGUge1xyXG5cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import { DatePipe } from '@angular/common';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class DateFormatPipe {
|
|
5
|
+
transform(value, args) {
|
|
6
|
+
return null;
|
|
7
|
+
}
|
|
8
|
+
transformTofilterDate(value) {
|
|
9
|
+
const datePipe = new DatePipe('en-US');
|
|
10
|
+
value = datePipe.transform(value, 'yyyy-MM-dd');
|
|
11
|
+
return value;
|
|
12
|
+
}
|
|
13
|
+
transformTomciDate(value) {
|
|
14
|
+
const datePipe = new DatePipe('en-US');
|
|
15
|
+
value = datePipe.transform(value, 'yyyy/MM/dd');
|
|
16
|
+
return value;
|
|
17
|
+
}
|
|
18
|
+
transformToDIsplayFormat(value) {
|
|
19
|
+
const datePipe = new DatePipe('en-US');
|
|
20
|
+
value = datePipe.transform(value, 'dd/MM/y');
|
|
21
|
+
return value;
|
|
22
|
+
}
|
|
23
|
+
transformToMonthlyDate(value) {
|
|
24
|
+
const datePipe = new DatePipe('en-US');
|
|
25
|
+
value = datePipe.transform(value, 'MMM d, y');
|
|
26
|
+
return value;
|
|
27
|
+
}
|
|
28
|
+
transformToDateWithTime(value) {
|
|
29
|
+
const datePipe = new DatePipe('en-US');
|
|
30
|
+
value = datePipe.transform(value, 'dd/MM/yyyy HH:mm a');
|
|
31
|
+
return value;
|
|
32
|
+
}
|
|
33
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DateFormatPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
34
|
+
static ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.9", ngImport: i0, type: DateFormatPipe, name: "dateFormat" });
|
|
35
|
+
}
|
|
36
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: DateFormatPipe, decorators: [{
|
|
37
|
+
type: Pipe,
|
|
38
|
+
args: [{
|
|
39
|
+
name: 'dateFormat'
|
|
40
|
+
}]
|
|
41
|
+
}] });
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1mb3JtYXQucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2pjb25zdW1lci1zaGFyZWQvc3JjL2xpYi9waXBlcy9kYXRlLWZvcm1hdC9kYXRlLWZvcm1hdC5waXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQWlCLE1BQU0sZUFBZSxDQUFDO0FBQ3BELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7QUFLM0MsTUFBTSxPQUFPLGNBQWM7SUFFekIsU0FBUyxDQUFDLEtBQVUsRUFBRSxJQUFVO1FBQzlCLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQUVELHFCQUFxQixDQUFDLEtBQVU7UUFDOUIsTUFBTSxRQUFRLEdBQUcsSUFBSSxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDdkMsS0FBSyxHQUFHLFFBQVEsQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLFlBQVksQ0FBQyxDQUFDO1FBQ2hELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUNELGtCQUFrQixDQUFDLEtBQVU7UUFDM0IsTUFBTSxRQUFRLEdBQUcsSUFBSSxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDdkMsS0FBSyxHQUFHLFFBQVEsQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLFlBQVksQ0FBQyxDQUFDO1FBQ2hELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUNELHdCQUF3QixDQUFDLEtBQVU7UUFDakMsTUFBTSxRQUFRLEdBQUcsSUFBSSxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDdkMsS0FBSyxHQUFHLFFBQVEsQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLFNBQVMsQ0FBQyxDQUFDO1FBQzdDLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUNELHNCQUFzQixDQUFDLEtBQVU7UUFDL0IsTUFBTSxRQUFRLEdBQUcsSUFBSSxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDdkMsS0FBSyxHQUFHLFFBQVEsQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQzlDLE9BQU8sS0FBSyxDQUFDO0lBRWYsQ0FBQztJQUNELHVCQUF1QixDQUFDLEtBQVU7UUFDaEMsTUFBTSxRQUFRLEdBQUcsSUFBSSxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDdkMsS0FBSyxHQUFHLFFBQVEsQ0FBQyxTQUFTLENBQUMsS0FBSyxFQUFFLG9CQUFvQixDQUFDLENBQUM7UUFDeEQsT0FBTyxLQUFLLENBQUM7SUFDZixDQUFDO3VHQS9CVSxjQUFjO3FHQUFkLGNBQWM7OzJGQUFkLGNBQWM7a0JBSDFCLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLFlBQVk7aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBEYXRlUGlwZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcblxyXG5AUGlwZSh7XHJcbiAgbmFtZTogJ2RhdGVGb3JtYXQnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBEYXRlRm9ybWF0UGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xyXG5cclxuICB0cmFuc2Zvcm0odmFsdWU6IGFueSwgYXJncz86IGFueSk6IGFueSB7XHJcbiAgICByZXR1cm4gbnVsbDtcclxuICB9XHJcblxyXG4gIHRyYW5zZm9ybVRvZmlsdGVyRGF0ZSh2YWx1ZTogYW55KSB7XHJcbiAgICBjb25zdCBkYXRlUGlwZSA9IG5ldyBEYXRlUGlwZSgnZW4tVVMnKTtcclxuICAgIHZhbHVlID0gZGF0ZVBpcGUudHJhbnNmb3JtKHZhbHVlLCAneXl5eS1NTS1kZCcpO1xyXG4gICAgcmV0dXJuIHZhbHVlO1xyXG4gIH1cclxuICB0cmFuc2Zvcm1Ub21jaURhdGUodmFsdWU6IGFueSkge1xyXG4gICAgY29uc3QgZGF0ZVBpcGUgPSBuZXcgRGF0ZVBpcGUoJ2VuLVVTJyk7XHJcbiAgICB2YWx1ZSA9IGRhdGVQaXBlLnRyYW5zZm9ybSh2YWx1ZSwgJ3l5eXkvTU0vZGQnKTtcclxuICAgIHJldHVybiB2YWx1ZTtcclxuICB9XHJcbiAgdHJhbnNmb3JtVG9ESXNwbGF5Rm9ybWF0KHZhbHVlOiBhbnkpIHtcclxuICAgIGNvbnN0IGRhdGVQaXBlID0gbmV3IERhdGVQaXBlKCdlbi1VUycpO1xyXG4gICAgdmFsdWUgPSBkYXRlUGlwZS50cmFuc2Zvcm0odmFsdWUsICdkZC9NTS95Jyk7XHJcbiAgICByZXR1cm4gdmFsdWU7XHJcbiAgfVxyXG4gIHRyYW5zZm9ybVRvTW9udGhseURhdGUodmFsdWU6IGFueSkge1xyXG4gICAgY29uc3QgZGF0ZVBpcGUgPSBuZXcgRGF0ZVBpcGUoJ2VuLVVTJyk7XHJcbiAgICB2YWx1ZSA9IGRhdGVQaXBlLnRyYW5zZm9ybSh2YWx1ZSwgJ01NTSBkLCB5Jyk7XHJcbiAgICByZXR1cm4gdmFsdWU7XHJcblxyXG4gIH1cclxuICB0cmFuc2Zvcm1Ub0RhdGVXaXRoVGltZSh2YWx1ZTogYW55KSB7XHJcbiAgICBjb25zdCBkYXRlUGlwZSA9IG5ldyBEYXRlUGlwZSgnZW4tVVMnKTtcclxuICAgIHZhbHVlID0gZGF0ZVBpcGUudHJhbnNmb3JtKHZhbHVlLCAnZGQvTU0veXl5eSBISDptbSBhJyk7XHJcbiAgICByZXR1cm4gdmFsdWU7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|