@posiwise/shared-components 0.0.30 → 0.0.31

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/esm2020/index.mjs CHANGED
@@ -18,6 +18,6 @@ export * from './lib/autheticator/autheticator.component';
18
18
  export * from './lib/clearbit-icon/clearbit-icon.component';
19
19
  export * from './lib/coming-soon/coming-soon.component';
20
20
  export * from './lib/no-data/no-data.component';
21
- // export * from './lib/pushback-popup/pushback-popup.component';
22
- // export * from './lib/label-management/entity-group/entity-group.component';
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL3NoYXJlZC1jb21wb25lbnRzL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsNkRBQTZELENBQUM7QUFDNUUsY0FBYyx1REFBdUQsQ0FBQztBQUN0RSxjQUFjLHlEQUF5RCxDQUFDO0FBQ3hFLGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLHlEQUF5RCxDQUFDO0FBQ3hFLGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsaUVBQWlFO0FBQ2pFLDhFQUE4RSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL3NoYXJlZC1jb21wb25lbnRzLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hYi10ZXN0L2FiLXRlc3QtY29udGFpbmVyL2FiLXRlc3QtY29udGFpbmVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hYi10ZXN0L2FiLWFsdGVybmF0aXZlL2FiLWFsdGVybmF0aXZlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wYXNzd29yZC12YWxpZGF0aW9uL3Bhc3N3b3JkLXZhbGlkYXRpb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2N1c3RvbS11cGxvYWRlci9jdXN0b20tdXBsb2FkZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ltYWdlLWNyb3BwZXIvaW1hZ2UtY3JvcHBlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHctdGFicy9wdy10YWJzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wZXJtaXNzaW9uLXRyZWUvcGVybWlzc2lvbi10cmVlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbnB1dC1jb250YWluZXIvaW5wdXQtY29udGFpbmVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZC1lcnJvci1kaXNwbGF5L2ZpZWxkLWVycm9yLWRpc3BsYXkuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ByaXZhY3ktYW5kLXRvcy9wcml2YWN5LWFuZC10b3MuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ByaXZhY3ktcG9saWN5L3ByaXZhY3ktcG9saWN5LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zcGxhc2gvc3BsYXNoLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90ZXJtcy1jb25kaXRpb25zL3Rlcm1zLWNvbmRpdGlvbnMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FwcC1sb2FkZXIvYXBwLWxvYWRlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZ2VvLXRlbXBsYXRlL2dlby10ZW1wbGF0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXV0aGV0aWNhdG9yL2F1dGhldGljYXRvci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2xlYXJiaXQtaWNvbi9jbGVhcmJpdC1pY29uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21pbmctc29vbi9jb21pbmctc29vbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbm8tZGF0YS9uby1kYXRhLmNvbXBvbmVudCc7XG4vLyBleHBvcnQgKiBmcm9tICcuL2xpYi9wdXNoYmFjay1wb3B1cC9wdXNoYmFjay1wb3B1cC5jb21wb25lbnQnO1xuLy8gZXhwb3J0ICogZnJvbSAnLi9saWIvbGFiZWwtbWFuYWdlbWVudC9lbnRpdHktZ3JvdXAvZW50aXR5LWdyb3VwLmNvbXBvbmVudCc7XG4iXX0=
21
+ export * from './lib/label-management/entity-group/entity-group.component';
22
+ export * from './lib/label-management/groups/groups.component';
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL3NoYXJlZC1jb21wb25lbnRzL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsNkRBQTZELENBQUM7QUFDNUUsY0FBYyx1REFBdUQsQ0FBQztBQUN0RSxjQUFjLHlEQUF5RCxDQUFDO0FBQ3hFLGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLHlEQUF5RCxDQUFDO0FBQ3hFLGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw0REFBNEQsQ0FBQztBQUMzRSxjQUFjLGdEQUFnRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvc2hhcmVkLWNvbXBvbmVudHMubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FiLXRlc3QvYWItdGVzdC1jb250YWluZXIvYWItdGVzdC1jb250YWluZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FiLXRlc3QvYWItYWx0ZXJuYXRpdmUvYWItYWx0ZXJuYXRpdmUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Bhc3N3b3JkLXZhbGlkYXRpb24vcGFzc3dvcmQtdmFsaWRhdGlvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY3VzdG9tLXVwbG9hZGVyL2N1c3RvbS11cGxvYWRlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaW1hZ2UtY3JvcHBlci9pbWFnZS1jcm9wcGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdy10YWJzL3B3LXRhYnMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Blcm1pc3Npb24tdHJlZS9wZXJtaXNzaW9uLXRyZWUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2lucHV0LWNvbnRhaW5lci9pbnB1dC1jb250YWluZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpZWxkLWVycm9yLWRpc3BsYXkvZmllbGQtZXJyb3ItZGlzcGxheS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHJpdmFjeS1hbmQtdG9zL3ByaXZhY3ktYW5kLXRvcy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHJpdmFjeS1wb2xpY3kvcHJpdmFjeS1wb2xpY3kuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NwbGFzaC9zcGxhc2guY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Rlcm1zLWNvbmRpdGlvbnMvdGVybXMtY29uZGl0aW9ucy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXBwLWxvYWRlci9hcHAtbG9hZGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9nZW8tdGVtcGxhdGUvZ2VvLXRlbXBsYXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRoZXRpY2F0b3IvYXV0aGV0aWNhdG9yLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jbGVhcmJpdC1pY29uL2NsZWFyYml0LWljb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbWluZy1zb29uL2NvbWluZy1zb29uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9uby1kYXRhL25vLWRhdGEuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xhYmVsLW1hbmFnZW1lbnQvZW50aXR5LWdyb3VwL2VudGl0eS1ncm91cC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbGFiZWwtbWFuYWdlbWVudC9ncm91cHMvZ3JvdXBzLmNvbXBvbmVudCc7XG4iXX0=
@@ -0,0 +1,156 @@
1
+ import { Component, Injector, TemplateRef, ViewChild } from '@angular/core';
2
+ import { NgbModal } from '@ng-bootstrap/ng-bootstrap';
3
+ import { TAG_ENTITY } from '@posiwise/common-utilities';
4
+ import { AppBaseComponent } from '@posiwise/app-base-component';
5
+ import { GroupService } from '@posiwise/common-services';
6
+ import { HelperService } from '@posiwise/helper-service';
7
+ import { PermissionService } from '@posiwise/common-services';
8
+ import { SubscriptionService } from '@posiwise/common-services';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@posiwise/common-services";
11
+ import * as i2 from "@ng-bootstrap/ng-bootstrap";
12
+ import * as i3 from "@angular/forms";
13
+ import * as i4 from "@posiwise/directives";
14
+ import * as i5 from "@angular/router";
15
+ import * as i6 from "primeng/api";
16
+ import * as i7 from "primeng/progressspinner";
17
+ import * as i8 from "primeng/table";
18
+ import * as i9 from "primeng/autocomplete";
19
+ import * as i10 from "@angular/common";
20
+ import * as i11 from "../../no-data/no-data.component";
21
+ import * as i12 from "@ngneat/transloco";
22
+ export class EntityGroupComponent extends AppBaseComponent {
23
+ constructor(groupService, subscriptionService, modalService, injector) {
24
+ super(injector);
25
+ this.groupService = groupService;
26
+ this.subscriptionService = subscriptionService;
27
+ this.modalService = modalService;
28
+ this.subscriptionMembers = []; // Holds all the members
29
+ this.subscribedMembers = []; // Holds all the members
30
+ this.filteredMembers = []; // Populates in the autocomplete
31
+ this.selectedMembers = []; // Selected in the autocomplete
32
+ this.admins = [];
33
+ this.subscriptionInfo = [];
34
+ this.isLoaded = false;
35
+ }
36
+ ngOnInit() {
37
+ this.getUserSubscription().subscribe(response => {
38
+ this.subscription = response;
39
+ if (this.subscription?.id) {
40
+ this.getSubscribedUsers();
41
+ }
42
+ });
43
+ this.route.params.subscribe(params => {
44
+ this.entityId = Number(params['groupId']);
45
+ this.getEntity();
46
+ });
47
+ this.userStore().subscribe(user => {
48
+ this.user = user;
49
+ if (this.user) {
50
+ this.userId = this.user.id;
51
+ }
52
+ });
53
+ this.chatPermission = `${PermissionService.selectedProduct?.permission}.${PermissionService.selectedProduct?.feature_key}`;
54
+ }
55
+ search(event) {
56
+ let data = [];
57
+ if (event.query) {
58
+ data = this.subscriptionMembers.filter((x) => {
59
+ return x.displayName.toLowerCase().includes(event.query.toLowerCase());
60
+ });
61
+ }
62
+ else {
63
+ this.subscriptionMembers.forEach(element => {
64
+ data.push(element);
65
+ });
66
+ }
67
+ this.filteredMembers = data;
68
+ }
69
+ open() {
70
+ this.groupService.getSubscriptionMembers(this.subscription?.id).subscribe(response => {
71
+ response.members.forEach(member => {
72
+ member.displayName = `${member.first_name || ''} ${member.last_name || ''} ${member.email}`.trim();
73
+ });
74
+ this.subscriptionMembers = response.members;
75
+ });
76
+ this.modalService.open(this.content, { centered: true, windowClass: 'modal-holder' });
77
+ }
78
+ closeModal(modal) {
79
+ modal.close();
80
+ this.filteredMembers = [];
81
+ }
82
+ getEntity() {
83
+ this.groupService.getEntityGroup(this.entityId).subscribe(response => {
84
+ response.members.forEach(member => {
85
+ member.displayName = `${member.first_name || ''} ${member.last_name || ''} ${member.email}`.trim();
86
+ });
87
+ this.isLoaded = true;
88
+ this.subscribedMembers = response.members;
89
+ this.selectedGroup = response;
90
+ });
91
+ }
92
+ onSave() {
93
+ const data = {
94
+ entity_groups: [
95
+ {
96
+ related_entity_id: this.selectedMembers.map(x => x.id),
97
+ related_entity_type: TAG_ENTITY.USER
98
+ }
99
+ ]
100
+ };
101
+ this.groupService.addEntityGroup(this.entityId, data).subscribe(() => {
102
+ this.modalService.dismissAll();
103
+ this.toast.success(this.translation.translate('Admin.Shared.Entity.AddedMessage'));
104
+ this.getEntity();
105
+ });
106
+ }
107
+ getSubscribedUsers() {
108
+ this.subscriptionService
109
+ .getEnrolledSubscription(this.subscription?.id)
110
+ .subscribe(response => {
111
+ this.subscriptionOwner = response.owner_id;
112
+ this.admins = response.admins;
113
+ this.enrolledUsers = response.members;
114
+ this.enrolledUsers.forEach(element => {
115
+ element.is_owner = element?.id === this.user?.id;
116
+ });
117
+ this.hasAccess =
118
+ this.admins.includes(this.user?.id) ||
119
+ this.user?.id === this.subscriptionOwner ||
120
+ this.permissionService.isSuperAdmin();
121
+ });
122
+ }
123
+ onDelete(memberId) {
124
+ HelperService.raiseDeletePopup()
125
+ .then(resp => {
126
+ if (resp.value) {
127
+ const data = JSON.stringify([memberId]);
128
+ this.groupService
129
+ .deleteEntityGroup(this.entityId, data, 'User')
130
+ .subscribe(() => {
131
+ this.toast.success(this.translation.translate('Admin.Shared.Entity.DeletedMessage'));
132
+ this.getEntity();
133
+ });
134
+ }
135
+ })
136
+ .catch(error => this.toast.showToast(error));
137
+ }
138
+ navigateToCommunications() {
139
+ this.router.navigate([`/${this.subscription?.slug}/enterprise/communications`], {
140
+ queryParams: { entity_id: this.entityId }
141
+ });
142
+ }
143
+ ngOnDestroy() {
144
+ super.ngOnDestroy();
145
+ }
146
+ }
147
+ EntityGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: EntityGroupComponent, deps: [{ token: i1.GroupService }, { token: i1.SubscriptionService }, { token: i2.NgbModal }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
148
+ EntityGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: EntityGroupComponent, selector: "pw-entity-group", viewQueries: [{ propertyName: "content", first: true, predicate: ["content"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div>\n <div class=\"row\">\n <div class=\"col-12 mb-3\">\n <h2>Team View</h2>\n\n <p>\n In this section, based on your permissions, you can add/remove members from your\n teams.\n <br />\n Then, you'll be able to see powerful insight on the activities performed by your\n team's members.\n </p>\n </div>\n </div>\n\n <div class=\"row\">\n <div class=\"col-md-6 col-xs-12 d-flex align-items-sm-center align-items-top text-start pe-0\">\n <a href=\"javascript:void(0)\"\n (click)=\"back()\"\n class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n <h3 class=\"ms-sm-2 d-inline mt-0 card-title mb-3 mb-sm-0\">\n Team view: {{ selectedGroup?.name }}\n </h3>\n </div>\n <div class=\"col-md-6 col-xs-12 text-end justify-content-end\">\n <button *ngIf=\"hasAccess\"\n class=\"btn btn-sm btn-outline-primary\"\n (click)=\"open()\">\n <i class=\"fa fa-plus-circle\" aria-hidden=\"true\"></i> Add Members\n </button>\n <button *ngIf=\"hasAccess\"\n class=\"btn btn-sm btn-outline-primary ms-2\"\n (click)=\"navigateToCommunications()\">\n <i class=\"fa fa-plus-circle\" aria-hidden=\"true\"></i> See Communications\n </button>\n </div>\n </div>\n\n <div class=\"w-100 text-center mt-3\"\n *ngIf=\"!isLoaded\">\n <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n </div>\n\n <div class=\"primeng-datatable-container table-responsive\"\n [class.hideTable]=\"subscribedMembers?.length === 0\">\n <p-table #dt\n [value]=\"subscribedMembers\"\n [paginator]=\"true\"\n [responsive]=\"true\"\n [rows]=\"PAGE_SIZE\">\n <ng-template pTemplate=\"header\">\n <tr>\n <th scope=\"true\">{{ 'Label.FirstName' | transloco }}</th>\n <th scope=\"true\">{{ 'Label.LastName' | transloco }}</th>\n <th scope=\"true\">{{ 'Label.Email' | transloco }}</th>\n <th scope=\"true\">{{ 'Label.Actions' | transloco }}</th>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"body\"\n let-member>\n <tr class=\"table-row\">\n <td data-head=\"First Name\">\n <a [routerLink]=\"['/members', member.slug]\">{{ member.first_name || null }}\n </a>\n </td>\n <td data-head=\"Last Name\">{{ member.last_name || null }}</td>\n <td data-head=\"Email\">{{ member.email }}</td>\n <td data-head=\"Action\">\n <ul class=\"list-unstyled list-inline\">\n <li ngbTooltip=\"Message\"\n class=\"me-2 me-sm-3\"\n *ngIf=\"member.id !== userId\"\n [routerLink]=\"['/message']\"\n [fragment]=\"member.slug\">\n <i\n class=\"fa fa-comments cta1-icon\"\n *rbacAllow=\"chatPermission\"\n aria-hidden=\"true\"\n ></i>\n </li>\n <li ngbTooltip=\"Remove\"\n class=\"me-2 me-sm-3\"\n (click)=\"onDelete(member.id)\"\n *ngIf=\"hasAccess\">\n <i class=\"fa fa-trash delete-icon\" aria-hidden=\"true\"></i>\n </li>\n </ul>\n </td>\n </tr>\n </ng-template>\n </p-table>\n </div>\n <pw-no-data message=\"There are no members in this team yet.\"\n *ngIf=\"subscribedMembers?.length === 0 && isLoaded\">\n </pw-no-data>\n</div>\n\n<ng-template #content\n let-modal>\n <div class=\"modal-header\">\n <h4 class=\"modal-title\"\n id=\"modal-basic-title\">Add Members</h4>\n <button type=\"button\"\n class=\"btn-close float-end\"\n aria-label=\"Close\"\n (click)=\"modal.dismiss()\">\n\n </button>\n </div>\n <div class=\"modal-body\">\n <p>Please start typing to select the members to add to this team.</p>\n <div class=\"ui-fluid skills-modal\">\n <p-autoComplete [suggestions]=\"filteredMembers\"\n [(ngModel)]=\"selectedMembers\"\n dataKey=\"id\"\n field=\"displayName\"\n (completeMethod)=\"search($event)\"\n styleClass=\"w-100\"\n placeholder=\"Member\"\n [multiple]=\"true\">\n </p-autoComplete>\n </div>\n </div>\n <div class=\"modal-footer\">\n <button type=\"button\"\n class=\"btn btn-outline-default\"\n (click)=\"closeModal(modal)\">\n {{ 'Button.Cancel' | transloco }}\n </button>\n <button type=\"button\"\n class=\"btn btn-primary\"\n (click)=\"onSave()\">\n {{ 'Button.Save' | transloco }}\n </button>\n </div>\n</ng-template>\n", styles: ["a.previous i{line-height:23px}\n"], dependencies: [{ kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.RbacAllowDirective, selector: "[rbacAllow]", inputs: ["rbacAllow"] }, { kind: "directive", type: i5.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i6.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { kind: "component", type: i7.ProgressSpinner, selector: "p-progressSpinner", inputs: ["style", "styleClass", "strokeWidth", "fill", "animationDuration"] }, { kind: "component", type: i8.Table, selector: "p-table", inputs: ["frozenColumns", "frozenValue", "style", "styleClass", "tableStyle", "tableStyleClass", "paginator", "pageLinks", "rowsPerPageOptions", "alwaysShowPaginator", "paginatorPosition", "paginatorDropdownAppendTo", "paginatorDropdownScrollHeight", "currentPageReportTemplate", "showCurrentPageReport", "showJumpToPageDropdown", "showJumpToPageInput", "showFirstLastIcon", "showPageLinks", "defaultSortOrder", "sortMode", "resetPageOnSort", "selectionMode", "selectionPageOnly", "contextMenuSelection", "contextMenuSelectionMode", "dataKey", "metaKeySelection", "rowSelectable", "rowTrackBy", "lazy", "lazyLoadOnInit", "compareSelectionBy", "csvSeparator", "exportFilename", "filters", "globalFilterFields", "filterDelay", "filterLocale", "expandedRowKeys", "editingRowKeys", "rowExpandMode", "scrollable", "scrollDirection", "rowGroupMode", "scrollHeight", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "virtualScrollDelay", "frozenWidth", "responsive", "contextMenu", "resizableColumns", "columnResizeMode", "reorderableColumns", "loading", "loadingIcon", "showLoader", "rowHover", "customSort", "showInitialSortBadge", "autoLayout", "exportFunction", "exportHeader", "stateKey", "stateStorage", "editMode", "groupRowsBy", "groupRowsByOrder", "responsiveLayout", "breakpoint", "virtualRowHeight", "value", "columns", "first", "rows", "totalRecords", "sortField", "sortOrder", "multiSortMeta", "selection", "selectAll"], outputs: ["selectAllChange", "selectionChange", "contextMenuSelectionChange", "onRowSelect", "onRowUnselect", "onPage", "onSort", "onFilter", "onLazyLoad", "onRowExpand", "onRowCollapse", "onContextMenuSelect", "onColResize", "onColReorder", "onRowReorder", "onEditInit", "onEditComplete", "onEditCancel", "onHeaderCheckboxToggle", "sortFunction", "firstChange", "rowsChange", "onStateSave", "onStateRestore"] }, { kind: "component", type: i9.AutoComplete, selector: "p-autoComplete", inputs: ["minLength", "delay", "style", "panelStyle", "styleClass", "panelStyleClass", "inputStyle", "inputId", "inputStyleClass", "placeholder", "readonly", "disabled", "scrollHeight", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "maxlength", "name", "required", "size", "appendTo", "autoHighlight", "forceSelection", "type", "autoZIndex", "baseZIndex", "ariaLabel", "dropdownAriaLabel", "ariaLabelledBy", "dropdownIcon", "unique", "group", "completeOnFocus", "showClear", "field", "dropdown", "showEmptyMessage", "dropdownMode", "multiple", "tabindex", "dataKey", "emptyMessage", "showTransitionOptions", "hideTransitionOptions", "autofocus", "autocomplete", "optionGroupChildren", "optionGroupLabel", "overlayOptions", "itemSize", "suggestions"], outputs: ["completeMethod", "onSelect", "onUnselect", "onFocus", "onBlur", "onDropdownClick", "onClear", "onKeyUp", "onShow", "onHide", "onLazyLoad"] }, { kind: "directive", type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "popperOptions", "triggers", "positionTarget", "container", "disableTooltip", "tooltipClass", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { kind: "component", type: i11.NoDataComponent, selector: "pw-no-data", inputs: ["message"] }, { kind: "pipe", type: i12.TranslocoPipe, name: "transloco" }] });
149
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: EntityGroupComponent, decorators: [{
150
+ type: Component,
151
+ args: [{ selector: 'pw-entity-group', template: "<div>\n <div class=\"row\">\n <div class=\"col-12 mb-3\">\n <h2>Team View</h2>\n\n <p>\n In this section, based on your permissions, you can add/remove members from your\n teams.\n <br />\n Then, you'll be able to see powerful insight on the activities performed by your\n team's members.\n </p>\n </div>\n </div>\n\n <div class=\"row\">\n <div class=\"col-md-6 col-xs-12 d-flex align-items-sm-center align-items-top text-start pe-0\">\n <a href=\"javascript:void(0)\"\n (click)=\"back()\"\n class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n <h3 class=\"ms-sm-2 d-inline mt-0 card-title mb-3 mb-sm-0\">\n Team view: {{ selectedGroup?.name }}\n </h3>\n </div>\n <div class=\"col-md-6 col-xs-12 text-end justify-content-end\">\n <button *ngIf=\"hasAccess\"\n class=\"btn btn-sm btn-outline-primary\"\n (click)=\"open()\">\n <i class=\"fa fa-plus-circle\" aria-hidden=\"true\"></i> Add Members\n </button>\n <button *ngIf=\"hasAccess\"\n class=\"btn btn-sm btn-outline-primary ms-2\"\n (click)=\"navigateToCommunications()\">\n <i class=\"fa fa-plus-circle\" aria-hidden=\"true\"></i> See Communications\n </button>\n </div>\n </div>\n\n <div class=\"w-100 text-center mt-3\"\n *ngIf=\"!isLoaded\">\n <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n </div>\n\n <div class=\"primeng-datatable-container table-responsive\"\n [class.hideTable]=\"subscribedMembers?.length === 0\">\n <p-table #dt\n [value]=\"subscribedMembers\"\n [paginator]=\"true\"\n [responsive]=\"true\"\n [rows]=\"PAGE_SIZE\">\n <ng-template pTemplate=\"header\">\n <tr>\n <th scope=\"true\">{{ 'Label.FirstName' | transloco }}</th>\n <th scope=\"true\">{{ 'Label.LastName' | transloco }}</th>\n <th scope=\"true\">{{ 'Label.Email' | transloco }}</th>\n <th scope=\"true\">{{ 'Label.Actions' | transloco }}</th>\n </tr>\n </ng-template>\n <ng-template pTemplate=\"body\"\n let-member>\n <tr class=\"table-row\">\n <td data-head=\"First Name\">\n <a [routerLink]=\"['/members', member.slug]\">{{ member.first_name || null }}\n </a>\n </td>\n <td data-head=\"Last Name\">{{ member.last_name || null }}</td>\n <td data-head=\"Email\">{{ member.email }}</td>\n <td data-head=\"Action\">\n <ul class=\"list-unstyled list-inline\">\n <li ngbTooltip=\"Message\"\n class=\"me-2 me-sm-3\"\n *ngIf=\"member.id !== userId\"\n [routerLink]=\"['/message']\"\n [fragment]=\"member.slug\">\n <i\n class=\"fa fa-comments cta1-icon\"\n *rbacAllow=\"chatPermission\"\n aria-hidden=\"true\"\n ></i>\n </li>\n <li ngbTooltip=\"Remove\"\n class=\"me-2 me-sm-3\"\n (click)=\"onDelete(member.id)\"\n *ngIf=\"hasAccess\">\n <i class=\"fa fa-trash delete-icon\" aria-hidden=\"true\"></i>\n </li>\n </ul>\n </td>\n </tr>\n </ng-template>\n </p-table>\n </div>\n <pw-no-data message=\"There are no members in this team yet.\"\n *ngIf=\"subscribedMembers?.length === 0 && isLoaded\">\n </pw-no-data>\n</div>\n\n<ng-template #content\n let-modal>\n <div class=\"modal-header\">\n <h4 class=\"modal-title\"\n id=\"modal-basic-title\">Add Members</h4>\n <button type=\"button\"\n class=\"btn-close float-end\"\n aria-label=\"Close\"\n (click)=\"modal.dismiss()\">\n\n </button>\n </div>\n <div class=\"modal-body\">\n <p>Please start typing to select the members to add to this team.</p>\n <div class=\"ui-fluid skills-modal\">\n <p-autoComplete [suggestions]=\"filteredMembers\"\n [(ngModel)]=\"selectedMembers\"\n dataKey=\"id\"\n field=\"displayName\"\n (completeMethod)=\"search($event)\"\n styleClass=\"w-100\"\n placeholder=\"Member\"\n [multiple]=\"true\">\n </p-autoComplete>\n </div>\n </div>\n <div class=\"modal-footer\">\n <button type=\"button\"\n class=\"btn btn-outline-default\"\n (click)=\"closeModal(modal)\">\n {{ 'Button.Cancel' | transloco }}\n </button>\n <button type=\"button\"\n class=\"btn btn-primary\"\n (click)=\"onSave()\">\n {{ 'Button.Save' | transloco }}\n </button>\n </div>\n</ng-template>\n", styles: ["a.previous i{line-height:23px}\n"] }]
152
+ }], ctorParameters: function () { return [{ type: i1.GroupService }, { type: i1.SubscriptionService }, { type: i2.NgbModal }, { type: i0.Injector }]; }, propDecorators: { content: [{
153
+ type: ViewChild,
154
+ args: ['content', { static: true }]
155
+ }] } });
156
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entity-group.component.js","sourceRoot":"","sources":["../../../../../../../libs/shared-components/src/lib/label-management/entity-group/entity-group.component.ts","../../../../../../../libs/shared-components/src/lib/label-management/entity-group/entity-group.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAqB,WAAW,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC/F,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AAEtD,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AACxD,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAGhE,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;;;;;;;;;;;;;;AAOhE,MAAM,OAAO,oBAAqB,SAAQ,gBAAgB;IAqCtD,YACY,YAA0B,EAC1B,mBAAwC,EACxC,YAAsB,EAC9B,QAAkB;QAElB,KAAK,CAAC,QAAQ,CAAC,CAAC;QALR,iBAAY,GAAZ,YAAY,CAAc;QAC1B,wBAAmB,GAAnB,mBAAmB,CAAqB;QACxC,iBAAY,GAAZ,YAAY,CAAU;QA/BlC,wBAAmB,GAAG,EAAE,CAAC,CAAC,wBAAwB;QAElD,sBAAiB,GAAG,EAAE,CAAC,CAAC,wBAAwB;QAEhD,oBAAe,GAAG,EAAE,CAAC,CAAC,gCAAgC;QAEtD,oBAAe,GAAG,EAAE,CAAC,CAAC,+BAA+B;QAIrD,WAAM,GAAG,EAAE,CAAC;QAEZ,qBAAgB,GAAG,EAAE,CAAC;QAUtB,aAAQ,GAAG,KAAK,CAAC;IAajB,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,mBAAmB,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;YAC5C,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC;YAC7B,IAAI,IAAI,CAAC,YAAY,EAAE,EAAE,EAAE;gBACvB,IAAI,CAAC,kBAAkB,EAAE,CAAC;aAC7B;QACL,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YACjC,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;YAC1C,IAAI,CAAC,SAAS,EAAE,CAAC;QACrB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,SAAS,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;YAC9B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;YACjB,IAAI,IAAI,CAAC,IAAI,EAAE;gBACX,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;aAC9B;QACL,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,cAAc,GAAG,GAAG,iBAAiB,CAAC,eAAe,EAAE,UAAU,IAAI,iBAAiB,CAAC,eAAe,EAAE,WAAW,EAAE,CAAC;IAC/H,CAAC;IAED,MAAM,CAAC,KAAK;QACR,IAAI,IAAI,GAAG,EAAE,CAAC;QACd,IAAI,KAAK,CAAC,KAAK,EAAE;YACb,IAAI,GAAG,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAM,EAAE,EAAE;gBAC9C,OAAO,CAAC,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC;YAC3E,CAAC,CAAC,CAAC;SACN;aAAM;YACH,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBACvC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACvB,CAAC,CAAC,CAAC;SACN;QACD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;IAChC,CAAC;IAED,IAAI;QACA,IAAI,CAAC,YAAY,CAAC,sBAAsB,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;YACjF,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;gBAC9B,MAAM,CAAC,WAAW,GAAG,GAAG,MAAM,CAAC,UAAU,IAAI,EAAE,IAAI,MAAM,CAAC,SAAS,IAAI,EAAE,IACrE,MAAM,CAAC,KACX,EAAE,CAAC,IAAI,EAAE,CAAC;YACd,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,mBAAmB,GAAG,QAAQ,CAAC,OAAO,CAAC;QAChD,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,WAAW,EAAE,cAAc,EAAE,CAAC,CAAC;IAC1F,CAAC;IAED,UAAU,CAAC,KAAK;QACZ,KAAK,CAAC,KAAK,EAAE,CAAC;QACd,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC9B,CAAC;IAED,SAAS;QACL,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;YACjE,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;gBAC9B,MAAM,CAAC,WAAW,GAAG,GAAG,MAAM,CAAC,UAAU,IAAI,EAAE,IAAI,MAAM,CAAC,SAAS,IAAI,EAAE,IACrE,MAAM,CAAC,KACX,EAAE,CAAC,IAAI,EAAE,CAAC;YACd,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;YACrB,IAAI,CAAC,iBAAiB,GAAG,QAAQ,CAAC,OAAO,CAAC;YAC1C,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC;QAClC,CAAC,CAAC,CAAC;IACP,CAAC;IAED,MAAM;QACF,MAAM,IAAI,GAAG;YACT,aAAa,EAAE;gBACX;oBACI,iBAAiB,EAAE,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;oBACtD,mBAAmB,EAAE,UAAU,CAAC,IAAI;iBACvC;aACJ;SACJ,CAAC;QAEF,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACjE,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;YAC/B,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,kCAAkC,CAAC,CAAC,CAAC;YAEnF,IAAI,CAAC,SAAS,EAAE,CAAC;QACrB,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,kBAAkB;QACtB,IAAI,CAAC,mBAAmB;aACnB,uBAAuB,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,CAAC;aAC9C,SAAS,CAAC,QAAQ,CAAC,EAAE;YAClB,IAAI,CAAC,iBAAiB,GAAG,QAAQ,CAAC,QAAQ,CAAC;YAC3C,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC;YAC9B,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC,OAAO,CAAC;YACtC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBACjC,OAAO,CAAC,QAAQ,GAAG,OAAO,EAAE,EAAE,KAAK,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;YACrD,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,SAAS;gBACV,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;oBACnC,IAAI,CAAC,IAAI,EAAE,EAAE,KAAK,IAAI,CAAC,iBAAiB;oBACxC,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;QAC9C,CAAC,CAAC,CAAC;IACX,CAAC;IAED,QAAQ,CAAC,QAAQ;QACb,aAAa,CAAC,gBAAgB,EAAE;aAC3B,IAAI,CAAC,IAAI,CAAC,EAAE;YACT,IAAI,IAAI,CAAC,KAAK,EAAE;gBACZ,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;gBACxC,IAAI,CAAC,YAAY;qBACZ,iBAAiB,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,EAAE,MAAM,CAAC;qBAC9C,SAAS,CAAC,GAAG,EAAE;oBACZ,IAAI,CAAC,KAAK,CAAC,OAAO,CACd,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,oCAAoC,CAAC,CACnE,CAAC;oBACF,IAAI,CAAC,SAAS,EAAE,CAAC;gBACrB,CAAC,CAAC,CAAC;aACV;QACL,CAAC,CAAC;aACD,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;IACrD,CAAC;IAED,wBAAwB;QACpB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,IAAI,CAAC,YAAY,EAAE,IAAI,4BAA4B,CAAC,EAAE;YAC5E,WAAW,EAAE,EAAE,SAAS,EAAE,IAAI,CAAC,QAAQ,EAAE;SAC5C,CAAC,CAAC;IACP,CAAC;IAEQ,WAAW;QAChB,KAAK,CAAC,WAAW,EAAE,CAAC;IACxB,CAAC;;iHA5KQ,oBAAoB;qGAApB,oBAAoB,gMCjBjC,qrJAwIA;2FDvHa,oBAAoB;kBALhC,SAAS;+BACI,iBAAiB;mLAKa,OAAO;sBAA9C,SAAS;uBAAC,SAAS,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import { Component, Injector, OnDestroy, OnInit, TemplateRef, ViewChild } from '@angular/core';\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\n\nimport { TAG_ENTITY } from '@posiwise/common-utilities';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { Subscription } from '@posiwise/common-utilities';\nimport { User } from '@posiwise/common-utilities';\nimport { GroupService } from '@posiwise/common-services';\nimport { HelperService } from '@posiwise/helper-service';\nimport { PermissionService } from '@posiwise/common-services';\nimport { SubscriptionService } from '@posiwise/common-services';\n\n@Component({\n    selector: 'pw-entity-group',\n    templateUrl: './entity-group.component.html',\n    styleUrls: ['./entity-group.component.scss']\n})\nexport class EntityGroupComponent extends AppBaseComponent implements OnInit, OnDestroy {\n    @ViewChild('content', { static: true }) content: TemplateRef<any>;\n\n    entityId: number;\n\n    selectedGroup: any;\n\n    subscriptionId: number;\n\n    subscriptionMembers = []; // Holds all the members\n\n    subscribedMembers = []; // Holds all the members\n\n    filteredMembers = []; // Populates in the autocomplete\n\n    selectedMembers = []; // Selected in the autocomplete\n\n    hasAccess: boolean;\n\n    admins = [];\n\n    subscriptionInfo = [];\n\n    subscriptionOwner: any;\n\n    enrolledUsers: any;\n\n    user: User;\n\n    userId: number;\n\n    isLoaded = false;\n\n    subscription: Subscription;\n\n    chatPermission: string;\n\n    constructor(\n        private groupService: GroupService,\n        private subscriptionService: SubscriptionService,\n        private modalService: NgbModal,\n        injector: Injector\n    ) {\n        super(injector);\n    }\n\n    ngOnInit() {\n        this.getUserSubscription().subscribe(response => {\n            this.subscription = response;\n            if (this.subscription?.id) {\n                this.getSubscribedUsers();\n            }\n        });\n        this.route.params.subscribe(params => {\n            this.entityId = Number(params['groupId']);\n            this.getEntity();\n        });\n        this.userStore().subscribe(user => {\n            this.user = user;\n            if (this.user) {\n                this.userId = this.user.id;\n            }\n        });\n        this.chatPermission = `${PermissionService.selectedProduct?.permission}.${PermissionService.selectedProduct?.feature_key}`;\n    }\n\n    search(event) {\n        let data = [];\n        if (event.query) {\n            data = this.subscriptionMembers.filter((x: any) => {\n                return x.displayName.toLowerCase().includes(event.query.toLowerCase());\n            });\n        } else {\n            this.subscriptionMembers.forEach(element => {\n                data.push(element);\n            });\n        }\n        this.filteredMembers = data;\n    }\n\n    open() {\n        this.groupService.getSubscriptionMembers(this.subscription?.id).subscribe(response => {\n            response.members.forEach(member => {\n                member.displayName = `${member.first_name || ''} ${member.last_name || ''} ${\n                    member.email\n                }`.trim();\n            });\n            this.subscriptionMembers = response.members;\n        });\n\n        this.modalService.open(this.content, { centered: true, windowClass: 'modal-holder' });\n    }\n\n    closeModal(modal) {\n        modal.close();\n        this.filteredMembers = [];\n    }\n\n    getEntity() {\n        this.groupService.getEntityGroup(this.entityId).subscribe(response => {\n            response.members.forEach(member => {\n                member.displayName = `${member.first_name || ''} ${member.last_name || ''} ${\n                    member.email\n                }`.trim();\n            });\n            this.isLoaded = true;\n            this.subscribedMembers = response.members;\n            this.selectedGroup = response;\n        });\n    }\n\n    onSave() {\n        const data = {\n            entity_groups: [\n                {\n                    related_entity_id: this.selectedMembers.map(x => x.id),\n                    related_entity_type: TAG_ENTITY.USER\n                }\n            ]\n        };\n\n        this.groupService.addEntityGroup(this.entityId, data).subscribe(() => {\n            this.modalService.dismissAll();\n            this.toast.success(this.translation.translate('Admin.Shared.Entity.AddedMessage'));\n\n            this.getEntity();\n        });\n    }\n\n    private getSubscribedUsers() {\n        this.subscriptionService\n            .getEnrolledSubscription(this.subscription?.id)\n            .subscribe(response => {\n                this.subscriptionOwner = response.owner_id;\n                this.admins = response.admins;\n                this.enrolledUsers = response.members;\n                this.enrolledUsers.forEach(element => {\n                    element.is_owner = element?.id === this.user?.id;\n                });\n                this.hasAccess =\n                    this.admins.includes(this.user?.id) ||\n                    this.user?.id === this.subscriptionOwner ||\n                    this.permissionService.isSuperAdmin();\n            });\n    }\n\n    onDelete(memberId) {\n        HelperService.raiseDeletePopup()\n            .then(resp => {\n                if (resp.value) {\n                    const data = JSON.stringify([memberId]);\n                    this.groupService\n                        .deleteEntityGroup(this.entityId, data, 'User')\n                        .subscribe(() => {\n                            this.toast.success(\n                                this.translation.translate('Admin.Shared.Entity.DeletedMessage')\n                            );\n                            this.getEntity();\n                        });\n                }\n            })\n            .catch(error => this.toast.showToast(error));\n    }\n\n    navigateToCommunications() {\n        this.router.navigate([`/${this.subscription?.slug}/enterprise/communications`], {\n            queryParams: { entity_id: this.entityId }\n        });\n    }\n\n    override ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","<div>\n  <div class=\"row\">\n    <div class=\"col-12 mb-3\">\n      <h2>Team View</h2>\n\n      <p>\n        In this section, based on your permissions, you can add/remove members from your\n        teams.\n        <br />\n        Then, you'll be able to see powerful insight on the activities performed by your\n        team's members.\n      </p>\n    </div>\n  </div>\n\n  <div class=\"row\">\n    <div class=\"col-md-6 col-xs-12 d-flex align-items-sm-center align-items-top text-start pe-0\">\n      <a href=\"javascript:void(0)\"\n        (click)=\"back()\"\n        class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n      <h3 class=\"ms-sm-2 d-inline mt-0 card-title mb-3 mb-sm-0\">\n        Team view: {{ selectedGroup?.name }}\n      </h3>\n    </div>\n    <div class=\"col-md-6 col-xs-12 text-end justify-content-end\">\n      <button *ngIf=\"hasAccess\"\n        class=\"btn btn-sm btn-outline-primary\"\n        (click)=\"open()\">\n        <i class=\"fa fa-plus-circle\" aria-hidden=\"true\"></i> Add Members\n      </button>\n      <button *ngIf=\"hasAccess\"\n        class=\"btn btn-sm btn-outline-primary ms-2\"\n        (click)=\"navigateToCommunications()\">\n        <i class=\"fa fa-plus-circle\" aria-hidden=\"true\"></i> See Communications\n      </button>\n    </div>\n  </div>\n\n  <div class=\"w-100 text-center mt-3\"\n    *ngIf=\"!isLoaded\">\n    <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n  </div>\n\n  <div class=\"primeng-datatable-container table-responsive\"\n    [class.hideTable]=\"subscribedMembers?.length === 0\">\n    <p-table #dt\n      [value]=\"subscribedMembers\"\n      [paginator]=\"true\"\n      [responsive]=\"true\"\n      [rows]=\"PAGE_SIZE\">\n      <ng-template pTemplate=\"header\">\n        <tr>\n          <th scope=\"true\">{{ 'Label.FirstName' | transloco }}</th>\n          <th scope=\"true\">{{ 'Label.LastName' | transloco }}</th>\n          <th scope=\"true\">{{ 'Label.Email' | transloco }}</th>\n          <th scope=\"true\">{{ 'Label.Actions' | transloco }}</th>\n        </tr>\n      </ng-template>\n      <ng-template pTemplate=\"body\"\n        let-member>\n        <tr class=\"table-row\">\n          <td data-head=\"First Name\">\n            <a [routerLink]=\"['/members', member.slug]\">{{ member.first_name || null }}\n            </a>\n          </td>\n          <td data-head=\"Last Name\">{{ member.last_name || null }}</td>\n          <td data-head=\"Email\">{{ member.email }}</td>\n          <td data-head=\"Action\">\n            <ul class=\"list-unstyled list-inline\">\n              <li ngbTooltip=\"Message\"\n                class=\"me-2 me-sm-3\"\n                *ngIf=\"member.id !== userId\"\n                [routerLink]=\"['/message']\"\n                [fragment]=\"member.slug\">\n                <i\n                                    class=\"fa fa-comments cta1-icon\"\n                                    *rbacAllow=\"chatPermission\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </li>\n              <li ngbTooltip=\"Remove\"\n                class=\"me-2 me-sm-3\"\n                (click)=\"onDelete(member.id)\"\n                *ngIf=\"hasAccess\">\n                <i class=\"fa fa-trash delete-icon\" aria-hidden=\"true\"></i>\n              </li>\n            </ul>\n          </td>\n        </tr>\n      </ng-template>\n    </p-table>\n  </div>\n  <pw-no-data message=\"There are no members in this team yet.\"\n    *ngIf=\"subscribedMembers?.length === 0 && isLoaded\">\n  </pw-no-data>\n</div>\n\n<ng-template #content\n  let-modal>\n  <div class=\"modal-header\">\n    <h4 class=\"modal-title\"\n      id=\"modal-basic-title\">Add Members</h4>\n    <button type=\"button\"\n      class=\"btn-close float-end\"\n      aria-label=\"Close\"\n      (click)=\"modal.dismiss()\">\n\n    </button>\n  </div>\n  <div class=\"modal-body\">\n    <p>Please start typing to select the members to add to this team.</p>\n    <div class=\"ui-fluid skills-modal\">\n      <p-autoComplete [suggestions]=\"filteredMembers\"\n        [(ngModel)]=\"selectedMembers\"\n        dataKey=\"id\"\n        field=\"displayName\"\n        (completeMethod)=\"search($event)\"\n        styleClass=\"w-100\"\n        placeholder=\"Member\"\n        [multiple]=\"true\">\n      </p-autoComplete>\n    </div>\n  </div>\n  <div class=\"modal-footer\">\n    <button type=\"button\"\n      class=\"btn btn-outline-default\"\n      (click)=\"closeModal(modal)\">\n      {{ 'Button.Cancel' | transloco }}\n    </button>\n    <button type=\"button\"\n      class=\"btn btn-primary\"\n      (click)=\"onSave()\">\n      {{ 'Button.Save' | transloco }}\n    </button>\n  </div>\n</ng-template>\n"]}
@@ -0,0 +1,217 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { Component, Injector } from '@angular/core';
3
+ import { UntypedFormBuilder, UntypedFormControl, Validators } from '@angular/forms';
4
+ import swal from 'sweetalert2';
5
+ import { AppBaseComponent } from '@posiwise/app-base-component';
6
+ import { DataService } from '@posiwise/common-services';
7
+ import { GroupService } from '@posiwise/common-services';
8
+ import { SubscriptionService } from '@posiwise/common-services';
9
+ import { ValidateForm } from '@posiwise/utils';
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "@angular/forms";
12
+ import * as i2 from "@posiwise/common-services";
13
+ import * as i3 from "@angular/router";
14
+ import * as i4 from "primeng/progressspinner";
15
+ import * as i5 from "@angular/common";
16
+ import * as i6 from "../../no-data/no-data.component";
17
+ import * as i7 from "@ngneat/transloco";
18
+ export class GroupsComponent extends AppBaseComponent {
19
+ constructor(fb, groupService, subscriptionService, dataService, injector) {
20
+ super(injector);
21
+ this.fb = fb;
22
+ this.groupService = groupService;
23
+ this.subscriptionService = subscriptionService;
24
+ this.dataService = dataService;
25
+ this.allGroups = [];
26
+ this.admins = [];
27
+ this.subscriptionInfo = [];
28
+ this.viewEdit = false;
29
+ this.groupDefinition = [];
30
+ this.groupsData = [];
31
+ this.isLoaded = false;
32
+ this.getUserSubscription().subscribe(response => {
33
+ this.subscription = response;
34
+ if (this.subscription?.id) {
35
+ this.id = this.subscription?.id;
36
+ }
37
+ });
38
+ this.form = this.fb.group({
39
+ name: new UntypedFormControl('', [Validators.required]),
40
+ description: new UntypedFormControl(''),
41
+ group_definition_id: new UntypedFormControl('', [Validators.required])
42
+ });
43
+ }
44
+ ngOnInit() {
45
+ this.dataService.currentMessage.subscribe(message => {
46
+ this.message = message;
47
+ });
48
+ this.userStore().subscribe(user => {
49
+ if (user) {
50
+ this.user = user;
51
+ this.getSubscribedUsers();
52
+ }
53
+ });
54
+ this.getAllGroupDefinition();
55
+ }
56
+ /** Function to save group */
57
+ saveGroup() {
58
+ this.submitted = true;
59
+ const formValue = this.form.value;
60
+ const data = {
61
+ name: formValue.name,
62
+ description: formValue.description,
63
+ group_definition_id: formValue.group_definition_id
64
+ };
65
+ this.groupService
66
+ .postGroup(data)
67
+ .subscribe(() => {
68
+ this.toast.success('Saved Successfully', '', {
69
+ extendedTimeOut: 1000000
70
+ });
71
+ this.form.reset();
72
+ this.getAllGroupDefinition();
73
+ this.isGroupOperations = false;
74
+ })
75
+ .add(() => {
76
+ this.submitted = false;
77
+ });
78
+ }
79
+ getAllGroupDefinition() {
80
+ this.allGroups = [];
81
+ this.groupService.groupDefinitionGetAll(this.id, 'Subscription').subscribe(response => {
82
+ this.isLoaded = true;
83
+ if (response.group_definitions.length > 0) {
84
+ this.groupDefinition = response.group_definitions;
85
+ this.groupDefinition.forEach(data => {
86
+ const groups = [...data.groups];
87
+ groups.forEach(group => {
88
+ this.allGroups.push({ ...group, group_definition_name: data?.name });
89
+ this.groupsData = this.allGroups;
90
+ });
91
+ });
92
+ }
93
+ else {
94
+ this.groupDefinition = [];
95
+ }
96
+ });
97
+ }
98
+ getSubscribedUsers() {
99
+ this.getUserSubscription().subscribe(sub => {
100
+ this.subscription = sub;
101
+ if (this.subscription?.id) {
102
+ this.subscriptionService.getEnrolledSubscription(sub?.id).subscribe(response => {
103
+ this.subscriptionOwner = response.owner_id;
104
+ this.admins = response.admins;
105
+ this.enrolledUsers = response.members;
106
+ this.enrolledUsers.forEach(element => {
107
+ element.is_owner = element?.id === this.user?.id;
108
+ });
109
+ this.hasAccess =
110
+ this.admins.includes(this.user?.id) ||
111
+ this.user?.id === this.subscriptionOwner ||
112
+ this.permissionService.isSuperAdmin();
113
+ });
114
+ }
115
+ });
116
+ }
117
+ groupOperation() {
118
+ this.form.reset();
119
+ this.viewEdit = false;
120
+ this.isGroupOperations = true;
121
+ this.isGroupEdit = false;
122
+ }
123
+ cancelUpdate() {
124
+ this.isGroupOperations = false;
125
+ this.form.reset();
126
+ }
127
+ editGroup(group_id) {
128
+ this.form.reset();
129
+ this.viewEdit = true;
130
+ this.isGroupOperations = true;
131
+ this.isGroupEdit = true;
132
+ this.group_id = group_id;
133
+ this.getGroupDetails(group_id);
134
+ }
135
+ getGroupDetails(id) {
136
+ this.groupService.getGroup(id).subscribe(response => {
137
+ this.form.patchValue({
138
+ name: response.name,
139
+ description: response.description,
140
+ group_definition_id: response.group_definition_id
141
+ });
142
+ });
143
+ }
144
+ updateDetails() {
145
+ const formValue = this.form.value;
146
+ const data = {
147
+ name: formValue.name,
148
+ description: formValue.description,
149
+ group_definition_id: formValue.group_definition_id
150
+ };
151
+ this.groupService.updateGroup(this.group_id, data).subscribe(() => {
152
+ this.toast.success(this.translation.translate('Admin.Shared.Groups.UpdatedMessage'));
153
+ this.form.reset();
154
+ this.getAllGroupDefinition();
155
+ this.isGroupOperations = false;
156
+ });
157
+ }
158
+ onDelete(id) {
159
+ swal.fire({
160
+ title: 'Delete',
161
+ text: `Are you sure you want to delete this team?`,
162
+ showCancelButton: true,
163
+ reverseButtons: true,
164
+ icon: 'warning'
165
+ }).then(rep => {
166
+ if (rep.value) {
167
+ this.groupService.deleteGroup(id).subscribe(_ => {
168
+ this.toast.success(this.translation.translate('Admin.Shared.Groups.DeletedMessage'));
169
+ this.isGroupOperations = false;
170
+ this.getAllGroupDefinition();
171
+ });
172
+ }
173
+ });
174
+ }
175
+ filterDomainsList(event) {
176
+ if (event.target.value !== '0') {
177
+ const searchedList = this.groupsData.filter(group => group.group_definition_id === Number(event.target.value));
178
+ this.allGroups = searchedList;
179
+ }
180
+ else {
181
+ this.allGroups = this.groupsData;
182
+ }
183
+ }
184
+ previous() {
185
+ this.location.back();
186
+ this.dataService.changeMessage(1);
187
+ }
188
+ navigateToCommunications(id) {
189
+ this.router.navigate([`/${this.subscription?.slug}/enterprise/communications`], {
190
+ queryParams: { entity_id: id }
191
+ });
192
+ }
193
+ navigateToDocumentations(id) {
194
+ this.router.navigate([`/${this.subscription?.slug}/enterprise/wiki`], {
195
+ queryParams: { entity_id: id }
196
+ });
197
+ }
198
+ trackByGroup(_index, item) {
199
+ return item.id;
200
+ }
201
+ ngOnDestroy() {
202
+ super.ngOnDestroy();
203
+ }
204
+ }
205
+ GroupsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: GroupsComponent, deps: [{ token: i1.UntypedFormBuilder }, { token: i2.GroupService }, { token: i2.SubscriptionService }, { token: i2.DataService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
206
+ GroupsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: GroupsComponent, selector: "pw-groups", usesInheritance: true, ngImport: i0, template: "<div>\n <section>\n <div class=\"row\">\n <div class=\"col-12 mb-3\">\n <h2>Enterprise Teams</h2>\n\n <p>\n Here you can define the teams for your Enterprise members. For example\n \"Corporate Sales Team\", \"Frontend Dev Team\" etc.\n <br />\n Once the teams created, you'll be able to add members to them and see useful\n insight based on the members activity in the corresponding team.\n </p>\n </div>\n </div>\n\n <div class=\"row\"\n *ngIf=\"!isGroupOperations\">\n <div class=\"col-12 d-flex justify-content-end align-items-center text-end\">\n <button *ngIf=\"hasAccess\"\n class=\"btn btn-sm btn-outline-primary\"\n (click)=\"groupOperation()\">\n <i class=\"fa fa-plus-circle\" aria-hidden=\"true\"></i> Add Team\n </button>\n <button *ngIf=\"hasAccess\"\n class=\"btn btn-sm btn-outline-primary ms-1\"\n [routerLink]=\"['/' + subscription?.slug + '/enterprise', 'groups', 'labels']\">\n <i class=\"fa fa-plus-circle\" aria-hidden=\"true\"></i> Manage Team Categories\n </button>\n </div>\n </div>\n\n <!-- Add Group Template -->\n <div *ngIf=\"isGroupOperations\"\n class=\"mb-4\">\n <h4 class=\"card-title d-inline\">{{ viewEdit ? 'Update the' : 'Create a new' }} team</h4>\n\n <div class=\"mt-4\"\n *ngIf=\"!isGroupEdit\">\n <form [formGroup]=\"form\"\n (ngSubmit)=\"saveGroup()\">\n <div class=\"row\">\n <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n <label>{{ 'Enterprise.Teams.TeamName' | transloco }}</label>\n <input type=\"text\"\n class=\"form-control\"\n formControlName=\"name\" />\n </div>\n <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n <label>{{ 'Enterprise.Teams.Description' | transloco }}</label>\n <input type=\"text\"\n class=\"form-control\"\n formControlName=\"description\" />\n </div>\n <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n <label>{{ 'Enterprise.Teams.TeamCategory' | transloco\n }}<span class=\"text-danger\">*</span>\n </label>\n <select class=\"form-select\"\n formControlName=\"group_definition_id\"\n [ngClass]=\"{\n 'is-invalid':\n submitted && form.controls['group_definition_id'].errors\n }\">\n <option *ngFor=\"let label of groupDefinition\"\n [value]=\"label.id\">\n {{ label.name }}\n </option>\n </select>\n </div>\n </div>\n\n <div class=\"row text-end mt-4\">\n <div class=\"col-12\">\n <button type=\"button\"\n (click)=\"isGroupOperations = !isGroupOperations\"\n class=\"btn btn-outline-default me-2\">\n {{ 'Button.Cancel' | transloco }}\n </button>\n <button type=\"submit\"\n class=\"btn btn-primary\">Add</button>\n </div>\n </div>\n </form>\n </div>\n\n <!-- Edit Group Template -->\n <div class=\"mt-4\"\n *ngIf=\"isGroupEdit\">\n <form [formGroup]=\"form\"\n (ngSubmit)=\"updateDetails()\">\n <div class=\"row\">\n <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n <label>{{ 'Enterprise.Teams.TeamName' | transloco }}</label>\n <input type=\"text\"\n class=\"form-control\"\n formControlName=\"name\"\n required=\"true\" />\n </div>\n <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n <label>{{ 'Enterprise.Teams.TeamDescription' | transloco }}</label>\n <input type=\"text\"\n value=\"{{ description }}\"\n class=\"form-control\"\n formControlName=\"description\"\n required=\"true\" />\n </div>\n <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n <label>{{ 'Enterprise.Teams.TeamCategory' | transloco\n }}<span class=\"text-danger\">*</span>\n </label>\n <select class=\"form-select\"\n formControlName=\"group_definition_id\"\n [ngClass]=\"{\n 'is-invalid':\n submitted && form.controls['group_definition_id'].errors\n }\">\n <option *ngFor=\"let label of groupDefinition\"\n [value]=\"label.id\">\n {{ label.name }}\n </option>\n </select>\n </div>\n </div>\n <div class=\"row text-end mt-4\">\n <div class=\"col-12\">\n <button type=\"button\"\n class=\"btn btn-outline-default me-2\"\n (click)=\"cancelUpdate()\">\n {{ 'Button.Cancel' | transloco }}\n </button>\n <button type=\"submit\"\n class=\"btn btn-primary\">\n {{ 'Button.Update' | transloco }}\n </button>\n </div>\n </div>\n </form>\n </div>\n </div>\n\n <div class=\"row\"\n *ngIf=\"!isGroupOperations\">\n <div class=\"col-4 mt-2 filter\">\n <select (change)=\"filterDomainsList($event)\"\n class=\"form-select\">\n <option value=\"0\">All Team Categories</option>\n <option *ngFor=\"let option of groupDefinition\"\n [value]=\"option.id\">\n {{ option.name }}\n </option>\n </select>\n </div>\n </div>\n <div class=\"w-100 text-center mt-3\"\n *ngIf=\"!isLoaded\">\n <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n </div>\n <div class=\"row group_list my-4\"\n *ngIf=\"!isGroupOperations\">\n <div class=\"col-12 col-md-6 col-xl-4 mt-3\"\n *ngFor=\"let group of allGroups; trackBy: trackByGroup\">\n <div class=\"card\">\n <div class=\"card-content\">\n <div class=\"card-header\">\n <h5 class=\"mb-3\">{{ group.name }}</h5>\n <p>{{ group.description | slice: 0:200 }}</p>\n <span><a class=\"badge bg-primary\">{{\n group?.group_definition_name\n }}</a></span>\n </div>\n <div class=\"card-footer\">\n <div class=\"float-end px-2\">\n <a class=\"me-2 my-1\"\n *ngIf=\"hasAccess\"\n (click)=\"onDelete(group.id)\">\n <i class=\"fa fa-trash delete-icon\" aria-hidden=\"true\"></i></a>\n <a class=\"me-2 my-1\"\n *ngIf=\"hasAccess\"\n (click)=\"editGroup(group.id)\"><i class=\"fa fa-edit edit-icon\" aria-hidden=\"true\"></i></a>\n <a class=\"me-2 my-1\"\n [routerLink]=\"[group.id, 'members']\"><i class=\"fa fa-tasks cta1-icon\" aria-hidden=\"true\"></i>\n </a>\n <a class=\"communications me-2 my-1\"\n (click)=\"navigateToCommunications(group.id)\"><i class=\"fa fa-comments cta2-icon\" aria-hidden=\"true\"></i></a>\n <a class=\"communications my-1\"\n (click)=\"navigateToDocumentations(group.id)\"><i class=\"fab fa-wikipedia-w cta1-icon\" aria-hidden=\"true\"></i></a>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </section>\n</div>\n<div *ngIf=\"allGroups?.length === 0 && hasAccess && !isGroupOperations && isLoaded\"\n class=\"clearboth\">\n <pw-no-data [message]=\"'Enterprise.Teams.NoTeamMessage' | transloco\"> </pw-no-data>\n</div>\n<div *ngIf=\"allGroups?.length === 0 && !hasAccess && !isGroupOperations && isLoaded\"\n class=\"clearboth\">\n <pw-no-data [message]=\"'Enterprise.Teams.NoTeamMessageIfUser' | transloco\"> </pw-no-data>\n</div>\n", styles: ["a.previous i{line-height:13px}.clearboth{clear:both}@media screen and (max-width: 480px){.filter{flex:none;max-width:100%!important}.communications{margin-top:2%}}\n"], dependencies: [{ kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { 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.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { 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: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { 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: i3.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i4.ProgressSpinner, selector: "p-progressSpinner", inputs: ["style", "styleClass", "strokeWidth", "fill", "animationDuration"] }, { kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i6.NoDataComponent, selector: "pw-no-data", inputs: ["message"] }, { kind: "pipe", type: i7.TranslocoPipe, name: "transloco" }, { kind: "pipe", type: i5.SlicePipe, name: "slice" }] });
207
+ __decorate([
208
+ ValidateForm('form'),
209
+ __metadata("design:type", Function),
210
+ __metadata("design:paramtypes", []),
211
+ __metadata("design:returntype", void 0)
212
+ ], GroupsComponent.prototype, "saveGroup", null);
213
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: GroupsComponent, decorators: [{
214
+ type: Component,
215
+ args: [{ selector: 'pw-groups', template: "<div>\n <section>\n <div class=\"row\">\n <div class=\"col-12 mb-3\">\n <h2>Enterprise Teams</h2>\n\n <p>\n Here you can define the teams for your Enterprise members. For example\n \"Corporate Sales Team\", \"Frontend Dev Team\" etc.\n <br />\n Once the teams created, you'll be able to add members to them and see useful\n insight based on the members activity in the corresponding team.\n </p>\n </div>\n </div>\n\n <div class=\"row\"\n *ngIf=\"!isGroupOperations\">\n <div class=\"col-12 d-flex justify-content-end align-items-center text-end\">\n <button *ngIf=\"hasAccess\"\n class=\"btn btn-sm btn-outline-primary\"\n (click)=\"groupOperation()\">\n <i class=\"fa fa-plus-circle\" aria-hidden=\"true\"></i> Add Team\n </button>\n <button *ngIf=\"hasAccess\"\n class=\"btn btn-sm btn-outline-primary ms-1\"\n [routerLink]=\"['/' + subscription?.slug + '/enterprise', 'groups', 'labels']\">\n <i class=\"fa fa-plus-circle\" aria-hidden=\"true\"></i> Manage Team Categories\n </button>\n </div>\n </div>\n\n <!-- Add Group Template -->\n <div *ngIf=\"isGroupOperations\"\n class=\"mb-4\">\n <h4 class=\"card-title d-inline\">{{ viewEdit ? 'Update the' : 'Create a new' }} team</h4>\n\n <div class=\"mt-4\"\n *ngIf=\"!isGroupEdit\">\n <form [formGroup]=\"form\"\n (ngSubmit)=\"saveGroup()\">\n <div class=\"row\">\n <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n <label>{{ 'Enterprise.Teams.TeamName' | transloco }}</label>\n <input type=\"text\"\n class=\"form-control\"\n formControlName=\"name\" />\n </div>\n <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n <label>{{ 'Enterprise.Teams.Description' | transloco }}</label>\n <input type=\"text\"\n class=\"form-control\"\n formControlName=\"description\" />\n </div>\n <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n <label>{{ 'Enterprise.Teams.TeamCategory' | transloco\n }}<span class=\"text-danger\">*</span>\n </label>\n <select class=\"form-select\"\n formControlName=\"group_definition_id\"\n [ngClass]=\"{\n 'is-invalid':\n submitted && form.controls['group_definition_id'].errors\n }\">\n <option *ngFor=\"let label of groupDefinition\"\n [value]=\"label.id\">\n {{ label.name }}\n </option>\n </select>\n </div>\n </div>\n\n <div class=\"row text-end mt-4\">\n <div class=\"col-12\">\n <button type=\"button\"\n (click)=\"isGroupOperations = !isGroupOperations\"\n class=\"btn btn-outline-default me-2\">\n {{ 'Button.Cancel' | transloco }}\n </button>\n <button type=\"submit\"\n class=\"btn btn-primary\">Add</button>\n </div>\n </div>\n </form>\n </div>\n\n <!-- Edit Group Template -->\n <div class=\"mt-4\"\n *ngIf=\"isGroupEdit\">\n <form [formGroup]=\"form\"\n (ngSubmit)=\"updateDetails()\">\n <div class=\"row\">\n <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n <label>{{ 'Enterprise.Teams.TeamName' | transloco }}</label>\n <input type=\"text\"\n class=\"form-control\"\n formControlName=\"name\"\n required=\"true\" />\n </div>\n <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n <label>{{ 'Enterprise.Teams.TeamDescription' | transloco }}</label>\n <input type=\"text\"\n value=\"{{ description }}\"\n class=\"form-control\"\n formControlName=\"description\"\n required=\"true\" />\n </div>\n <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n <label>{{ 'Enterprise.Teams.TeamCategory' | transloco\n }}<span class=\"text-danger\">*</span>\n </label>\n <select class=\"form-select\"\n formControlName=\"group_definition_id\"\n [ngClass]=\"{\n 'is-invalid':\n submitted && form.controls['group_definition_id'].errors\n }\">\n <option *ngFor=\"let label of groupDefinition\"\n [value]=\"label.id\">\n {{ label.name }}\n </option>\n </select>\n </div>\n </div>\n <div class=\"row text-end mt-4\">\n <div class=\"col-12\">\n <button type=\"button\"\n class=\"btn btn-outline-default me-2\"\n (click)=\"cancelUpdate()\">\n {{ 'Button.Cancel' | transloco }}\n </button>\n <button type=\"submit\"\n class=\"btn btn-primary\">\n {{ 'Button.Update' | transloco }}\n </button>\n </div>\n </div>\n </form>\n </div>\n </div>\n\n <div class=\"row\"\n *ngIf=\"!isGroupOperations\">\n <div class=\"col-4 mt-2 filter\">\n <select (change)=\"filterDomainsList($event)\"\n class=\"form-select\">\n <option value=\"0\">All Team Categories</option>\n <option *ngFor=\"let option of groupDefinition\"\n [value]=\"option.id\">\n {{ option.name }}\n </option>\n </select>\n </div>\n </div>\n <div class=\"w-100 text-center mt-3\"\n *ngIf=\"!isLoaded\">\n <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n </div>\n <div class=\"row group_list my-4\"\n *ngIf=\"!isGroupOperations\">\n <div class=\"col-12 col-md-6 col-xl-4 mt-3\"\n *ngFor=\"let group of allGroups; trackBy: trackByGroup\">\n <div class=\"card\">\n <div class=\"card-content\">\n <div class=\"card-header\">\n <h5 class=\"mb-3\">{{ group.name }}</h5>\n <p>{{ group.description | slice: 0:200 }}</p>\n <span><a class=\"badge bg-primary\">{{\n group?.group_definition_name\n }}</a></span>\n </div>\n <div class=\"card-footer\">\n <div class=\"float-end px-2\">\n <a class=\"me-2 my-1\"\n *ngIf=\"hasAccess\"\n (click)=\"onDelete(group.id)\">\n <i class=\"fa fa-trash delete-icon\" aria-hidden=\"true\"></i></a>\n <a class=\"me-2 my-1\"\n *ngIf=\"hasAccess\"\n (click)=\"editGroup(group.id)\"><i class=\"fa fa-edit edit-icon\" aria-hidden=\"true\"></i></a>\n <a class=\"me-2 my-1\"\n [routerLink]=\"[group.id, 'members']\"><i class=\"fa fa-tasks cta1-icon\" aria-hidden=\"true\"></i>\n </a>\n <a class=\"communications me-2 my-1\"\n (click)=\"navigateToCommunications(group.id)\"><i class=\"fa fa-comments cta2-icon\" aria-hidden=\"true\"></i></a>\n <a class=\"communications my-1\"\n (click)=\"navigateToDocumentations(group.id)\"><i class=\"fab fa-wikipedia-w cta1-icon\" aria-hidden=\"true\"></i></a>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </section>\n</div>\n<div *ngIf=\"allGroups?.length === 0 && hasAccess && !isGroupOperations && isLoaded\"\n class=\"clearboth\">\n <pw-no-data [message]=\"'Enterprise.Teams.NoTeamMessage' | transloco\"> </pw-no-data>\n</div>\n<div *ngIf=\"allGroups?.length === 0 && !hasAccess && !isGroupOperations && isLoaded\"\n class=\"clearboth\">\n <pw-no-data [message]=\"'Enterprise.Teams.NoTeamMessageIfUser' | transloco\"> </pw-no-data>\n</div>\n", styles: ["a.previous i{line-height:13px}.clearboth{clear:both}@media screen and (max-width: 480px){.filter{flex:none;max-width:100%!important}.communications{margin-top:2%}}\n"] }]
216
+ }], ctorParameters: function () { return [{ type: i1.UntypedFormBuilder }, { type: i2.GroupService }, { type: i2.SubscriptionService }, { type: i2.DataService }, { type: i0.Injector }]; }, propDecorators: { saveGroup: [] } });
217
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"groups.component.js","sourceRoot":"","sources":["../../../../../../../libs/shared-components/src/lib/label-management/groups/groups.component.ts","../../../../../../../libs/shared-components/src/lib/label-management/groups/groups.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, OnDestroy, OnInit } from '@angular/core';\nimport {\n    UntypedFormBuilder,\n    UntypedFormControl,\n    UntypedFormGroup,\n    Validators\n} from '@angular/forms';\nimport swal from 'sweetalert2';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { Subscription } from '@posiwise/common-utilities';\nimport { User } from '@posiwise/common-utilities';\nimport { DataService } from '@posiwise/common-services';\nimport { GroupService } from '@posiwise/common-services';\nimport { SubscriptionService } from '@posiwise/common-services';\nimport { ValidateForm } from '@posiwise/utils';\n\n@Component({\n    selector: 'pw-groups',\n    templateUrl: './groups.component.html',\n    styleUrls: ['./groups.component.scss']\n})\nexport class GroupsComponent extends AppBaseComponent implements OnInit, OnDestroy {\n    message: number;\n\n    submitted: boolean;\n\n    isGroupOperations: boolean;\n\n    isGroupEdit: boolean;\n\n    form: UntypedFormGroup;\n\n    allGroups: any = [];\n\n    id: number;\n\n    description: any;\n\n    name: any;\n\n    group_id: number;\n\n    hasAccess: boolean;\n\n    admins = [];\n\n    subscriptionInfo = [];\n\n    subscriptionOwner: any;\n\n    enrolledUsers: any;\n\n    user: User;\n\n    viewEdit = false;\n\n    groupDefinition: any = [];\n\n    private groupsData: any = [];\n\n    isLoaded = false;\n\n    subscription: Subscription;\n\n    constructor(\n        private fb: UntypedFormBuilder,\n        private groupService: GroupService,\n        private subscriptionService: SubscriptionService,\n        private dataService: DataService,\n        injector: Injector\n    ) {\n        super(injector);\n        this.getUserSubscription().subscribe(response => {\n            this.subscription = response;\n            if (this.subscription?.id) {\n                this.id = this.subscription?.id;\n            }\n        });\n\n        this.form = this.fb.group({\n            name: new UntypedFormControl('', [Validators.required]),\n            description: new UntypedFormControl(''),\n            group_definition_id: new UntypedFormControl('', [Validators.required])\n        });\n    }\n\n    ngOnInit() {\n        this.dataService.currentMessage.subscribe(message => {\n            this.message = message;\n        });\n        this.userStore().subscribe(user => {\n            if (user) {\n                this.user = user;\n                this.getSubscribedUsers();\n            }\n        });\n        this.getAllGroupDefinition();\n    }\n\n    /** Function to save group */\n    @ValidateForm('form')\n    saveGroup() {\n        this.submitted = true;\n        const formValue = this.form.value;\n        const data = {\n            name: formValue.name,\n            description: formValue.description,\n            group_definition_id: formValue.group_definition_id\n        };\n        this.groupService\n            .postGroup(data)\n            .subscribe(() => {\n                this.toast.success('Saved Successfully', '', {\n                    extendedTimeOut: 1000000\n                });\n                this.form.reset();\n                this.getAllGroupDefinition();\n                this.isGroupOperations = false;\n            })\n            .add(() => {\n                this.submitted = false;\n            });\n    }\n\n    private getAllGroupDefinition() {\n        this.allGroups = [];\n        this.groupService.groupDefinitionGetAll(this.id, 'Subscription').subscribe(response => {\n            this.isLoaded = true;\n            if (response.group_definitions.length > 0) {\n                this.groupDefinition = response.group_definitions;\n                this.groupDefinition.forEach(data => {\n                    const groups = [...data.groups];\n                    groups.forEach(group => {\n                        this.allGroups.push({ ...group, group_definition_name: data?.name });\n                        this.groupsData = this.allGroups;\n                    });\n                });\n            } else {\n                this.groupDefinition = [];\n            }\n        });\n    }\n\n    private getSubscribedUsers() {\n        this.getUserSubscription().subscribe(sub => {\n            this.subscription = sub;\n            if (this.subscription?.id) {\n                this.subscriptionService.getEnrolledSubscription(sub?.id).subscribe(response => {\n                    this.subscriptionOwner = response.owner_id;\n                    this.admins = response.admins;\n                    this.enrolledUsers = response.members;\n                    this.enrolledUsers.forEach(element => {\n                        element.is_owner = element?.id === this.user?.id;\n                    });\n                    this.hasAccess =\n                        this.admins.includes(this.user?.id) ||\n                        this.user?.id === this.subscriptionOwner ||\n                        this.permissionService.isSuperAdmin();\n                });\n            }\n        });\n    }\n\n    groupOperation() {\n        this.form.reset();\n        this.viewEdit = false;\n        this.isGroupOperations = true;\n        this.isGroupEdit = false;\n    }\n\n    cancelUpdate() {\n        this.isGroupOperations = false;\n        this.form.reset();\n    }\n\n    editGroup(group_id: number) {\n        this.form.reset();\n        this.viewEdit = true;\n        this.isGroupOperations = true;\n        this.isGroupEdit = true;\n        this.group_id = group_id;\n        this.getGroupDetails(group_id);\n    }\n\n    private getGroupDetails(id: number) {\n        this.groupService.getGroup(id).subscribe(response => {\n            this.form.patchValue({\n                name: response.name,\n                description: response.description,\n                group_definition_id: response.group_definition_id\n            });\n        });\n    }\n\n    updateDetails() {\n        const formValue = this.form.value;\n        const data = {\n            name: formValue.name,\n            description: formValue.description,\n            group_definition_id: formValue.group_definition_id\n        };\n        this.groupService.updateGroup(this.group_id, data).subscribe(() => {\n            this.toast.success(this.translation.translate('Admin.Shared.Groups.UpdatedMessage'));\n            this.form.reset();\n            this.getAllGroupDefinition();\n            this.isGroupOperations = false;\n        });\n    }\n\n    onDelete(id: number) {\n        swal.fire({\n            title: 'Delete',\n            text: `Are you sure you want to delete this team?`,\n            showCancelButton: true,\n            reverseButtons: true,\n            icon: 'warning'\n        }).then(rep => {\n            if (rep.value) {\n                this.groupService.deleteGroup(id).subscribe(_ => {\n                    this.toast.success(\n                        this.translation.translate('Admin.Shared.Groups.DeletedMessage')\n                    );\n                    this.isGroupOperations = false;\n                    this.getAllGroupDefinition();\n                });\n            }\n        });\n    }\n\n    filterDomainsList(event) {\n        if (event.target.value !== '0') {\n            const searchedList = this.groupsData.filter(\n                group => group.group_definition_id === Number(event.target.value)\n            );\n            this.allGroups = searchedList;\n        } else {\n            this.allGroups = this.groupsData;\n        }\n    }\n\n    previous() {\n        this.location.back();\n        this.dataService.changeMessage(1);\n    }\n\n    navigateToCommunications(id: number) {\n        this.router.navigate([`/${this.subscription?.slug}/enterprise/communications`], {\n            queryParams: { entity_id: id }\n        });\n    }\n\n    navigateToDocumentations(id: number) {\n        this.router.navigate([`/${this.subscription?.slug}/enterprise/wiki`], {\n            queryParams: { entity_id: id }\n        });\n    }\n\n    trackByGroup(_index: number, item: any) {\n        return item.id;\n    }\n\n    override ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","<div>\n  <section>\n    <div class=\"row\">\n      <div class=\"col-12 mb-3\">\n        <h2>Enterprise Teams</h2>\n\n        <p>\n          Here you can define the teams for your Enterprise members. For example\n          \"Corporate Sales Team\", \"Frontend Dev Team\" etc.\n          <br />\n          Once the teams created, you'll be able to add members to them and see useful\n          insight based on the members activity in the corresponding team.\n        </p>\n      </div>\n    </div>\n\n    <div class=\"row\"\n      *ngIf=\"!isGroupOperations\">\n      <div class=\"col-12 d-flex justify-content-end align-items-center text-end\">\n        <button *ngIf=\"hasAccess\"\n          class=\"btn btn-sm btn-outline-primary\"\n          (click)=\"groupOperation()\">\n          <i class=\"fa fa-plus-circle\" aria-hidden=\"true\"></i> Add Team\n        </button>\n        <button *ngIf=\"hasAccess\"\n          class=\"btn btn-sm btn-outline-primary ms-1\"\n          [routerLink]=\"['/' + subscription?.slug + '/enterprise', 'groups', 'labels']\">\n          <i class=\"fa fa-plus-circle\" aria-hidden=\"true\"></i> Manage Team Categories\n        </button>\n      </div>\n    </div>\n\n    <!-- Add Group Template -->\n    <div *ngIf=\"isGroupOperations\"\n      class=\"mb-4\">\n      <h4 class=\"card-title d-inline\">{{ viewEdit ? 'Update the' : 'Create a new' }} team</h4>\n\n      <div class=\"mt-4\"\n        *ngIf=\"!isGroupEdit\">\n        <form [formGroup]=\"form\"\n          (ngSubmit)=\"saveGroup()\">\n          <div class=\"row\">\n            <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n              <label>{{ 'Enterprise.Teams.TeamName' | transloco }}</label>\n              <input type=\"text\"\n                class=\"form-control\"\n                formControlName=\"name\" />\n            </div>\n            <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n              <label>{{ 'Enterprise.Teams.Description' | transloco }}</label>\n              <input type=\"text\"\n                class=\"form-control\"\n                formControlName=\"description\" />\n            </div>\n            <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n              <label>{{ 'Enterprise.Teams.TeamCategory' | transloco\n                                }}<span class=\"text-danger\">*</span>\n              </label>\n              <select class=\"form-select\"\n                formControlName=\"group_definition_id\"\n                [ngClass]=\"{\n                                    'is-invalid':\n                                        submitted && form.controls['group_definition_id'].errors\n                                }\">\n                <option *ngFor=\"let label of groupDefinition\"\n                  [value]=\"label.id\">\n                  {{ label.name }}\n                </option>\n              </select>\n            </div>\n          </div>\n\n          <div class=\"row text-end mt-4\">\n            <div class=\"col-12\">\n              <button type=\"button\"\n                (click)=\"isGroupOperations = !isGroupOperations\"\n                class=\"btn btn-outline-default me-2\">\n                {{ 'Button.Cancel' | transloco }}\n              </button>\n              <button type=\"submit\"\n                class=\"btn btn-primary\">Add</button>\n            </div>\n          </div>\n        </form>\n      </div>\n\n      <!-- Edit Group Template -->\n      <div class=\"mt-4\"\n        *ngIf=\"isGroupEdit\">\n        <form [formGroup]=\"form\"\n          (ngSubmit)=\"updateDetails()\">\n          <div class=\"row\">\n            <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n              <label>{{ 'Enterprise.Teams.TeamName' | transloco }}</label>\n              <input type=\"text\"\n                class=\"form-control\"\n                formControlName=\"name\"\n                required=\"true\" />\n            </div>\n            <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n              <label>{{ 'Enterprise.Teams.TeamDescription' | transloco }}</label>\n              <input type=\"text\"\n                value=\"{{ description }}\"\n                class=\"form-control\"\n                formControlName=\"description\"\n                required=\"true\" />\n            </div>\n            <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n              <label>{{ 'Enterprise.Teams.TeamCategory' | transloco\n                                }}<span class=\"text-danger\">*</span>\n              </label>\n              <select class=\"form-select\"\n                formControlName=\"group_definition_id\"\n                [ngClass]=\"{\n                                    'is-invalid':\n                                        submitted && form.controls['group_definition_id'].errors\n                                }\">\n                <option *ngFor=\"let label of groupDefinition\"\n                  [value]=\"label.id\">\n                  {{ label.name }}\n                </option>\n              </select>\n            </div>\n          </div>\n          <div class=\"row text-end mt-4\">\n            <div class=\"col-12\">\n              <button type=\"button\"\n                class=\"btn btn-outline-default me-2\"\n                (click)=\"cancelUpdate()\">\n                {{ 'Button.Cancel' | transloco }}\n              </button>\n              <button type=\"submit\"\n                class=\"btn btn-primary\">\n                {{ 'Button.Update' | transloco }}\n              </button>\n            </div>\n          </div>\n        </form>\n      </div>\n    </div>\n\n    <div class=\"row\"\n      *ngIf=\"!isGroupOperations\">\n      <div class=\"col-4 mt-2 filter\">\n        <select (change)=\"filterDomainsList($event)\"\n          class=\"form-select\">\n          <option value=\"0\">All Team Categories</option>\n          <option *ngFor=\"let option of groupDefinition\"\n            [value]=\"option.id\">\n            {{ option.name }}\n          </option>\n        </select>\n      </div>\n    </div>\n    <div class=\"w-100 text-center mt-3\"\n      *ngIf=\"!isLoaded\">\n      <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n    </div>\n    <div class=\"row group_list my-4\"\n      *ngIf=\"!isGroupOperations\">\n      <div class=\"col-12 col-md-6 col-xl-4 mt-3\"\n        *ngFor=\"let group of allGroups; trackBy: trackByGroup\">\n        <div class=\"card\">\n          <div class=\"card-content\">\n            <div class=\"card-header\">\n              <h5 class=\"mb-3\">{{ group.name }}</h5>\n              <p>{{ group.description | slice: 0:200 }}</p>\n              <span><a class=\"badge bg-primary\">{{\n                                    group?.group_definition_name\n                                }}</a></span>\n            </div>\n            <div class=\"card-footer\">\n              <div class=\"float-end px-2\">\n                <a class=\"me-2 my-1\"\n                  *ngIf=\"hasAccess\"\n                  (click)=\"onDelete(group.id)\">\n                  <i class=\"fa fa-trash delete-icon\" aria-hidden=\"true\"></i></a>\n                <a class=\"me-2 my-1\"\n                  *ngIf=\"hasAccess\"\n                  (click)=\"editGroup(group.id)\"><i class=\"fa fa-edit edit-icon\" aria-hidden=\"true\"></i></a>\n                <a class=\"me-2 my-1\"\n                  [routerLink]=\"[group.id, 'members']\"><i class=\"fa fa-tasks cta1-icon\" aria-hidden=\"true\"></i>\n                </a>\n                <a class=\"communications me-2 my-1\"\n                  (click)=\"navigateToCommunications(group.id)\"><i class=\"fa fa-comments cta2-icon\" aria-hidden=\"true\"></i></a>\n                <a class=\"communications my-1\"\n                  (click)=\"navigateToDocumentations(group.id)\"><i class=\"fab fa-wikipedia-w cta1-icon\" aria-hidden=\"true\"></i></a>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n  </section>\n</div>\n<div *ngIf=\"allGroups?.length === 0 && hasAccess && !isGroupOperations && isLoaded\"\n  class=\"clearboth\">\n  <pw-no-data [message]=\"'Enterprise.Teams.NoTeamMessage' | transloco\"> </pw-no-data>\n</div>\n<div *ngIf=\"allGroups?.length === 0 && !hasAccess && !isGroupOperations && isLoaded\"\n  class=\"clearboth\">\n  <pw-no-data [message]=\"'Enterprise.Teams.NoTeamMessageIfUser' | transloco\"> </pw-no-data>\n</div>\n"]}