simpo-component-library 2.0.93 → 2.0.95
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/components/payment-details/payment-details.component.mjs +151 -0
- package/esm2022/lib/sections/registration-form/registration-form.component.mjs +87 -3
- package/esm2022/lib/services/events.service.mjs +2 -1
- package/esm2022/lib/services/rest.service.mjs +8 -1
- package/fesm2022/simpo-component-library.mjs +94 -2
- package/fesm2022/simpo-component-library.mjs.map +1 -1
- package/lib/components/payment-details/payment-details.component.d.ts +18 -0
- package/lib/directive/background-directive.d.ts +1 -1
- package/lib/directive/button-directive.directive.d.ts +1 -1
- package/lib/directive/color.directive.d.ts +1 -1
- package/lib/sections/pricing-section/pricing-section.component.d.ts +1 -1
- package/lib/sections/registration-form/registration-form.component.d.ts +14 -2
- package/lib/services/events.service.d.ts +1 -0
- package/lib/services/rest.service.d.ts +2 -0
- package/package.json +1 -1
- package/simpo-component-library-2.0.95.tgz +0 -0
- package/simpo-component-library-2.0.93.tgz +0 -0
@@ -0,0 +1,151 @@
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
2
|
+
import { Component, Input } from '@angular/core';
|
3
|
+
import { FormsModule } from '@angular/forms';
|
4
|
+
import * as i0 from "@angular/core";
|
5
|
+
import * as i1 from "@angular/common";
|
6
|
+
import * as i2 from "@angular/forms";
|
7
|
+
export class PaymentDetailsComponent {
|
8
|
+
constructor() {
|
9
|
+
this.subscriptionsData = [];
|
10
|
+
this.Object = Object;
|
11
|
+
this.feeStructure = {
|
12
|
+
"id": '1234',
|
13
|
+
"businessDetails": {
|
14
|
+
"id": '1234'
|
15
|
+
},
|
16
|
+
"grades": [
|
17
|
+
{
|
18
|
+
"_id": "1234",
|
19
|
+
"name": "Grade II"
|
20
|
+
},
|
21
|
+
{
|
22
|
+
"_id": "1234",
|
23
|
+
"name": "Grade IV"
|
24
|
+
}
|
25
|
+
],
|
26
|
+
"board": "STATE",
|
27
|
+
"academicYearStart": 2024,
|
28
|
+
"academicYearEnd": 2025,
|
29
|
+
"feeConfigs": [
|
30
|
+
{
|
31
|
+
"feeTypeId": '12324',
|
32
|
+
"feeHeadId": '1234',
|
33
|
+
"feeType": "Tution fee",
|
34
|
+
"feeHead": "exam fee",
|
35
|
+
"amount": 300,
|
36
|
+
"discountAmount": 0,
|
37
|
+
"isFixed": false
|
38
|
+
}
|
39
|
+
],
|
40
|
+
"subscriptionPlans": [],
|
41
|
+
"totalAmount": 300,
|
42
|
+
"createdTimestamp": {
|
43
|
+
"$date": "2024-12-15T07:10:54.889Z"
|
44
|
+
},
|
45
|
+
"updatedTimestamp": {
|
46
|
+
"$date": "2024-12-15T07:10:54.889Z"
|
47
|
+
},
|
48
|
+
"active": true,
|
49
|
+
};
|
50
|
+
this.defaultImage = 'https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/917067c1734337280303cancel.png';
|
51
|
+
this.subscriptions = {
|
52
|
+
"Food Fee": [
|
53
|
+
{
|
54
|
+
subscriptionTitle: 'Breakfast',
|
55
|
+
pricing: {
|
56
|
+
"WEEKLY": 2000,
|
57
|
+
"MONTHLY": 3000,
|
58
|
+
"YEARLY": 4000
|
59
|
+
}
|
60
|
+
},
|
61
|
+
{
|
62
|
+
subscriptionTitle: 'Lunch',
|
63
|
+
pricing: {
|
64
|
+
"WEEKLY": 2000,
|
65
|
+
"MONTHLY": 3000,
|
66
|
+
"YEARLY": 4000
|
67
|
+
}
|
68
|
+
},
|
69
|
+
{
|
70
|
+
subscriptionTitle: 'Snacks',
|
71
|
+
pricing: {
|
72
|
+
"WEEKLY": 2000,
|
73
|
+
"MONTHLY": 3000,
|
74
|
+
"YEARLY": 4000
|
75
|
+
}
|
76
|
+
}
|
77
|
+
]
|
78
|
+
};
|
79
|
+
}
|
80
|
+
ngOnInit() {
|
81
|
+
this.feeStructure = this.admissionData.studentFeeStructure;
|
82
|
+
this.subscriptions = this.arrangeSubscriptionForAdmission(this.subscriptionsData);
|
83
|
+
this.feeConfig = this.arrangeFeeConfig(this.feeStructure.feeConfigs);
|
84
|
+
this.calculateTotalAmount();
|
85
|
+
}
|
86
|
+
toggleSelection(subscription, frequency) {
|
87
|
+
if (!this.feeStructure.subscriptionPlans)
|
88
|
+
this.feeStructure.subscriptionPlans = [];
|
89
|
+
let removeIndex = -1;
|
90
|
+
for (let i = 0; i < this.feeStructure.subscriptionPlans.length; i++) {
|
91
|
+
let sub = this.feeStructure.subscriptionPlans[i];
|
92
|
+
if (sub.subId === subscription.subId) {
|
93
|
+
removeIndex = i;
|
94
|
+
break;
|
95
|
+
}
|
96
|
+
}
|
97
|
+
if (removeIndex == -1) {
|
98
|
+
this.feeStructure.subscriptionPlans.push({ ...subscription, frequency: frequency });
|
99
|
+
this.calculateTotalAmount();
|
100
|
+
return;
|
101
|
+
}
|
102
|
+
this.feeStructure.subscriptionPlans.splice(removeIndex, 1);
|
103
|
+
if (subscription.selectedOption === frequency) {
|
104
|
+
subscription.selectedOption = null;
|
105
|
+
}
|
106
|
+
else {
|
107
|
+
subscription.selectedOption = frequency;
|
108
|
+
this.feeStructure.subscriptionPlans.push({ ...subscription, frequency: frequency });
|
109
|
+
}
|
110
|
+
this.calculateTotalAmount();
|
111
|
+
}
|
112
|
+
calculateTotalAmount() {
|
113
|
+
this.feeStructure.totalAmount = 0;
|
114
|
+
for (let config of this.feeStructure.feeConfigs) {
|
115
|
+
this.feeStructure.totalAmount += config.amount;
|
116
|
+
}
|
117
|
+
for (let subscription of this.feeStructure.subscriptionPlans) {
|
118
|
+
this.feeStructure.totalAmount += subscription.pricing[subscription.frequency];
|
119
|
+
}
|
120
|
+
}
|
121
|
+
arrangeSubscriptionForAdmission(subscriptionList) {
|
122
|
+
let response = {};
|
123
|
+
for (let subscription of subscriptionList) {
|
124
|
+
if (!response[subscription.subscriptionType]) {
|
125
|
+
response[subscription.subscriptionType] = [];
|
126
|
+
}
|
127
|
+
response[subscription.subscriptionType].push(subscription);
|
128
|
+
}
|
129
|
+
return response;
|
130
|
+
}
|
131
|
+
arrangeFeeConfig(feeConfigList) {
|
132
|
+
let response = {};
|
133
|
+
for (let config of feeConfigList) {
|
134
|
+
if (!response[config.feeType])
|
135
|
+
response[config.feeType] = [];
|
136
|
+
response[config.feeType].push(config);
|
137
|
+
}
|
138
|
+
return response;
|
139
|
+
}
|
140
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: PaymentDetailsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
141
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: PaymentDetailsComponent, isStandalone: true, selector: "simpo-payment-details", inputs: { admissionData: "admissionData", subscriptionsData: "subscriptionsData" }, ngImport: i0, template: "<section class=\"main-section\">\r\n <div class=\"row\">\r\n <div class=\"col-md-6\">\r\n <div class=\"heading left-side\">\r\n Admission Fee\r\n </div>\r\n\r\n <div class=\"left-side mt-10\" *ngFor=\"let configList of Object.keys(feeConfig)\">\r\n <div class=\"heading mb-20\">{{configList}}</div>\r\n\r\n <div class=\"d-flex justify-space mt-10 mb-15\" *ngFor=\"let config of feeConfig[configList]\">\r\n <p class=\"sub-heading mb-0\">{{config.feeHead}}</p>\r\n <p class=\"amount mb-0\">\u20B9 {{config.amount}}</p>\r\n </div>\r\n </div>\r\n\r\n <div class=\"left-side mt-10\" *ngFor=\"let type of Object.keys(subscriptions)\">\r\n <p class=\"heading\">{{type}}</p>\r\n\r\n <table class=\"subscription-table w-100\">\r\n <thead>\r\n <th>Subscription Title</th>\r\n <th>Monthly</th>\r\n <th>Quaterly</th>\r\n <th>Yearly</th>\r\n <th>On Demand</th>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let data of subscriptions[type];let i = index\">\r\n <td>{{data.subName}}</td>\r\n <td>\r\n <div class=\"form-check\" *ngIf=\"data.pricing['QUARTERLY']\">\r\n <input class=\"form-check-input\" type=\"radio\" name=\"subscription{{i}}\" [value]=\"'MONTHLY'\" (click)=\"toggleSelection(data, 'MONTHLY')\" [checked]=\"data.selectedOption === 'MONTHLY'\" [(ngModel)]=\"data.selectedOption\" id=\"flexRadioDefault2\">\r\n <label class=\"form-check-label\" for=\"flexCheckChecked\">\r\n \u20B9 {{data.pricing['MONTHLY']}}\r\n </label>\r\n </div>\r\n <img class=\"defaultImage\" *ngIf=\"!data.pricing['QUARTERLY']\" [src]=\"defaultImage\" alt=\"\">\r\n </td>\r\n <td>\r\n <div class=\"form-check\" *ngIf=\"data.pricing['MONTHLY']\">\r\n <input class=\"form-check-input\" type=\"radio\" name=\"subscription{{i}}\" [value]=\"'QUARTERLY'\" (click)=\"toggleSelection(data, 'QUARTERLY')\" [checked]=\"data.selectedOption === 'QUARTERLY'\" [(ngModel)]=\"data.selectedOption\" id=\"flexCheckChecked\">\r\n <label class=\"form-check-label\" for=\"flexCheckChecked\">\r\n \u20B9 {{data.pricing['QUARTERLY']}}\r\n </label>\r\n <img class=\"defaultImage\" *ngIf=\"!data.pricing['MONTHLY']\" [src]=\"defaultImage\" alt=\"\">\r\n </div>\r\n </td>\r\n <td>\r\n <div class=\"form-check\" *ngIf=\"data.pricing['ANNUALLY']\">\r\n <input class=\"form-check-input\" type=\"radio\" name=\"subscription{{i}}\" [value]=\"'ANNUALLY'\" (click)=\"toggleSelection(data, 'ANNUALLY')\" [checked]=\"data.selectedOption === 'ANNUALLY'\" [(ngModel)]=\"data.selectedOption\" id=\"flexCheckChecked\">\r\n <label class=\"form-check-label\" for=\"flexCheckChecked\">\r\n \u20B9 {{data.pricing['ANNUALLY']}}\r\n </label>\r\n </div>\r\n <img class=\"defaultImage\" *ngIf=\"!data.pricing['ANNUALLY']\" [src]=\"defaultImage\" alt=\"\">\r\n </td>\r\n <td>\r\n <div class=\"form-check\" *ngIf=\"data.pricing['ONDEMAND']\">\r\n <input class=\"form-check-input\" type=\"radio\" name=\"subscription{{i}}\" [value]=\"'ONDEMAND'\" (click)=\"toggleSelection(data, 'ONDEMAND')\" [checked]=\"data.selectedOption === 'ONDEMAND'\" [(ngModel)]=\"data.selectedOption\" id=\"flexCheckChecked\">\r\n <label class=\"form-check-label\" for=\"flexCheckChecked\">\r\n \u20B9 {{data.pricing['ONDEMAND']}}\r\n </label>\r\n </div>\r\n <img class=\"defaultImage\" *ngIf=\"!data.pricing['ONDEMAND']\" [src]=\"defaultImage\" alt=\"\">\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n </div>\r\n <div class=\"col-md-6 right-side\">\r\n <div class=\"heading mb-20\">\r\n Fee Calculation\r\n </div>\r\n <div class=\"d-flex justify-space mt-10 mb-15\" *ngFor=\"let config of feeStructure.feeConfigs\">\r\n <p class=\"sub-heading mb-0\">{{config.feeHead}}</p>\r\n <p class=\"amount mb-0\">\u20B9 {{config.amount}}</p>\r\n </div>\r\n\r\n <div class=\"d-flex justify-space mt-10 mb-15\" *ngFor=\"let subscripition of feeStructure.subscriptionPlans\">\r\n <p class=\"sub-heading mb-0\">{{subscripition.subName}}</p>\r\n <p class=\"amount mb-0\">\u20B9 {{subscripition.pricing[subscripition.frequency]}}</p>\r\n </div>\r\n\r\n <div class=\"total-fee\">\r\n <div class=\"heading mb-5\">\r\n Total Fee\r\n </div>\r\n <div class=\"amount\">\r\n \u20B9 {{feeStructure.totalAmount}}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</section>\r\n", styles: [".heading{font-size:18px;font-weight:500}.left-side{background:#fafcff99;padding:2rem}.mt-10{margin-top:10px}.justify-space{justify-content:space-between}.sub-heading,.amount{font-size:16px;font-weight:500}.mb-0{margin-bottom:0}.mb-20{margin-bottom:20px}.mb-15{margin-bottom:15px}.subscription-table{width:50%}.subscription-table th{color:#434443;font-weight:400;font-size:16px;font-family:DM SANS}.subscription-table td{font-weight:500;color:#000;font-size:16px;margin-top:67px;padding-top:10px}.right-side{background-color:#fdfbfa;padding:2rem;position:relative}.right-side .sub-heading{font-size:18px}.right-side .amount{font-size:16px}.right-side .heading{font-weight:400}.mb-5{margin-bottom:5px}.total-fee{position:absolute;bottom:20px;width:90%}.total-fee .amount{background:#fff;height:87px;display:flex;align-items:center;justify-content:center;font-size:32px;border-radius:8px}.defaultImage{height:15px;width:15px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: FormsModule }, { 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.RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: ["name", "formControlName", "value"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] }); }
|
142
|
+
}
|
143
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: PaymentDetailsComponent, decorators: [{
|
144
|
+
type: Component,
|
145
|
+
args: [{ selector: 'simpo-payment-details', standalone: true, imports: [CommonModule, FormsModule], template: "<section class=\"main-section\">\r\n <div class=\"row\">\r\n <div class=\"col-md-6\">\r\n <div class=\"heading left-side\">\r\n Admission Fee\r\n </div>\r\n\r\n <div class=\"left-side mt-10\" *ngFor=\"let configList of Object.keys(feeConfig)\">\r\n <div class=\"heading mb-20\">{{configList}}</div>\r\n\r\n <div class=\"d-flex justify-space mt-10 mb-15\" *ngFor=\"let config of feeConfig[configList]\">\r\n <p class=\"sub-heading mb-0\">{{config.feeHead}}</p>\r\n <p class=\"amount mb-0\">\u20B9 {{config.amount}}</p>\r\n </div>\r\n </div>\r\n\r\n <div class=\"left-side mt-10\" *ngFor=\"let type of Object.keys(subscriptions)\">\r\n <p class=\"heading\">{{type}}</p>\r\n\r\n <table class=\"subscription-table w-100\">\r\n <thead>\r\n <th>Subscription Title</th>\r\n <th>Monthly</th>\r\n <th>Quaterly</th>\r\n <th>Yearly</th>\r\n <th>On Demand</th>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let data of subscriptions[type];let i = index\">\r\n <td>{{data.subName}}</td>\r\n <td>\r\n <div class=\"form-check\" *ngIf=\"data.pricing['QUARTERLY']\">\r\n <input class=\"form-check-input\" type=\"radio\" name=\"subscription{{i}}\" [value]=\"'MONTHLY'\" (click)=\"toggleSelection(data, 'MONTHLY')\" [checked]=\"data.selectedOption === 'MONTHLY'\" [(ngModel)]=\"data.selectedOption\" id=\"flexRadioDefault2\">\r\n <label class=\"form-check-label\" for=\"flexCheckChecked\">\r\n \u20B9 {{data.pricing['MONTHLY']}}\r\n </label>\r\n </div>\r\n <img class=\"defaultImage\" *ngIf=\"!data.pricing['QUARTERLY']\" [src]=\"defaultImage\" alt=\"\">\r\n </td>\r\n <td>\r\n <div class=\"form-check\" *ngIf=\"data.pricing['MONTHLY']\">\r\n <input class=\"form-check-input\" type=\"radio\" name=\"subscription{{i}}\" [value]=\"'QUARTERLY'\" (click)=\"toggleSelection(data, 'QUARTERLY')\" [checked]=\"data.selectedOption === 'QUARTERLY'\" [(ngModel)]=\"data.selectedOption\" id=\"flexCheckChecked\">\r\n <label class=\"form-check-label\" for=\"flexCheckChecked\">\r\n \u20B9 {{data.pricing['QUARTERLY']}}\r\n </label>\r\n <img class=\"defaultImage\" *ngIf=\"!data.pricing['MONTHLY']\" [src]=\"defaultImage\" alt=\"\">\r\n </div>\r\n </td>\r\n <td>\r\n <div class=\"form-check\" *ngIf=\"data.pricing['ANNUALLY']\">\r\n <input class=\"form-check-input\" type=\"radio\" name=\"subscription{{i}}\" [value]=\"'ANNUALLY'\" (click)=\"toggleSelection(data, 'ANNUALLY')\" [checked]=\"data.selectedOption === 'ANNUALLY'\" [(ngModel)]=\"data.selectedOption\" id=\"flexCheckChecked\">\r\n <label class=\"form-check-label\" for=\"flexCheckChecked\">\r\n \u20B9 {{data.pricing['ANNUALLY']}}\r\n </label>\r\n </div>\r\n <img class=\"defaultImage\" *ngIf=\"!data.pricing['ANNUALLY']\" [src]=\"defaultImage\" alt=\"\">\r\n </td>\r\n <td>\r\n <div class=\"form-check\" *ngIf=\"data.pricing['ONDEMAND']\">\r\n <input class=\"form-check-input\" type=\"radio\" name=\"subscription{{i}}\" [value]=\"'ONDEMAND'\" (click)=\"toggleSelection(data, 'ONDEMAND')\" [checked]=\"data.selectedOption === 'ONDEMAND'\" [(ngModel)]=\"data.selectedOption\" id=\"flexCheckChecked\">\r\n <label class=\"form-check-label\" for=\"flexCheckChecked\">\r\n \u20B9 {{data.pricing['ONDEMAND']}}\r\n </label>\r\n </div>\r\n <img class=\"defaultImage\" *ngIf=\"!data.pricing['ONDEMAND']\" [src]=\"defaultImage\" alt=\"\">\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n </div>\r\n <div class=\"col-md-6 right-side\">\r\n <div class=\"heading mb-20\">\r\n Fee Calculation\r\n </div>\r\n <div class=\"d-flex justify-space mt-10 mb-15\" *ngFor=\"let config of feeStructure.feeConfigs\">\r\n <p class=\"sub-heading mb-0\">{{config.feeHead}}</p>\r\n <p class=\"amount mb-0\">\u20B9 {{config.amount}}</p>\r\n </div>\r\n\r\n <div class=\"d-flex justify-space mt-10 mb-15\" *ngFor=\"let subscripition of feeStructure.subscriptionPlans\">\r\n <p class=\"sub-heading mb-0\">{{subscripition.subName}}</p>\r\n <p class=\"amount mb-0\">\u20B9 {{subscripition.pricing[subscripition.frequency]}}</p>\r\n </div>\r\n\r\n <div class=\"total-fee\">\r\n <div class=\"heading mb-5\">\r\n Total Fee\r\n </div>\r\n <div class=\"amount\">\r\n \u20B9 {{feeStructure.totalAmount}}\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</section>\r\n", styles: [".heading{font-size:18px;font-weight:500}.left-side{background:#fafcff99;padding:2rem}.mt-10{margin-top:10px}.justify-space{justify-content:space-between}.sub-heading,.amount{font-size:16px;font-weight:500}.mb-0{margin-bottom:0}.mb-20{margin-bottom:20px}.mb-15{margin-bottom:15px}.subscription-table{width:50%}.subscription-table th{color:#434443;font-weight:400;font-size:16px;font-family:DM SANS}.subscription-table td{font-weight:500;color:#000;font-size:16px;margin-top:67px;padding-top:10px}.right-side{background-color:#fdfbfa;padding:2rem;position:relative}.right-side .sub-heading{font-size:18px}.right-side .amount{font-size:16px}.right-side .heading{font-weight:400}.mb-5{margin-bottom:5px}.total-fee{position:absolute;bottom:20px;width:90%}.total-fee .amount{background:#fff;height:87px;display:flex;align-items:center;justify-content:center;font-size:32px;border-radius:8px}.defaultImage{height:15px;width:15px}\n"] }]
|
146
|
+
}], ctorParameters: () => [], propDecorators: { admissionData: [{
|
147
|
+
type: Input
|
148
|
+
}], subscriptionsData: [{
|
149
|
+
type: Input
|
150
|
+
}] } });
|
151
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"payment-details.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/components/payment-details/payment-details.component.ts","../../../../../../projects/simpo-ui/src/lib/components/payment-details/payment-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, Input } from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'simpo-payment-details',\r\n  standalone: true,\r\n  imports: [CommonModule, FormsModule],\r\n  templateUrl: './payment-details.component.html',\r\n  styleUrl: './payment-details.component.css'\r\n})\r\nexport class PaymentDetailsComponent {\r\n  @Input() admissionData: any;\r\n  @Input() subscriptionsData: any[] = []\r\n  Object = Object\r\n\r\n  constructor() {}\r\n\r\n  feeStructure: any = {\r\n    \"id\": '1234',\r\n    \"businessDetails\": {\r\n      \"id\": '1234'\r\n    },\r\n    \"grades\": [\r\n      {\r\n        \"_id\": \"1234\",\r\n        \"name\": \"Grade II\"\r\n      },\r\n      {\r\n        \"_id\": \"1234\",\r\n        \"name\": \"Grade IV\"\r\n      }\r\n    ],\r\n    \"board\": \"STATE\",\r\n    \"academicYearStart\": 2024,\r\n    \"academicYearEnd\": 2025,\r\n    \"feeConfigs\": [\r\n      {\r\n        \"feeTypeId\": '12324',\r\n        \"feeHeadId\": '1234',\r\n        \"feeType\": \"Tution fee\",\r\n        \"feeHead\": \"exam fee\",\r\n        \"amount\": 300,\r\n        \"discountAmount\": 0,\r\n        \"isFixed\": false\r\n      }\r\n    ],\r\n    \"subscriptionPlans\": [],\r\n    \"totalAmount\": 300,\r\n    \"createdTimestamp\": {\r\n      \"$date\": \"2024-12-15T07:10:54.889Z\"\r\n    },\r\n    \"updatedTimestamp\": {\r\n      \"$date\": \"2024-12-15T07:10:54.889Z\"\r\n    },\r\n    \"active\": true,\r\n  }\r\n\r\n\r\n  feeConfig: any;\r\n  ngOnInit() {\r\n    this.feeStructure = this.admissionData.studentFeeStructure;\r\n    this.subscriptions = this.arrangeSubscriptionForAdmission(this.subscriptionsData);\r\n    this.feeConfig = this.arrangeFeeConfig(this.feeStructure.feeConfigs);\r\n    this.calculateTotalAmount();\r\n  }\r\n\r\n  defaultImage: string = 'https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/917067c1734337280303cancel.png';\r\n  subscriptions: any = {\r\n    \"Food Fee\" : [\r\n      {\r\n        subscriptionTitle : 'Breakfast',\r\n        pricing  : {\r\n          \"WEEKLY\" : 2000,\r\n          \"MONTHLY\"  : 3000,\r\n          \"YEARLY\" : 4000\r\n        }\r\n      },\r\n      {\r\n        subscriptionTitle : 'Lunch',\r\n        pricing  : {\r\n          \"WEEKLY\" : 2000,\r\n          \"MONTHLY\"  : 3000,\r\n          \"YEARLY\" : 4000\r\n        }\r\n      },\r\n      {\r\n        subscriptionTitle : 'Snacks',\r\n        pricing  : {\r\n          \"WEEKLY\" : 2000,\r\n          \"MONTHLY\"  : 3000,\r\n          \"YEARLY\" : 4000\r\n        }\r\n      }\r\n    ]\r\n  }\r\n\r\n  toggleSelection(subscription: any, frequency: string): void {\r\n    if(!this.feeStructure.subscriptionPlans)\r\n      this.feeStructure.subscriptionPlans = [];\r\n\r\n    let removeIndex: number = -1;\r\n    for(let i = 0;i<this.feeStructure.subscriptionPlans.length;i++) {\r\n      let sub = this.feeStructure.subscriptionPlans[i];\r\n\r\n      if(sub.subId === subscription.subId){\r\n        removeIndex = i;\r\n        break;\r\n      }\r\n    }\r\n\r\n    if(removeIndex == -1) {\r\n      this.feeStructure.subscriptionPlans.push({...subscription, frequency: frequency})\r\n      this.calculateTotalAmount();\r\n      return;\r\n    }\r\n\r\n    this.feeStructure.subscriptionPlans.splice(removeIndex, 1);\r\n\r\n    if (subscription.selectedOption === frequency) {\r\n      subscription.selectedOption = null;\r\n    } else {\r\n      subscription.selectedOption = frequency;\r\n      this.feeStructure.subscriptionPlans.push({...subscription, frequency: frequency})\r\n    }\r\n\r\n    this.calculateTotalAmount();\r\n  }\r\n\r\n  calculateTotalAmount() {\r\n    this.feeStructure.totalAmount = 0;\r\n\r\n    for(let config of this.feeStructure.feeConfigs) {\r\n      this.feeStructure.totalAmount += config.amount;\r\n    }\r\n\r\n    for(let subscription of this.feeStructure.subscriptionPlans) {\r\n      this.feeStructure.totalAmount += subscription.pricing[subscription.frequency];\r\n    }\r\n  }\r\n\r\n  arrangeSubscriptionForAdmission(subscriptionList: any[]) {\r\n    let response: any = {};\r\n\r\n    for(let subscription of subscriptionList) {\r\n      if(!response[subscription.subscriptionType]) {\r\n        response[subscription.subscriptionType] = [];\r\n      }\r\n      response[subscription.subscriptionType].push(subscription);\r\n    }\r\n\r\n    return response;\r\n  }\r\n\r\n  arrangeFeeConfig(feeConfigList: any[]) {\r\n    let response: any = {};\r\n\r\n    for(let config of feeConfigList) {\r\n      if(!response[config.feeType])\r\n        response[config.feeType] = [];\r\n\r\n      response[config.feeType].push(config);\r\n    }\r\n\r\n    return response;\r\n  }\r\n}\r\n","<section class=\"main-section\">\r\n  <div class=\"row\">\r\n    <div class=\"col-md-6\">\r\n      <div class=\"heading left-side\">\r\n        Admission Fee\r\n      </div>\r\n\r\n      <div class=\"left-side mt-10\" *ngFor=\"let configList of Object.keys(feeConfig)\">\r\n        <div class=\"heading mb-20\">{{configList}}</div>\r\n\r\n        <div class=\"d-flex justify-space mt-10 mb-15\" *ngFor=\"let config of feeConfig[configList]\">\r\n          <p class=\"sub-heading mb-0\">{{config.feeHead}}</p>\r\n          <p class=\"amount mb-0\">₹ {{config.amount}}</p>\r\n        </div>\r\n      </div>\r\n\r\n      <div class=\"left-side mt-10\" *ngFor=\"let type of Object.keys(subscriptions)\">\r\n        <p class=\"heading\">{{type}}</p>\r\n\r\n        <table class=\"subscription-table w-100\">\r\n          <thead>\r\n            <th>Subscription Title</th>\r\n            <th>Monthly</th>\r\n            <th>Quaterly</th>\r\n            <th>Yearly</th>\r\n            <th>On Demand</th>\r\n          </thead>\r\n          <tbody>\r\n            <tr *ngFor=\"let data of subscriptions[type];let i = index\">\r\n              <td>{{data.subName}}</td>\r\n              <td>\r\n                <div class=\"form-check\" *ngIf=\"data.pricing['QUARTERLY']\">\r\n                  <input class=\"form-check-input\" type=\"radio\" name=\"subscription{{i}}\"  [value]=\"'MONTHLY'\" (click)=\"toggleSelection(data, 'MONTHLY')\"  [checked]=\"data.selectedOption === 'MONTHLY'\"  [(ngModel)]=\"data.selectedOption\" id=\"flexRadioDefault2\">\r\n                  <label class=\"form-check-label\" for=\"flexCheckChecked\">\r\n                    ₹ {{data.pricing['MONTHLY']}}\r\n                  </label>\r\n                </div>\r\n                <img class=\"defaultImage\" *ngIf=\"!data.pricing['QUARTERLY']\" [src]=\"defaultImage\" alt=\"\">\r\n            </td>\r\n              <td>\r\n                <div class=\"form-check\" *ngIf=\"data.pricing['MONTHLY']\">\r\n                  <input class=\"form-check-input\" type=\"radio\" name=\"subscription{{i}}\" [value]=\"'QUARTERLY'\" (click)=\"toggleSelection(data, 'QUARTERLY')\"  [checked]=\"data.selectedOption === 'QUARTERLY'\" [(ngModel)]=\"data.selectedOption\" id=\"flexCheckChecked\">\r\n                  <label class=\"form-check-label\" for=\"flexCheckChecked\">\r\n                    ₹ {{data.pricing['QUARTERLY']}}\r\n                  </label>\r\n                  <img class=\"defaultImage\" *ngIf=\"!data.pricing['MONTHLY']\" [src]=\"defaultImage\" alt=\"\">\r\n                </div>\r\n              </td>\r\n              <td>\r\n                <div class=\"form-check\" *ngIf=\"data.pricing['ANNUALLY']\">\r\n                  <input class=\"form-check-input\" type=\"radio\" name=\"subscription{{i}}\" [value]=\"'ANNUALLY'\" (click)=\"toggleSelection(data, 'ANNUALLY')\"  [checked]=\"data.selectedOption === 'ANNUALLY'\" [(ngModel)]=\"data.selectedOption\" id=\"flexCheckChecked\">\r\n                  <label class=\"form-check-label\" for=\"flexCheckChecked\">\r\n                    ₹ {{data.pricing['ANNUALLY']}}\r\n                  </label>\r\n                </div>\r\n                <img class=\"defaultImage\" *ngIf=\"!data.pricing['ANNUALLY']\" [src]=\"defaultImage\" alt=\"\">\r\n              </td>\r\n              <td>\r\n                <div class=\"form-check\" *ngIf=\"data.pricing['ONDEMAND']\">\r\n                  <input class=\"form-check-input\" type=\"radio\" name=\"subscription{{i}}\" [value]=\"'ONDEMAND'\" (click)=\"toggleSelection(data, 'ONDEMAND')\"  [checked]=\"data.selectedOption === 'ONDEMAND'\" [(ngModel)]=\"data.selectedOption\" id=\"flexCheckChecked\">\r\n                  <label class=\"form-check-label\" for=\"flexCheckChecked\">\r\n                    ₹ {{data.pricing['ONDEMAND']}}\r\n                  </label>\r\n                </div>\r\n                <img class=\"defaultImage\" *ngIf=\"!data.pricing['ONDEMAND']\" [src]=\"defaultImage\" alt=\"\">\r\n              </td>\r\n            </tr>\r\n          </tbody>\r\n        </table>\r\n      </div>\r\n    </div>\r\n    <div class=\"col-md-6 right-side\">\r\n      <div class=\"heading mb-20\">\r\n        Fee Calculation\r\n      </div>\r\n      <div class=\"d-flex justify-space mt-10 mb-15\" *ngFor=\"let config of feeStructure.feeConfigs\">\r\n        <p class=\"sub-heading mb-0\">{{config.feeHead}}</p>\r\n        <p class=\"amount mb-0\">₹ {{config.amount}}</p>\r\n      </div>\r\n\r\n      <div class=\"d-flex justify-space mt-10 mb-15\" *ngFor=\"let subscripition of feeStructure.subscriptionPlans\">\r\n        <p class=\"sub-heading mb-0\">{{subscripition.subName}}</p>\r\n        <p class=\"amount mb-0\">₹ {{subscripition.pricing[subscripition.frequency]}}</p>\r\n      </div>\r\n\r\n      <div class=\"total-fee\">\r\n        <div class=\"heading mb-5\">\r\n          Total Fee\r\n        </div>\r\n        <div class=\"amount\">\r\n          ₹ {{feeStructure.totalAmount}}\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</section>\r\n"]}
|