@posiwise/admin-module 0.0.160 → 0.0.162
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/domain-config/domain-config-details/domain-config-build/domain-config-build.component.mjs +198 -102
- package/esm2022/lib/components/domain-config/domain-config-details/domain-config-details.component.mjs +2 -2
- package/esm2022/lib/components/domain-config/domain-config-details/domain-config-integrations/domain-config-integrations.component.mjs +3 -2
- package/esm2022/lib/components/domain-config/domain-config-details/domain-config-interface/domain-config-interface.component.mjs +3 -2
- package/esm2022/lib/components/domain-config/domain-config-details/domain-config-organization/domain-config-organization.component.mjs +3 -2
- package/esm2022/lib/components/domain-config/domain-config-details/domain-config-security/domain-config-security.component.mjs +3 -2
- package/esm2022/lib/components/domain-config/domain-config-details/domain-config-social/domain-config-social.component.mjs +3 -2
- package/esm2022/lib/components/faqs/add-faq/add-faq.component.mjs +3 -3
- package/esm2022/lib/components/faqs/edit-faq/edit-faq.component.mjs +3 -3
- package/esm2022/lib/components/faqs/faqs-list/faqs-list.component.mjs +4 -4
- package/esm2022/lib/components/login-notifications/login-notification-details/login-notification-details.component.mjs +2 -2
- package/esm2022/lib/components/products/product-details/product-details.component.mjs +3 -3
- package/esm2022/lib/components/products/products-list/products-list.component.mjs +3 -3
- package/esm2022/lib/components/resources/resources-admin-details/resources-admin-details.component.mjs +57 -28
- package/esm2022/lib/components/resources/resources-admin-tabs/resources-index/resources-index.component.mjs +5 -5
- package/esm2022/lib/components/subscriptions/subscription-agents/subscription-agents.component.mjs +4 -4
- package/esm2022/lib/components/subscriptions/subscription-agents-list/subscription-agents-list.component.mjs +2 -2
- package/esm2022/lib/components/subscriptions/subscription-details/subscription-details.component.mjs +4 -4
- package/esm2022/lib/components/subscriptions/subscription-product-details/subscription-product-details.component.mjs +3 -3
- package/esm2022/lib/components/subscriptions/subscription-products/subscription-products.component.mjs +2 -2
- package/esm2022/lib/components/subscriptions/subscription-users/add-members/add-members.component.mjs +16 -5
- package/esm2022/lib/components/subscriptions/subscription-users/subscription-users.component.mjs +38 -8
- package/esm2022/lib/components/subscriptions/subscriptions-insight/subscription-insight-average-price/subscription-insight-average-price.component.mjs +2 -7
- package/esm2022/lib/components/subscriptions/subscriptions-insight/subscription-insight-average-user/subscription-insight-average-user.component.mjs +2 -7
- package/esm2022/lib/components/subscriptions/subscriptions-insight/subscription-insight-nps/subscription-insight-nps.component.mjs +2 -7
- package/esm2022/lib/components/subscriptions/subscriptions-insight/subscription-insight-product-session/subscription-insight-product-session.component.mjs +2 -7
- package/esm2022/lib/components/subscriptions/subscriptions-insight/subscription-insight-user-session/subscription-insight-user-session.component.mjs +2 -7
- package/esm2022/lib/components/subscriptions/subscriptions-list/invite-users/invite-users.component.mjs +6 -6
- package/esm2022/lib/components/subscriptions/subscriptions-list/subscriptions-list.component.mjs +11 -10
- package/esm2022/lib/components/tags/tags-details/tags-details.component.mjs +15 -5
- package/esm2022/lib/components/tags/tags-list/tags-list.component.mjs +4 -4
- package/esm2022/lib/components/tracking/ahoy-events/ahoy-events.component.mjs +5 -6
- package/esm2022/lib/components/tracking/ahoy-messages/ahoy-messages.component.mjs +5 -6
- package/esm2022/lib/components/tracking/ahoy-visits/ahoy-visits.component.mjs +4 -3
- package/esm2022/lib/components/tracking/events/events.component.mjs +4 -3
- package/esm2022/lib/components/tracking/versions/versions.component.mjs +3 -3
- package/esm2022/lib/components/users/user-details/user-details.component.mjs +6 -3
- package/esm2022/lib/components/users/users-list/users-list.component.mjs +11 -11
- package/fesm2022/posiwise-admin-module.mjs +399 -247
- package/fesm2022/posiwise-admin-module.mjs.map +1 -1
- package/lib/components/domain-config/domain-config-details/domain-config-build/domain-config-build.component.d.ts +9 -0
- package/lib/components/resources/resources-admin-details/resources-admin-details.component.d.ts +14 -1
- package/lib/components/resources/resources-admin-tabs/resources-index/resources-index.component.d.ts +1 -1
- package/lib/components/subscriptions/subscription-users/add-members/add-members.component.d.ts +2 -1
- package/lib/components/subscriptions/subscription-users/subscription-users.component.d.ts +3 -0
- package/lib/components/tags/tags-details/tags-details.component.d.ts +4 -2
- package/package.json +1 -1
|
@@ -1,8 +1,10 @@
|
|
|
1
|
+
import { __decorate, __metadata } from "tslib";
|
|
1
2
|
import { Component, EventEmitter, Injector, Output } from '@angular/core';
|
|
2
3
|
import { UntypedFormBuilder, Validators } from '@angular/forms';
|
|
3
4
|
import { AppBaseComponent } from '@posiwise/app-base-component';
|
|
4
5
|
import { AuthService, SubscriptionService, ValidationService } from '@posiwise/common-services';
|
|
5
6
|
import { TOKEN_HEADER_KEY } from '@posiwise/common-utilities';
|
|
7
|
+
import { ValidateForm } from '@posiwise/utils';
|
|
6
8
|
import { StatusCodes } from 'http-status-codes';
|
|
7
9
|
import { humanizeBytes, UploadStatus } from 'ngx-uploader';
|
|
8
10
|
import swal from 'sweetalert2';
|
|
@@ -40,6 +42,9 @@ export class AddMembersComponent extends AppBaseComponent {
|
|
|
40
42
|
this.getSubscriptionDetails();
|
|
41
43
|
});
|
|
42
44
|
}
|
|
45
|
+
get emailsFormArrayElements() {
|
|
46
|
+
return this.form.get('emailsFormArray');
|
|
47
|
+
}
|
|
43
48
|
createItem() {
|
|
44
49
|
return this.formBuilder.group({
|
|
45
50
|
email: ['', [Validators.email, Validators.required]]
|
|
@@ -137,7 +142,7 @@ export class AddMembersComponent extends AppBaseComponent {
|
|
|
137
142
|
if (response?.status === StatusCodes.OK) {
|
|
138
143
|
this.membersAdded.emit();
|
|
139
144
|
this.toast.success(response.message);
|
|
140
|
-
this.form.
|
|
145
|
+
this.form.setControl('emailsFormArray', this.formBuilder.array([this.createItem()]));
|
|
141
146
|
}
|
|
142
147
|
else {
|
|
143
148
|
this.toast.error(response.error.message);
|
|
@@ -151,12 +156,18 @@ export class AddMembersComponent extends AppBaseComponent {
|
|
|
151
156
|
});
|
|
152
157
|
}
|
|
153
158
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: AddMembersComponent, deps: [{ token: i0.Injector }, { token: i1.UntypedFormBuilder }, { token: i2.SubscriptionService }, { token: i2.AuthService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
154
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: AddMembersComponent, selector: "pw-add-members", outputs: { membersAdded: "membersAdded" }, usesInheritance: true, ngImport: i0, template: "<section>\n <div class=\"row\">\n <div class=\"col-12 mb-3\">\n <div class=\"title d-flex\">\n <a\n aria-label=\"Navigate to Target\"\n (click)=\"membersAdded.emit()\"\n class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n <h2 class=\"mt-3\">Enterprise Members for this subscription</h2>\n </div>\n <p>Here you can add members to your subscription</p>\n </div>\n </div>\n</section>\n\n<section>\n <h5 class=\"ms-2 pt-3\">Upload File (CSV)</h5>\n <div class=\"row p-2\">\n <div class=\"col-12\">\n <div class=\"upload-box\">\n <div class=\"upload-box-content\">\n <div class=\"drop-container\"\n ngFileDrop\n [options]=\"options\"\n (uploadOutput)=\"onUploadOutput($event)\"\n [uploadInput]=\"uploadInput\">\n <p>\n Drag files here or\n <label class=\"upload-button\">\n <input type=\"file\"\n ngFileSelect\n [options]=\"options\"\n (uploadOutput)=\"onUploadOutput($event)\"\n [uploadInput]=\"uploadInput\"\n multiple />\n browse\n </label>\n to upload.\n </p>\n </div>\n <div class=\"upload-item\"\n *ngFor=\"let f of files; let i = index\">\n <div class=\"upload-item-content\">\n <div class=\"filename\">\n <div class=\"filename-left\">\n <i class=\"ionicon ion-ios-copy\" aria-hidden=\"true\"></i>\n <span>{{ f.name }}</span>\n </div>\n </div>\n <div class=\"progress-content\">\n <div class=\"progress\">\n <span class=\"bar\"\n [style.width]=\"f?.progress?.data?.percentage + '%'\"\n [class.is-done]=\"f?.progress?.data?.percentage === 100\"></span>\n </div>\n </div>\n <div class=\"progress-text-content\">\n <span class=\"progress-text\"\n [class.is-done]=\"f?.progress?.data?.percentage === 100\">\n <span>{{ f.progress?.data?.percentage }}% </span>\n <span *ngIf=\"f.progress?.data?.percentage !== 100\">Uploading...</span>\n <span *ngIf=\"f.progress?.data?.percentage === 100\">Done</span>\n </span>\n <span class=\"speed-and-eta-text\"\n *ngIf=\"\n f.progress?.data?.percentage !== 0 &&\n f.progress?.data?.percentage !== 100\n \">\n <span>{{ f.progress?.data?.speedHuman }} </span>\n <span>ETA {{ f.progress?.data?.etaHuman }}</span>\n </span>\n </div>\n </div>\n </div>\n <div class=\"help-text\">\n <span>Note: You can upload a .csv file containing the comma separated emails\n of the members to add.</span>\n </div>\n </div>\n </div>\n </div>\n </div>\n <h5 class=\"ms-2 pt-3 d-inline-block me-2\">Add Member's Email</h5>\n <small><strong> (Available {{ availableUnits }} Seats) </strong></small>\n <div class=\"p-2\">\n <form [formGroup]=\"form\"\n (ngSubmit)=\"onSignUpMember()\">\n <div formArrayName=\"emailsFormArray\"\n *ngFor=\"\n let item of
|
|
159
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: AddMembersComponent, selector: "pw-add-members", outputs: { membersAdded: "membersAdded" }, usesInheritance: true, ngImport: i0, template: "<section>\n <div class=\"row\">\n <div class=\"col-12 mb-3\">\n <div class=\"title d-flex\">\n <a\n aria-label=\"Navigate to Target\"\n (click)=\"membersAdded.emit()\"\n class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n <h2 class=\"mt-3\">Enterprise Members for this subscription</h2>\n </div>\n <p>Here you can add members to your subscription</p>\n </div>\n </div>\n</section>\n\n<section>\n <h5 class=\"ms-2 pt-3\">Upload File (CSV)</h5>\n <div class=\"row p-2\">\n <div class=\"col-12\">\n <div class=\"upload-box\">\n <div class=\"upload-box-content\">\n <div class=\"drop-container\"\n ngFileDrop\n [options]=\"options\"\n (uploadOutput)=\"onUploadOutput($event)\"\n [uploadInput]=\"uploadInput\">\n <p>\n Drag files here or\n <label class=\"upload-button\">\n <input type=\"file\"\n ngFileSelect\n accept=\".csv\"\n [options]=\"options\"\n (uploadOutput)=\"onUploadOutput($event)\"\n [uploadInput]=\"uploadInput\"\n multiple />\n browse\n </label>\n to upload.\n </p>\n </div>\n <div class=\"upload-item\"\n *ngFor=\"let f of files; let i = index\">\n <div class=\"upload-item-content\">\n <div class=\"filename\">\n <div class=\"filename-left\">\n <i class=\"ionicon ion-ios-copy\" aria-hidden=\"true\"></i>\n <span>{{ f.name }}</span>\n </div>\n </div>\n <div class=\"progress-content\">\n <div class=\"progress\">\n <span class=\"bar\"\n [style.width]=\"f?.progress?.data?.percentage + '%'\"\n [class.is-done]=\"f?.progress?.data?.percentage === 100\"></span>\n </div>\n </div>\n <div class=\"progress-text-content\">\n <span class=\"progress-text\"\n [class.is-done]=\"f?.progress?.data?.percentage === 100\">\n <span>{{ f.progress?.data?.percentage }}% </span>\n <span *ngIf=\"f.progress?.data?.percentage !== 100\">Uploading...</span>\n <span *ngIf=\"f.progress?.data?.percentage === 100\">Done</span>\n </span>\n <span class=\"speed-and-eta-text\"\n *ngIf=\"\n f.progress?.data?.percentage !== 0 &&\n f.progress?.data?.percentage !== 100\n \">\n <span>{{ f.progress?.data?.speedHuman }} </span>\n <span>ETA {{ f.progress?.data?.etaHuman }}</span>\n </span>\n </div>\n </div>\n </div>\n <div class=\"help-text\">\n <span>Note: You can upload a .csv file containing the comma separated emails\n of the members to add.</span>\n </div>\n </div>\n </div>\n </div>\n </div>\n <h5 class=\"ms-2 pt-3 d-inline-block me-2\">Add Member's Email</h5>\n <small><strong> (Available {{ availableUnits }} Seats) </strong></small>\n <div class=\"p-2\">\n <form [formGroup]=\"form\"\n (ngSubmit)=\"onSignUpMember()\">\n <div formArrayName=\"emailsFormArray\"\n *ngFor=\"\n let item of emailsFormArrayElements.controls\n let i = index;\n let last = last\n \">\n <div [formGroupName]=\"i\">\n <div class=\"row mb-2\">\n <label class=\"col-12 col-md-4 text-md-end col-form-label col-form-label-sm\" for=\"Email\">\n #{{ i + 1 }}</label>\n <div class=\"col-10 col-md-4\">\n <input formControlName=\"email\"\n class=\"form-control form-control-sm\"\n placeholder=\"Email\" />\n </div>\n <div class=\"col-2\">\n <button class=\"btn btn-sm btn-danger\"\n type=\"button\">\n <i\n class=\"fa fa-times\"\n title=\"Delete\"\n (click)=\"removeItem(i)\"\n (keydown.enter)=\"removeItem(i)\"\n aria-hidden=\"true\"\n ></i>\n </button>\n <i\n class=\"btn btn-sm btn-primary fal fa-plus ms-2\"\n *ngIf=\"last && emailsFormArray?.controls?.length < availableUnits\"\n title=\"Add More\"\n (click)=\"addItem()\"\n (keydown.enter)=\"addItem()\"\n aria-hidden=\"true\"\n ></i>\n </div>\n </div>\n </div>\n </div>\n <div class=\"text-center mt-2\">\n <button class=\"btn btn-sm btn-outline-default me-2\"\n (click)=\"membersAdded.emit()\">\n <i class=\"fa fa-plus-times\" aria-hidden=\"true\" aria-label=\"Go Back\"></i>\n {{ 'Button.Back' | transloco }}\n </button>\n <button type=\"submit\"\n class=\"btn btn-sm btn-outline-primary me-2\"\n [buttonBusy]=\"buttonBusy\"\n [disabled]=\"form.invalid || buttonBusy\">\n Add Members\n </button>\n </div>\n </form>\n </div>\n</section>\n", dependencies: [{ kind: "directive", type: i3.NgFileDropDirective, selector: "[ngFileDrop]", inputs: ["options", "uploadInput"], outputs: ["uploadOutput"] }, { kind: "directive", type: i3.NgFileSelectDirective, selector: "[ngFileSelect]", inputs: ["options", "uploadInput"], outputs: ["uploadOutput"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.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: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i5.ButtonBusyDirective, selector: "[buttonBusy]", inputs: ["buttonBusy", "busyText"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i1.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "directive", type: i1.FormArrayName, selector: "[formArrayName]", inputs: ["formArrayName"] }, { kind: "pipe", type: i6.TranslocoPipe, name: "transloco" }] }); }
|
|
155
160
|
}
|
|
161
|
+
__decorate([
|
|
162
|
+
ValidateForm('form'),
|
|
163
|
+
__metadata("design:type", Function),
|
|
164
|
+
__metadata("design:paramtypes", []),
|
|
165
|
+
__metadata("design:returntype", void 0)
|
|
166
|
+
], AddMembersComponent.prototype, "onSignUpMember", null);
|
|
156
167
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: AddMembersComponent, decorators: [{
|
|
157
168
|
type: Component,
|
|
158
|
-
args: [{ selector: 'pw-add-members', template: "<section>\n <div class=\"row\">\n <div class=\"col-12 mb-3\">\n <div class=\"title d-flex\">\n <a\n aria-label=\"Navigate to Target\"\n (click)=\"membersAdded.emit()\"\n class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n <h2 class=\"mt-3\">Enterprise Members for this subscription</h2>\n </div>\n <p>Here you can add members to your subscription</p>\n </div>\n </div>\n</section>\n\n<section>\n <h5 class=\"ms-2 pt-3\">Upload File (CSV)</h5>\n <div class=\"row p-2\">\n <div class=\"col-12\">\n <div class=\"upload-box\">\n <div class=\"upload-box-content\">\n <div class=\"drop-container\"\n ngFileDrop\n [options]=\"options\"\n (uploadOutput)=\"onUploadOutput($event)\"\n [uploadInput]=\"uploadInput\">\n <p>\n Drag files here or\n <label class=\"upload-button\">\n <input type=\"file\"\n ngFileSelect\n [options]=\"options\"\n (uploadOutput)=\"onUploadOutput($event)\"\n [uploadInput]=\"uploadInput\"\n multiple />\n browse\n </label>\n to upload.\n </p>\n </div>\n <div class=\"upload-item\"\n *ngFor=\"let f of files; let i = index\">\n <div class=\"upload-item-content\">\n <div class=\"filename\">\n <div class=\"filename-left\">\n <i class=\"ionicon ion-ios-copy\" aria-hidden=\"true\"></i>\n <span>{{ f.name }}</span>\n </div>\n </div>\n <div class=\"progress-content\">\n <div class=\"progress\">\n <span class=\"bar\"\n [style.width]=\"f?.progress?.data?.percentage + '%'\"\n [class.is-done]=\"f?.progress?.data?.percentage === 100\"></span>\n </div>\n </div>\n <div class=\"progress-text-content\">\n <span class=\"progress-text\"\n [class.is-done]=\"f?.progress?.data?.percentage === 100\">\n <span>{{ f.progress?.data?.percentage }}% </span>\n <span *ngIf=\"f.progress?.data?.percentage !== 100\">Uploading...</span>\n <span *ngIf=\"f.progress?.data?.percentage === 100\">Done</span>\n </span>\n <span class=\"speed-and-eta-text\"\n *ngIf=\"\n f.progress?.data?.percentage !== 0 &&\n f.progress?.data?.percentage !== 100\n \">\n <span>{{ f.progress?.data?.speedHuman }} </span>\n <span>ETA {{ f.progress?.data?.etaHuman }}</span>\n </span>\n </div>\n </div>\n </div>\n <div class=\"help-text\">\n <span>Note: You can upload a .csv file containing the comma separated emails\n of the members to add.</span>\n </div>\n </div>\n </div>\n </div>\n </div>\n <h5 class=\"ms-2 pt-3 d-inline-block me-2\">Add Member's Email</h5>\n <small><strong> (Available {{ availableUnits }} Seats) </strong></small>\n <div class=\"p-2\">\n <form [formGroup]=\"form\"\n (ngSubmit)=\"onSignUpMember()\">\n <div formArrayName=\"emailsFormArray\"\n *ngFor=\"\n let item of
|
|
169
|
+
args: [{ selector: 'pw-add-members', template: "<section>\n <div class=\"row\">\n <div class=\"col-12 mb-3\">\n <div class=\"title d-flex\">\n <a\n aria-label=\"Navigate to Target\"\n (click)=\"membersAdded.emit()\"\n class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n <h2 class=\"mt-3\">Enterprise Members for this subscription</h2>\n </div>\n <p>Here you can add members to your subscription</p>\n </div>\n </div>\n</section>\n\n<section>\n <h5 class=\"ms-2 pt-3\">Upload File (CSV)</h5>\n <div class=\"row p-2\">\n <div class=\"col-12\">\n <div class=\"upload-box\">\n <div class=\"upload-box-content\">\n <div class=\"drop-container\"\n ngFileDrop\n [options]=\"options\"\n (uploadOutput)=\"onUploadOutput($event)\"\n [uploadInput]=\"uploadInput\">\n <p>\n Drag files here or\n <label class=\"upload-button\">\n <input type=\"file\"\n ngFileSelect\n accept=\".csv\"\n [options]=\"options\"\n (uploadOutput)=\"onUploadOutput($event)\"\n [uploadInput]=\"uploadInput\"\n multiple />\n browse\n </label>\n to upload.\n </p>\n </div>\n <div class=\"upload-item\"\n *ngFor=\"let f of files; let i = index\">\n <div class=\"upload-item-content\">\n <div class=\"filename\">\n <div class=\"filename-left\">\n <i class=\"ionicon ion-ios-copy\" aria-hidden=\"true\"></i>\n <span>{{ f.name }}</span>\n </div>\n </div>\n <div class=\"progress-content\">\n <div class=\"progress\">\n <span class=\"bar\"\n [style.width]=\"f?.progress?.data?.percentage + '%'\"\n [class.is-done]=\"f?.progress?.data?.percentage === 100\"></span>\n </div>\n </div>\n <div class=\"progress-text-content\">\n <span class=\"progress-text\"\n [class.is-done]=\"f?.progress?.data?.percentage === 100\">\n <span>{{ f.progress?.data?.percentage }}% </span>\n <span *ngIf=\"f.progress?.data?.percentage !== 100\">Uploading...</span>\n <span *ngIf=\"f.progress?.data?.percentage === 100\">Done</span>\n </span>\n <span class=\"speed-and-eta-text\"\n *ngIf=\"\n f.progress?.data?.percentage !== 0 &&\n f.progress?.data?.percentage !== 100\n \">\n <span>{{ f.progress?.data?.speedHuman }} </span>\n <span>ETA {{ f.progress?.data?.etaHuman }}</span>\n </span>\n </div>\n </div>\n </div>\n <div class=\"help-text\">\n <span>Note: You can upload a .csv file containing the comma separated emails\n of the members to add.</span>\n </div>\n </div>\n </div>\n </div>\n </div>\n <h5 class=\"ms-2 pt-3 d-inline-block me-2\">Add Member's Email</h5>\n <small><strong> (Available {{ availableUnits }} Seats) </strong></small>\n <div class=\"p-2\">\n <form [formGroup]=\"form\"\n (ngSubmit)=\"onSignUpMember()\">\n <div formArrayName=\"emailsFormArray\"\n *ngFor=\"\n let item of emailsFormArrayElements.controls\n let i = index;\n let last = last\n \">\n <div [formGroupName]=\"i\">\n <div class=\"row mb-2\">\n <label class=\"col-12 col-md-4 text-md-end col-form-label col-form-label-sm\" for=\"Email\">\n #{{ i + 1 }}</label>\n <div class=\"col-10 col-md-4\">\n <input formControlName=\"email\"\n class=\"form-control form-control-sm\"\n placeholder=\"Email\" />\n </div>\n <div class=\"col-2\">\n <button class=\"btn btn-sm btn-danger\"\n type=\"button\">\n <i\n class=\"fa fa-times\"\n title=\"Delete\"\n (click)=\"removeItem(i)\"\n (keydown.enter)=\"removeItem(i)\"\n aria-hidden=\"true\"\n ></i>\n </button>\n <i\n class=\"btn btn-sm btn-primary fal fa-plus ms-2\"\n *ngIf=\"last && emailsFormArray?.controls?.length < availableUnits\"\n title=\"Add More\"\n (click)=\"addItem()\"\n (keydown.enter)=\"addItem()\"\n aria-hidden=\"true\"\n ></i>\n </div>\n </div>\n </div>\n </div>\n <div class=\"text-center mt-2\">\n <button class=\"btn btn-sm btn-outline-default me-2\"\n (click)=\"membersAdded.emit()\">\n <i class=\"fa fa-plus-times\" aria-hidden=\"true\" aria-label=\"Go Back\"></i>\n {{ 'Button.Back' | transloco }}\n </button>\n <button type=\"submit\"\n class=\"btn btn-sm btn-outline-primary me-2\"\n [buttonBusy]=\"buttonBusy\"\n [disabled]=\"form.invalid || buttonBusy\">\n Add Members\n </button>\n </div>\n </form>\n </div>\n</section>\n" }]
|
|
159
170
|
}], ctorParameters: () => [{ type: i0.Injector }, { type: i1.UntypedFormBuilder }, { type: i2.SubscriptionService }, { type: i2.AuthService }], propDecorators: { membersAdded: [{
|
|
160
171
|
type: Output
|
|
161
|
-
}] } });
|
|
162
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-members.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/admin-module/src/lib/components/subscriptions/subscription-users/add-members/add-members.component.ts","../../../../../../../../../libs/admin-module/src/lib/components/subscriptions/subscription-users/add-members/add-members.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Injector, OnInit, Output } from '@angular/core';\nimport { UntypedFormArray, UntypedFormBuilder, UntypedFormGroup, Validators } from '@angular/forms';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AuthService, SubscriptionService, ValidationService } from '@posiwise/common-services';\nimport { TOKEN_HEADER_KEY } from '@posiwise/common-utilities';\n\nimport { StatusCodes } from 'http-status-codes';\nimport {\n    humanizeBytes,\n    UploaderOptions,\n    UploadFile,\n    UploadInput,\n    UploadOutput,\n    UploadStatus\n} from 'ngx-uploader';\nimport swal from 'sweetalert2';\n\n@Component({\n    selector: 'pw-add-members',\n    templateUrl: './add-members.component.html'\n})\nexport class AddMembersComponent extends AppBaseComponent implements OnInit {\n    @Output() membersAdded = new EventEmitter<void>();\n    form: UntypedFormGroup;\n    emailsFormArray: UntypedFormArray;\n\n    availableUnits = 0;\n    buttonBusy = false;\n\n    files: UploadFile[] = [];\n    uploadInput: EventEmitter<UploadInput> = new EventEmitter<UploadInput>();\n    dragOver = false;\n    options: UploaderOptions = { concurrency: 1, maxUploads: 3 };\n    humanizeBytes = humanizeBytes;\n\n    private token: string;\n    id: number;\n    page = 1;\n\n    constructor(\n        injector: Injector,\n        private readonly formBuilder: UntypedFormBuilder,\n        private readonly subscriptionService: SubscriptionService,\n        private readonly authService: AuthService\n    ) {\n        super(injector);\n        this.token = btoa(this.authService.getToken());\n        this.form = this.formBuilder.group({\n            email: ['', ValidationService.email],\n            emailsFormArray: this.formBuilder.array([this.createItem()])\n        });\n    }\n\n    ngOnInit(): void {\n        this.route.params.subscribe(data => {\n            this.id = Number(data['id']);\n            this.getSubscriptionDetails();\n        });\n    }\n\n    private createItem(): UntypedFormGroup {\n        return this.formBuilder.group({\n            email: ['', [Validators.email, Validators.required]]\n        });\n    }\n\n    addItem(): void {\n        this.emailsFormArray = this.form.get('emailsFormArray') as UntypedFormArray;\n        if (\n            this.emailsFormArray.valid &&\n            this.emailsFormArray.controls.length < this.availableUnits\n        ) {\n            this.emailsFormArray.push(this.createItem());\n        }\n    }\n\n    private getSubscriptionDetails() {\n        this.subscriptionService.getById(this.id).subscribe(resp => {\n            this.availableUnits = resp.products[0].purchased_units - resp.units_in_use;\n        });\n    }\n\n    removeItem(index: number): void {\n        this.emailsFormArray = this.form.get('emailsFormArray') as UntypedFormArray;\n        this.emailsFormArray.removeAt(index);\n    }\n\n    onUploadOutput(output: UploadOutput): void {\n        switch (output.type) {\n            case 'allAddedToQueue':\n                if (this.files.length > 0) {\n                    const event: UploadInput = {\n                        type: 'uploadAll',\n                        url: this.subscriptionService.signUpMemberUrl(this.id),\n                        method: 'POST',\n                        data: {\n                            send_marketing_emails: 'true',\n                            confirmation_path: 'confirm'\n                        },\n                        headers: {\n                            [TOKEN_HEADER_KEY]: this.token\n                        }\n                    };\n                    this.uploadInput.emit(event);\n                }\n                break;\n\n            case 'addedToQueue':\n                if (output.file) {\n                    const ext = output.file.name.split('.').pop();\n                    if (['csv', 'xlsx'].includes(ext)) {\n                        this.files.push(output.file);\n                    } else {\n                        this.toast.error('Only csv and xlsx formats are supported.');\n                    }\n                }\n                break;\n\n            case 'uploading':\n                if (output.file) {\n                    const index = this.files.findIndex(file => file.id === output.file.id);\n                    this.files[index] = output.file;\n                }\n                break;\n\n            case 'removed':\n                this.files = this.files.filter(file => file !== output.file);\n                break;\n\n            case 'dragOver':\n                this.dragOver = true;\n                break;\n\n            case 'dragOut':\n            case 'drop':\n                this.dragOver = false;\n                break;\n        }\n\n        this.files = this.files.filter(file => file.progress.status !== UploadStatus.Done);\n    }\n\n    onSignUpMember(): void {\n        swal.fire({\n            title: this.translation.translate('Label.Confirm'),\n            text: this.translation.translate(\n                'Admin.Subscriptions.confirmEnterpriseMembersSubscriptionMessage'\n            ),\n            showCancelButton: true,\n            reverseButtons: true,\n            icon: 'warning',\n            confirmButtonText: 'Yes'\n        }).then(rep => {\n            if (rep.value) {\n                const emails = this.form\n                    .get('emailsFormArray')\n                    ?.value?.map(item => item.email)\n                    .join(',');\n                if (emails) {\n                    this.buttonBusy = true;\n                    const data = {\n                        confirmation_path: 'confirm',\n                        emails,\n                        send_marketing_emails: true\n                    };\n                    this.subscriptionService\n                        .addMembersToSubscription(this.id, data)\n                        .subscribe(response => {\n                            if (response?.status === StatusCodes.OK) {\n                                this.membersAdded.emit();\n                                this.toast.success(response.message);\n                                this.form.reset();\n                            } else {\n                                this.toast.error(response.error.message);\n                            }\n                        })\n                        .add(() => {\n                            this.buttonBusy = false;\n                        });\n                }\n            }\n        });\n    }\n}\n","<section>\n  <div class=\"row\">\n    <div class=\"col-12 mb-3\">\n      <div class=\"title d-flex\">\n        <a\n          aria-label=\"Navigate to Target\"\n          (click)=\"membersAdded.emit()\"\n          class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n        <h2 class=\"mt-3\">Enterprise Members for this subscription</h2>\n      </div>\n      <p>Here you can add members to your subscription</p>\n    </div>\n  </div>\n</section>\n\n<section>\n  <h5 class=\"ms-2 pt-3\">Upload File (CSV)</h5>\n  <div class=\"row p-2\">\n    <div class=\"col-12\">\n      <div class=\"upload-box\">\n        <div class=\"upload-box-content\">\n          <div class=\"drop-container\"\n            ngFileDrop\n            [options]=\"options\"\n            (uploadOutput)=\"onUploadOutput($event)\"\n            [uploadInput]=\"uploadInput\">\n            <p>\n              Drag files here or\n              <label class=\"upload-button\">\n                <input type=\"file\"\n                  ngFileSelect\n                  [options]=\"options\"\n                  (uploadOutput)=\"onUploadOutput($event)\"\n                  [uploadInput]=\"uploadInput\"\n                  multiple />\n                browse\n              </label>\n              to upload.\n            </p>\n          </div>\n          <div class=\"upload-item\"\n            *ngFor=\"let f of files; let i = index\">\n            <div class=\"upload-item-content\">\n              <div class=\"filename\">\n                <div class=\"filename-left\">\n                  <i class=\"ionicon ion-ios-copy\" aria-hidden=\"true\"></i>\n                  <span>{{ f.name }}</span>\n                </div>\n              </div>\n              <div class=\"progress-content\">\n                <div class=\"progress\">\n                  <span class=\"bar\"\n                    [style.width]=\"f?.progress?.data?.percentage + '%'\"\n                    [class.is-done]=\"f?.progress?.data?.percentage === 100\"></span>\n                </div>\n              </div>\n              <div class=\"progress-text-content\">\n                <span class=\"progress-text\"\n                  [class.is-done]=\"f?.progress?.data?.percentage === 100\">\n                  <span>{{ f.progress?.data?.percentage }}% </span>\n                  <span *ngIf=\"f.progress?.data?.percentage !== 100\">Uploading...</span>\n                  <span *ngIf=\"f.progress?.data?.percentage === 100\">Done</span>\n                </span>\n                <span class=\"speed-and-eta-text\"\n                  *ngIf=\"\n                                        f.progress?.data?.percentage !== 0 &&\n                                        f.progress?.data?.percentage !== 100\n                                    \">\n                  <span>{{ f.progress?.data?.speedHuman }} </span>\n                  <span>ETA {{ f.progress?.data?.etaHuman }}</span>\n                </span>\n              </div>\n            </div>\n          </div>\n          <div class=\"help-text\">\n            <span>Note: You can upload a .csv file containing the comma separated emails\n              of the members to add.</span>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n  <h5 class=\"ms-2 pt-3 d-inline-block me-2\">Add Member's Email</h5>\n  <small><strong> (Available {{ availableUnits }} Seats) </strong></small>\n  <div class=\"p-2\">\n    <form [formGroup]=\"form\"\n      (ngSubmit)=\"onSignUpMember()\">\n      <div formArrayName=\"emailsFormArray\"\n        *ngFor=\"\n                    let item of form.get('emailsFormArray')['controls'];\n                    let i = index;\n                    let last = last\n                \">\n        <div [formGroupName]=\"i\">\n          <div class=\"row mb-2\">\n            <label class=\"col-12 col-md-4 text-md-end col-form-label col-form-label-sm\" for=\"Email\">\n              #{{ i + 1 }}</label>\n            <div class=\"col-10 col-md-4\">\n              <input formControlName=\"email\"\n                class=\"form-control form-control-sm\"\n                placeholder=\"Email\" />\n            </div>\n            <div class=\"col-2\">\n              <button class=\"btn btn-sm btn-danger\"\n                type=\"button\">\n                <i\n                                class=\"fa fa-times\"\n                                title=\"Delete\"\n                                (click)=\"removeItem(i)\"\n                                (keydown.enter)=\"removeItem(i)\"\n                                aria-hidden=\"true\"\n                            ></i>\n              </button>\n              <i\n                                class=\"btn btn-sm btn-primary fal fa-plus ms-2\"\n                                *ngIf=\"last && emailsFormArray?.controls?.length < availableUnits\"\n                                title=\"Add More\"\n                                (click)=\"addItem()\"\n                                (keydown.enter)=\"addItem()\"\n                                aria-hidden=\"true\"\n                            ></i>\n            </div>\n          </div>\n        </div>\n      </div>\n      <div class=\"text-center mt-2\">\n        <button class=\"btn btn-sm btn-outline-default me-2\"\n        (click)=\"membersAdded.emit()\">\n          <i class=\"fa fa-plus-times\" aria-hidden=\"true\"></i>\n          {{ 'Button.Back' | transloco }}\n        </button>\n        <button type=\"submit\"\n          class=\"btn btn-sm btn-outline-primary me-2\"\n          [buttonBusy]=\"buttonBusy\"\n          [disabled]=\"form.invalid || buttonBusy\">\n          Add Members\n        </button>\n      </div>\n    </form>\n  </div>\n</section>\n"]}
|
|
172
|
+
}], onSignUpMember: [] } });
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-members.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/admin-module/src/lib/components/subscriptions/subscription-users/add-members/add-members.component.ts","../../../../../../../../../libs/admin-module/src/lib/components/subscriptions/subscription-users/add-members/add-members.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Injector, OnInit, Output } from '@angular/core';\nimport { UntypedFormArray, UntypedFormBuilder, UntypedFormGroup, Validators } from '@angular/forms';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AuthService, SubscriptionService, ValidationService } from '@posiwise/common-services';\nimport { TOKEN_HEADER_KEY } from '@posiwise/common-utilities';\nimport { ValidateForm } from '@posiwise/utils';\n\nimport { StatusCodes } from 'http-status-codes';\nimport {\n    humanizeBytes,\n    UploaderOptions,\n    UploadFile,\n    UploadInput,\n    UploadOutput,\n    UploadStatus\n} from 'ngx-uploader';\nimport swal from 'sweetalert2';\n\n@Component({\n    selector: 'pw-add-members',\n    templateUrl: './add-members.component.html'\n})\nexport class AddMembersComponent extends AppBaseComponent implements OnInit {\n    @Output() membersAdded = new EventEmitter<void>();\n    form: UntypedFormGroup;\n    emailsFormArray: UntypedFormArray;\n\n    availableUnits = 0;\n    buttonBusy = false;\n\n    files: UploadFile[] = [];\n    uploadInput: EventEmitter<UploadInput> = new EventEmitter<UploadInput>();\n    dragOver = false;\n    options: UploaderOptions = { concurrency: 1, maxUploads: 3 };\n    humanizeBytes = humanizeBytes;\n\n    private readonly token: string;\n    id: number;\n    page = 1;\n\n    constructor(\n        injector: Injector,\n        private readonly formBuilder: UntypedFormBuilder,\n        private readonly subscriptionService: SubscriptionService,\n        private readonly authService: AuthService\n    ) {\n        super(injector);\n        this.token = btoa(this.authService.getToken());\n        this.form = this.formBuilder.group({\n            email: ['', ValidationService.email],\n            emailsFormArray: this.formBuilder.array([this.createItem()])\n        });\n    }\n\n    ngOnInit(): void {\n        this.route.params.subscribe(data => {\n            this.id = Number(data['id']);\n            this.getSubscriptionDetails();\n        });\n    }\n\n    get emailsFormArrayElements(): UntypedFormArray {\n        return this.form.get('emailsFormArray') as UntypedFormArray;\n    }\n\n    private createItem(): UntypedFormGroup {\n        return this.formBuilder.group({\n            email: ['', [Validators.email, Validators.required]]\n        });\n    }\n\n    addItem(): void {\n        this.emailsFormArray = this.form.get('emailsFormArray') as UntypedFormArray;\n        if (\n            this.emailsFormArray.valid &&\n            this.emailsFormArray.controls.length < this.availableUnits\n        ) {\n            this.emailsFormArray.push(this.createItem());\n        }\n    }\n\n    private getSubscriptionDetails() {\n        this.subscriptionService.getById(this.id).subscribe(resp => {\n            this.availableUnits = resp.products[0].purchased_units - resp.units_in_use;\n        });\n    }\n\n    removeItem(index: number): void {\n        this.emailsFormArray = this.form.get('emailsFormArray') as UntypedFormArray;\n        this.emailsFormArray.removeAt(index);\n    }\n\n    onUploadOutput(output: UploadOutput): void {\n        switch (output.type) {\n            case 'allAddedToQueue':\n                if (this.files.length > 0) {\n                    const event: UploadInput = {\n                        type: 'uploadAll',\n                        url: this.subscriptionService.signUpMemberUrl(this.id),\n                        method: 'POST',\n                        data: {\n                            send_marketing_emails: 'true',\n                            confirmation_path: 'confirm'\n                        },\n                        headers: {\n                            [TOKEN_HEADER_KEY]: this.token\n                        }\n                    };\n                    this.uploadInput.emit(event);\n                }\n                break;\n\n            case 'addedToQueue':\n                if (output.file) {\n                    const ext = output.file.name.split('.').pop();\n                    if (['csv', 'xlsx'].includes(ext)) {\n                        this.files.push(output.file);\n                    } else {\n                        this.toast.error('Only csv and xlsx formats are supported.');\n                    }\n                }\n                break;\n\n            case 'uploading':\n                if (output.file) {\n                    const index = this.files.findIndex(file => file.id === output.file.id);\n                    this.files[index] = output.file;\n                }\n                break;\n\n            case 'removed':\n                this.files = this.files.filter(file => file !== output.file);\n                break;\n\n            case 'dragOver':\n                this.dragOver = true;\n                break;\n\n            case 'dragOut':\n            case 'drop':\n                this.dragOver = false;\n                break;\n        }\n\n        this.files = this.files.filter(file => file.progress.status !== UploadStatus.Done);\n    }\n    @ValidateForm('form')\n    onSignUpMember(): void {\n        swal.fire({\n            title: this.translation.translate('Label.Confirm'),\n            text: this.translation.translate(\n                'Admin.Subscriptions.confirmEnterpriseMembersSubscriptionMessage'\n            ),\n            showCancelButton: true,\n            reverseButtons: true,\n            icon: 'warning',\n            confirmButtonText: 'Yes'\n        }).then(rep => {\n            if (rep.value) {\n                const emails = this.form\n                    .get('emailsFormArray')\n                    ?.value?.map(item => item.email)\n                    .join(',');\n                if (emails) {\n                    this.buttonBusy = true;\n                    const data = {\n                        confirmation_path: 'confirm',\n                        emails,\n                        send_marketing_emails: true\n                    };\n                    this.subscriptionService\n                        .addMembersToSubscription(this.id, data)\n                        .subscribe(response => {\n                            if (response?.status === StatusCodes.OK) {\n                                this.membersAdded.emit();\n                                this.toast.success(response.message);\n                                this.form.setControl(\n                                    'emailsFormArray',\n                                    this.formBuilder.array([this.createItem()])\n                                );\n                            } else {\n                                this.toast.error(response.error.message);\n                            }\n                        })\n                        .add(() => {\n                            this.buttonBusy = false;\n                        });\n                }\n            }\n        });\n    }\n}\n","<section>\n  <div class=\"row\">\n    <div class=\"col-12 mb-3\">\n      <div class=\"title d-flex\">\n        <a\n          aria-label=\"Navigate to Target\"\n          (click)=\"membersAdded.emit()\"\n          class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n        <h2 class=\"mt-3\">Enterprise Members for this subscription</h2>\n      </div>\n      <p>Here you can add members to your subscription</p>\n    </div>\n  </div>\n</section>\n\n<section>\n  <h5 class=\"ms-2 pt-3\">Upload File (CSV)</h5>\n  <div class=\"row p-2\">\n    <div class=\"col-12\">\n      <div class=\"upload-box\">\n        <div class=\"upload-box-content\">\n          <div class=\"drop-container\"\n            ngFileDrop\n            [options]=\"options\"\n            (uploadOutput)=\"onUploadOutput($event)\"\n            [uploadInput]=\"uploadInput\">\n            <p>\n              Drag files here or\n              <label class=\"upload-button\">\n                <input type=\"file\"\n                  ngFileSelect\n                  accept=\".csv\"\n                  [options]=\"options\"\n                  (uploadOutput)=\"onUploadOutput($event)\"\n                  [uploadInput]=\"uploadInput\"\n                  multiple />\n                browse\n              </label>\n              to upload.\n            </p>\n          </div>\n          <div class=\"upload-item\"\n            *ngFor=\"let f of files; let i = index\">\n            <div class=\"upload-item-content\">\n              <div class=\"filename\">\n                <div class=\"filename-left\">\n                  <i class=\"ionicon ion-ios-copy\" aria-hidden=\"true\"></i>\n                  <span>{{ f.name }}</span>\n                </div>\n              </div>\n              <div class=\"progress-content\">\n                <div class=\"progress\">\n                  <span class=\"bar\"\n                    [style.width]=\"f?.progress?.data?.percentage + '%'\"\n                    [class.is-done]=\"f?.progress?.data?.percentage === 100\"></span>\n                </div>\n              </div>\n              <div class=\"progress-text-content\">\n                <span class=\"progress-text\"\n                  [class.is-done]=\"f?.progress?.data?.percentage === 100\">\n                  <span>{{ f.progress?.data?.percentage }}% </span>\n                  <span *ngIf=\"f.progress?.data?.percentage !== 100\">Uploading...</span>\n                  <span *ngIf=\"f.progress?.data?.percentage === 100\">Done</span>\n                </span>\n                <span class=\"speed-and-eta-text\"\n                  *ngIf=\"\n                                        f.progress?.data?.percentage !== 0 &&\n                                        f.progress?.data?.percentage !== 100\n                                    \">\n                  <span>{{ f.progress?.data?.speedHuman }} </span>\n                  <span>ETA {{ f.progress?.data?.etaHuman }}</span>\n                </span>\n              </div>\n            </div>\n          </div>\n          <div class=\"help-text\">\n            <span>Note: You can upload a .csv file containing the comma separated emails\n              of the members to add.</span>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n  <h5 class=\"ms-2 pt-3 d-inline-block me-2\">Add Member's Email</h5>\n  <small><strong> (Available {{ availableUnits }} Seats) </strong></small>\n  <div class=\"p-2\">\n    <form [formGroup]=\"form\"\n      (ngSubmit)=\"onSignUpMember()\">\n      <div formArrayName=\"emailsFormArray\"\n        *ngFor=\"\n                    let item of emailsFormArrayElements.controls\n                    let i = index;\n                    let last = last\n                \">\n        <div [formGroupName]=\"i\">\n          <div class=\"row mb-2\">\n            <label class=\"col-12 col-md-4 text-md-end col-form-label col-form-label-sm\" for=\"Email\">\n              #{{ i + 1 }}</label>\n            <div class=\"col-10 col-md-4\">\n              <input formControlName=\"email\"\n                class=\"form-control form-control-sm\"\n                placeholder=\"Email\" />\n            </div>\n            <div class=\"col-2\">\n              <button class=\"btn btn-sm btn-danger\"\n                type=\"button\">\n                <i\n                                class=\"fa fa-times\"\n                                title=\"Delete\"\n                                (click)=\"removeItem(i)\"\n                                (keydown.enter)=\"removeItem(i)\"\n                                aria-hidden=\"true\"\n                            ></i>\n              </button>\n              <i\n                                class=\"btn btn-sm btn-primary fal fa-plus ms-2\"\n                                *ngIf=\"last && emailsFormArray?.controls?.length < availableUnits\"\n                                title=\"Add More\"\n                                (click)=\"addItem()\"\n                                (keydown.enter)=\"addItem()\"\n                                aria-hidden=\"true\"\n                            ></i>\n            </div>\n          </div>\n        </div>\n      </div>\n      <div class=\"text-center mt-2\">\n        <button class=\"btn btn-sm btn-outline-default me-2\"\n        (click)=\"membersAdded.emit()\">\n          <i class=\"fa fa-plus-times\" aria-hidden=\"true\" aria-label=\"Go Back\"></i>\n          {{ 'Button.Back' | transloco }}\n        </button>\n        <button type=\"submit\"\n          class=\"btn btn-sm btn-outline-primary me-2\"\n          [buttonBusy]=\"buttonBusy\"\n          [disabled]=\"form.invalid || buttonBusy\">\n          Add Members\n        </button>\n      </div>\n    </form>\n  </div>\n</section>\n"]}
|