@posiwise/shared-components 0.0.31 → 0.0.33

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
@@ -20,4 +20,6 @@ export * from './lib/coming-soon/coming-soon.component';
20
20
  export * from './lib/no-data/no-data.component';
21
21
  export * from './lib/label-management/entity-group/entity-group.component';
22
22
  export * from './lib/label-management/groups/groups.component';
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL3NoYXJlZC1jb21wb25lbnRzL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsNkRBQTZELENBQUM7QUFDNUUsY0FBYyx1REFBdUQsQ0FBQztBQUN0RSxjQUFjLHlEQUF5RCxDQUFDO0FBQ3hFLGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLHlEQUF5RCxDQUFDO0FBQ3hFLGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw0REFBNEQsQ0FBQztBQUMzRSxjQUFjLGdEQUFnRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvc2hhcmVkLWNvbXBvbmVudHMubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FiLXRlc3QvYWItdGVzdC1jb250YWluZXIvYWItdGVzdC1jb250YWluZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FiLXRlc3QvYWItYWx0ZXJuYXRpdmUvYWItYWx0ZXJuYXRpdmUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Bhc3N3b3JkLXZhbGlkYXRpb24vcGFzc3dvcmQtdmFsaWRhdGlvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY3VzdG9tLXVwbG9hZGVyL2N1c3RvbS11cGxvYWRlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaW1hZ2UtY3JvcHBlci9pbWFnZS1jcm9wcGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdy10YWJzL3B3LXRhYnMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Blcm1pc3Npb24tdHJlZS9wZXJtaXNzaW9uLXRyZWUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2lucHV0LWNvbnRhaW5lci9pbnB1dC1jb250YWluZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ZpZWxkLWVycm9yLWRpc3BsYXkvZmllbGQtZXJyb3ItZGlzcGxheS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHJpdmFjeS1hbmQtdG9zL3ByaXZhY3ktYW5kLXRvcy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHJpdmFjeS1wb2xpY3kvcHJpdmFjeS1wb2xpY3kuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NwbGFzaC9zcGxhc2guY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Rlcm1zLWNvbmRpdGlvbnMvdGVybXMtY29uZGl0aW9ucy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXBwLWxvYWRlci9hcHAtbG9hZGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9nZW8tdGVtcGxhdGUvZ2VvLXRlbXBsYXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hdXRoZXRpY2F0b3IvYXV0aGV0aWNhdG9yLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jbGVhcmJpdC1pY29uL2NsZWFyYml0LWljb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbWluZy1zb29uL2NvbWluZy1zb29uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9uby1kYXRhL25vLWRhdGEuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xhYmVsLW1hbmFnZW1lbnQvZW50aXR5LWdyb3VwL2VudGl0eS1ncm91cC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbGFiZWwtbWFuYWdlbWVudC9ncm91cHMvZ3JvdXBzLmNvbXBvbmVudCc7XG4iXX0=
23
+ export * from './lib/label-management/group-definition/group-definition.component';
24
+ export * from './lib/number-picker/number-picker.component';
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL3NoYXJlZC1jb21wb25lbnRzL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsNkRBQTZELENBQUM7QUFDNUUsY0FBYyx1REFBdUQsQ0FBQztBQUN0RSxjQUFjLHlEQUF5RCxDQUFDO0FBQ3hFLGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLHlEQUF5RCxDQUFDO0FBQ3hFLGNBQWMsaURBQWlELENBQUM7QUFDaEUsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyw2Q0FBNkMsQ0FBQztBQUM1RCxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw0REFBNEQsQ0FBQztBQUMzRSxjQUFjLGdEQUFnRCxDQUFDO0FBQy9ELGNBQWMsb0VBQW9FLENBQUM7QUFDbkYsY0FBYyw2Q0FBNkMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL3NoYXJlZC1jb21wb25lbnRzLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hYi10ZXN0L2FiLXRlc3QtY29udGFpbmVyL2FiLXRlc3QtY29udGFpbmVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9hYi10ZXN0L2FiLWFsdGVybmF0aXZlL2FiLWFsdGVybmF0aXZlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wYXNzd29yZC12YWxpZGF0aW9uL3Bhc3N3b3JkLXZhbGlkYXRpb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2N1c3RvbS11cGxvYWRlci9jdXN0b20tdXBsb2FkZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ltYWdlLWNyb3BwZXIvaW1hZ2UtY3JvcHBlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHctdGFicy9wdy10YWJzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wZXJtaXNzaW9uLXRyZWUvcGVybWlzc2lvbi10cmVlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9pbnB1dC1jb250YWluZXIvaW5wdXQtY29udGFpbmVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9maWVsZC1lcnJvci1kaXNwbGF5L2ZpZWxkLWVycm9yLWRpc3BsYXkuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ByaXZhY3ktYW5kLXRvcy9wcml2YWN5LWFuZC10b3MuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ByaXZhY3ktcG9saWN5L3ByaXZhY3ktcG9saWN5LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zcGxhc2gvc3BsYXNoLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90ZXJtcy1jb25kaXRpb25zL3Rlcm1zLWNvbmRpdGlvbnMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FwcC1sb2FkZXIvYXBwLWxvYWRlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZ2VvLXRlbXBsYXRlL2dlby10ZW1wbGF0ZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYXV0aGV0aWNhdG9yL2F1dGhldGljYXRvci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2xlYXJiaXQtaWNvbi9jbGVhcmJpdC1pY29uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21pbmctc29vbi9jb21pbmctc29vbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbm8tZGF0YS9uby1kYXRhLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9sYWJlbC1tYW5hZ2VtZW50L2VudGl0eS1ncm91cC9lbnRpdHktZ3JvdXAuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2xhYmVsLW1hbmFnZW1lbnQvZ3JvdXBzL2dyb3Vwcy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvbGFiZWwtbWFuYWdlbWVudC9ncm91cC1kZWZpbml0aW9uL2dyb3VwLWRlZmluaXRpb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL251bWJlci1waWNrZXIvbnVtYmVyLXBpY2tlci5jb21wb25lbnQnO1xuIl19
@@ -0,0 +1,166 @@
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 { TAG_ENTITY } from '@posiwise/common-utilities';
6
+ import { AppBaseComponent } from '@posiwise/app-base-component';
7
+ import { DataService } from '@posiwise/common-services';
8
+ import { GroupService } from '@posiwise/common-services';
9
+ import { SubscriptionService } from '@posiwise/common-services';
10
+ import { ValidateForm } from '@posiwise/utils';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "@posiwise/common-services";
13
+ import * as i2 from "@angular/forms";
14
+ import * as i3 from "primeng/progressspinner";
15
+ import * as i4 from "@angular/common";
16
+ import * as i5 from "ngx-ui-switch";
17
+ import * as i6 from "../../no-data/no-data.component";
18
+ import * as i7 from "@ngneat/transloco";
19
+ export class GroupDefinitionComponent extends AppBaseComponent {
20
+ constructor(groupservice, fb, subscriptionService, data, injector) {
21
+ super(injector);
22
+ this.groupservice = groupservice;
23
+ this.fb = fb;
24
+ this.subscriptionService = subscriptionService;
25
+ this.data = data;
26
+ this.subscriptions = [];
27
+ this.admins = [];
28
+ this.subscriptionInfo = [];
29
+ this.isLoaded = false;
30
+ this.form = this.fb.group({
31
+ name: new UntypedFormControl('', [Validators.required]),
32
+ description: new UntypedFormControl(''),
33
+ is_private: [true]
34
+ });
35
+ }
36
+ ngOnInit() {
37
+ this.getUserSubscriptionId().subscribe(id => {
38
+ this.id = id;
39
+ });
40
+ this.getAllGroupDefinition();
41
+ this.getSubscribedUsers();
42
+ this.userStore().subscribe(user => {
43
+ this.user = user;
44
+ });
45
+ this.data.currentMessage.subscribe(message => {
46
+ this.message = message;
47
+ });
48
+ }
49
+ getAllGroupDefinition() {
50
+ this.groupservice
51
+ .groupDefinitionGetAll(this.id, 'Subscription')
52
+ .subscribe(response => {
53
+ if (response.group_definitions.length > 0) {
54
+ this.groupDefinition = response.group_definitions;
55
+ }
56
+ else {
57
+ this.groupDefinition = [];
58
+ }
59
+ })
60
+ .add(() => {
61
+ this.isLoaded = true;
62
+ });
63
+ }
64
+ getSubscribedUsers() {
65
+ this.subscriptionService.getEnrolledSubscription(this.id).subscribe(response => {
66
+ this.subscriptionOwner = response.owner_id;
67
+ this.admins = response.admins;
68
+ this.enrolledUsers = response.members;
69
+ this.enrolledUsers.forEach(element => {
70
+ element.is_owner = element?.id === this.user?.id;
71
+ });
72
+ this.hasAccess =
73
+ this.admins.includes(this.user?.id) ||
74
+ this.user?.id === this.subscriptionOwner ||
75
+ this.permissionService.isSuperAdmin();
76
+ });
77
+ }
78
+ updateDetails() {
79
+ const formValue = this.form.value;
80
+ const data = {
81
+ name: formValue.name,
82
+ description: formValue.description,
83
+ is_private: formValue.is_private
84
+ };
85
+ this.groupservice.groupDefinitionsUpdate(this.groupDefId, data).subscribe(() => {
86
+ this.toast.success(this.translation.translate('Admin.Shared.Definition.UpdatedMessage'));
87
+ this.form.reset();
88
+ this.viewDefinition = false;
89
+ this.getAllGroupDefinition();
90
+ });
91
+ }
92
+ onGroupDefinitionEdit(id) {
93
+ this.viewEdit = true;
94
+ this.viewDefinition = true;
95
+ this.groupDefId = id;
96
+ this.getSubscriptionDetails();
97
+ }
98
+ getSubscriptionDetails() {
99
+ this.groupservice.getGroupDefinitionById(this.groupDefId).subscribe(response => {
100
+ this.groupDefinitionDetails = response;
101
+ this.form.patchValue({
102
+ description: this.groupDefinitionDetails.description,
103
+ name: this.groupDefinitionDetails.name
104
+ });
105
+ });
106
+ }
107
+ saveGroupDefinition() {
108
+ const data = {
109
+ name: this.form.value.name,
110
+ description: this.form.value.description,
111
+ related_entity_id: this.id,
112
+ related_entity_type: TAG_ENTITY.SUBSCRIPTION,
113
+ is_private: this.form.value.is_private
114
+ };
115
+ this.groupservice.groupDefinitions(data).subscribe(() => {
116
+ this.toast.success(this.translation.translate('Admin.Shared.Definition.AddedMessage'));
117
+ this.form.reset();
118
+ this.getAllGroupDefinition();
119
+ this.viewDefinition = false;
120
+ });
121
+ }
122
+ onDelete(id) {
123
+ swal.fire({
124
+ title: 'Delete',
125
+ text: 'Are you sure you want to delete this label?',
126
+ showCancelButton: true,
127
+ reverseButtons: true,
128
+ icon: 'warning'
129
+ }).then(rep => {
130
+ if (rep.value) {
131
+ this.groupservice.groupDefinitionsDelete(id).subscribe(_ => {
132
+ this.toast.success(this.translation.translate('Admin.Shared.Definition.DeletedMessage'));
133
+ this.getAllGroupDefinition();
134
+ });
135
+ }
136
+ });
137
+ }
138
+ viewDefinitions() {
139
+ this.viewDefinition = true;
140
+ this.viewEdit = false;
141
+ }
142
+ previous() {
143
+ this.location.back();
144
+ this.data.changeMessage(1);
145
+ }
146
+ onCancel() {
147
+ this.form.reset();
148
+ this.viewDefinition = !this.viewDefinition;
149
+ }
150
+ ngOnDestroy() {
151
+ super.ngOnDestroy();
152
+ }
153
+ }
154
+ GroupDefinitionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: GroupDefinitionComponent, deps: [{ token: i1.GroupService }, { token: i2.UntypedFormBuilder }, { token: i1.SubscriptionService }, { token: i1.DataService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
155
+ GroupDefinitionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: GroupDefinitionComponent, selector: "pw-groupdefinition", usesInheritance: true, ngImport: i0, template: "<section>\n <div class=\"row\">\n <div class=\"col-12 mb-3\">\n <h2>Enterprise Teams Categories</h2>\n\n <p>\n Here you can define the categories for your enterprise's groups. For example \"Sales\n Department\", \"Development Department\", etc.\n <br />\n Once the category created, you'll be able to add teams 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=\"!viewDefinition\">\n <div class=\"col-6 d-flex align-items-center text-start mb-sm-3 mb-lg-0\">\n <a href=\"javascript:void(0)\"\n (click)=\"previous()\"\n class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n </div>\n <div class=\"col-6\"\n *ngIf=\"hasAccess\">\n <button class=\"float-end btn btn-sm btn-outline-primary me-2\"\n (click)=\"viewDefinitions()\">\n <i class=\"fa fa-plus-circle\" aria-hidden=\"true\"></i> Create new Team Category\n </button>\n </div>\n </div>\n\n <div *ngIf=\"viewDefinition\">\n <h4 class=\"card-title d-inline mb-5\">\n {{ viewEdit ? 'Update the' : 'Create a new' }} category\n </h4>\n\n <div class=\"mt-4\"\n *ngIf=\"!viewEdit\">\n <form [formGroup]=\"form\"\n (ngSubmit)=\"saveGroupDefinition()\">\n <div class=\"row\">\n <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n <label>{{ 'Label.Name' | 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.IsPrivate' | transloco }}</label>\n <div class=\"display-block\">\n <ui-switch size=\"small\"\n checkedLabel=\"True\"\n uncheckedLabel=\"false\"\n formControlName=\"is_private\">\n </ui-switch>\n </div>\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)=\"onCancel()\">\n {{ 'Button.Cancel' | transloco }}\n </button>\n <button type=\"submit\"\n class=\"btn btn-primary\">Add Category</button>\n </div>\n </div>\n </form>\n </div>\n\n <div class=\"mt-4\"\n *ngIf=\"viewEdit\">\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>{{ 'Label.Name' | 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.IsPrivate' | transloco }}</label>\n <div class=\"display-block\">\n <ui-switch size=\"small\"\n checkedLabel=\"True\"\n uncheckedLabel=\"false\"\n formControlName=\"is_private\">\n </ui-switch>\n </div>\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)=\"onCancel()\">\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=\"w-100 text-center mt-3\"\n *ngIf=\"!isLoaded\">\n <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n </div>\n\n <ng-container *ngIf=\"groupDefinition?.length !== 0\">\n <div class=\"row mb-last-3 group-definitions-wrapper\"\n *ngIf=\"!viewDefinition\">\n <div class=\"col-12 col-md-6 col-xl-4 mt-3\"\n *ngFor=\"let group of groupDefinition\">\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 </div>\n <div class=\"card-footer\">\n <div class=\"float-end px-2\">\n <a class=\"btn btn-sm btn-outline-danger me-2\"\n *ngIf=\"hasAccess\"\n (click)=\"onDelete(group.id)\">{{ 'Button.Delete' | transloco }}</a>\n <a class=\"btn btn-sm btn-outline-primary me-2\"\n *ngIf=\"hasAccess\"\n (click)=\"onGroupDefinitionEdit(group.id)\">{{ 'Button.Edit' | transloco }}</a>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n <div *ngIf=\"groupDefinition?.length === 0 && hasAccess && !viewDefinition && isLoaded\">\n <pw-no-data [message]=\"'Enterprise.Teams.NoLabelsMessage' | transloco\"> </pw-no-data>\n </div>\n <div *ngIf=\"groupDefinition?.length === 0 && !hasAccess && isLoaded\">\n <pw-no-data [message]=\"'Enterprise.Teams.NoLabelsUserMessage' | transloco\"> </pw-no-data>\n </div>\n</section>\n", styles: [".mb-last-3{margin-bottom:3rem}\n"], dependencies: [{ kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i3.ProgressSpinner, selector: "p-progressSpinner", inputs: ["style", "styleClass", "strokeWidth", "fill", "animationDuration"] }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.UiSwitchComponent, selector: "ui-switch", inputs: ["size", "color", "switchOffColor", "switchColor", "defaultBgColor", "defaultBoColor", "checkedLabel", "uncheckedLabel", "checkedTextColor", "uncheckedTextColor", "beforeChange", "checked", "disabled", "reverse", "loading"], outputs: ["change", "changeEvent", "valueChange"] }, { kind: "component", type: i6.NoDataComponent, selector: "pw-no-data", inputs: ["message"] }, { kind: "pipe", type: i7.TranslocoPipe, name: "transloco" }, { kind: "pipe", type: i4.SlicePipe, name: "slice" }] });
156
+ __decorate([
157
+ ValidateForm('form'),
158
+ __metadata("design:type", Function),
159
+ __metadata("design:paramtypes", []),
160
+ __metadata("design:returntype", void 0)
161
+ ], GroupDefinitionComponent.prototype, "saveGroupDefinition", null);
162
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: GroupDefinitionComponent, decorators: [{
163
+ type: Component,
164
+ args: [{ selector: 'pw-groupdefinition', template: "<section>\n <div class=\"row\">\n <div class=\"col-12 mb-3\">\n <h2>Enterprise Teams Categories</h2>\n\n <p>\n Here you can define the categories for your enterprise's groups. For example \"Sales\n Department\", \"Development Department\", etc.\n <br />\n Once the category created, you'll be able to add teams 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=\"!viewDefinition\">\n <div class=\"col-6 d-flex align-items-center text-start mb-sm-3 mb-lg-0\">\n <a href=\"javascript:void(0)\"\n (click)=\"previous()\"\n class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n </div>\n <div class=\"col-6\"\n *ngIf=\"hasAccess\">\n <button class=\"float-end btn btn-sm btn-outline-primary me-2\"\n (click)=\"viewDefinitions()\">\n <i class=\"fa fa-plus-circle\" aria-hidden=\"true\"></i> Create new Team Category\n </button>\n </div>\n </div>\n\n <div *ngIf=\"viewDefinition\">\n <h4 class=\"card-title d-inline mb-5\">\n {{ viewEdit ? 'Update the' : 'Create a new' }} category\n </h4>\n\n <div class=\"mt-4\"\n *ngIf=\"!viewEdit\">\n <form [formGroup]=\"form\"\n (ngSubmit)=\"saveGroupDefinition()\">\n <div class=\"row\">\n <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n <label>{{ 'Label.Name' | 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.IsPrivate' | transloco }}</label>\n <div class=\"display-block\">\n <ui-switch size=\"small\"\n checkedLabel=\"True\"\n uncheckedLabel=\"false\"\n formControlName=\"is_private\">\n </ui-switch>\n </div>\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)=\"onCancel()\">\n {{ 'Button.Cancel' | transloco }}\n </button>\n <button type=\"submit\"\n class=\"btn btn-primary\">Add Category</button>\n </div>\n </div>\n </form>\n </div>\n\n <div class=\"mt-4\"\n *ngIf=\"viewEdit\">\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>{{ 'Label.Name' | 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.IsPrivate' | transloco }}</label>\n <div class=\"display-block\">\n <ui-switch size=\"small\"\n checkedLabel=\"True\"\n uncheckedLabel=\"false\"\n formControlName=\"is_private\">\n </ui-switch>\n </div>\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)=\"onCancel()\">\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=\"w-100 text-center mt-3\"\n *ngIf=\"!isLoaded\">\n <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n </div>\n\n <ng-container *ngIf=\"groupDefinition?.length !== 0\">\n <div class=\"row mb-last-3 group-definitions-wrapper\"\n *ngIf=\"!viewDefinition\">\n <div class=\"col-12 col-md-6 col-xl-4 mt-3\"\n *ngFor=\"let group of groupDefinition\">\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 </div>\n <div class=\"card-footer\">\n <div class=\"float-end px-2\">\n <a class=\"btn btn-sm btn-outline-danger me-2\"\n *ngIf=\"hasAccess\"\n (click)=\"onDelete(group.id)\">{{ 'Button.Delete' | transloco }}</a>\n <a class=\"btn btn-sm btn-outline-primary me-2\"\n *ngIf=\"hasAccess\"\n (click)=\"onGroupDefinitionEdit(group.id)\">{{ 'Button.Edit' | transloco }}</a>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n </ng-container>\n <div *ngIf=\"groupDefinition?.length === 0 && hasAccess && !viewDefinition && isLoaded\">\n <pw-no-data [message]=\"'Enterprise.Teams.NoLabelsMessage' | transloco\"> </pw-no-data>\n </div>\n <div *ngIf=\"groupDefinition?.length === 0 && !hasAccess && isLoaded\">\n <pw-no-data [message]=\"'Enterprise.Teams.NoLabelsUserMessage' | transloco\"> </pw-no-data>\n </div>\n</section>\n", styles: [".mb-last-3{margin-bottom:3rem}\n"] }]
165
+ }], ctorParameters: function () { return [{ type: i1.GroupService }, { type: i2.UntypedFormBuilder }, { type: i1.SubscriptionService }, { type: i1.DataService }, { type: i0.Injector }]; }, propDecorators: { saveGroupDefinition: [] } });
166
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-definition.component.js","sourceRoot":"","sources":["../../../../../../../libs/shared-components/src/lib/label-management/group-definition/group-definition.component.ts","../../../../../../../libs/shared-components/src/lib/label-management/group-definition/group-definition.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 { TAG_ENTITY } from '@posiwise/common-utilities';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\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-groupdefinition',\n    templateUrl: './group-definition.component.html',\n    styleUrls: ['./group-definition.component.scss']\n})\nexport class GroupDefinitionComponent extends AppBaseComponent implements OnInit, OnDestroy {\n    subscriptions = [];\n\n    message: number;\n\n    groupDefinition: any[];\n\n    form: UntypedFormGroup;\n\n    id: number;\n\n    viewDefinition: boolean;\n\n    viewEdit: boolean;\n\n    private groupDefId: number;\n\n    private groupDefinitionDetails: any;\n\n    hasAccess: boolean;\n\n    admins = [];\n\n    subscriptionInfo = [];\n\n    subscriptionOwner: any;\n\n    enrolledUsers: any;\n\n    user: User;\n\n    isLoaded = false;\n\n    constructor(\n        private groupservice: GroupService,\n        private fb: UntypedFormBuilder,\n        private subscriptionService: SubscriptionService,\n        private data: DataService,\n        injector: Injector\n    ) {\n        super(injector);\n        this.form = this.fb.group({\n            name: new UntypedFormControl('', [Validators.required]),\n            description: new UntypedFormControl(''),\n            is_private: [true]\n        });\n    }\n\n    ngOnInit() {\n        this.getUserSubscriptionId().subscribe(id => {\n            this.id = id;\n        });\n        this.getAllGroupDefinition();\n        this.getSubscribedUsers();\n        this.userStore().subscribe(user => {\n            this.user = user;\n        });\n        this.data.currentMessage.subscribe(message => {\n            this.message = message;\n        });\n    }\n\n    private getAllGroupDefinition() {\n        this.groupservice\n            .groupDefinitionGetAll(this.id, 'Subscription')\n            .subscribe(response => {\n                if (response.group_definitions.length > 0) {\n                    this.groupDefinition = response.group_definitions;\n                } else {\n                    this.groupDefinition = [];\n                }\n            })\n            .add(() => {\n                this.isLoaded = true;\n            });\n    }\n\n    private getSubscribedUsers() {\n        this.subscriptionService.getEnrolledSubscription(this.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    updateDetails() {\n        const formValue = this.form.value;\n        const data = {\n            name: formValue.name,\n            description: formValue.description,\n            is_private: formValue.is_private\n        };\n        this.groupservice.groupDefinitionsUpdate(this.groupDefId, data).subscribe(() => {\n            this.toast.success(\n                this.translation.translate('Admin.Shared.Definition.UpdatedMessage')\n            );\n\n            this.form.reset();\n            this.viewDefinition = false;\n            this.getAllGroupDefinition();\n        });\n    }\n\n    onGroupDefinitionEdit(id: number) {\n        this.viewEdit = true;\n        this.viewDefinition = true;\n        this.groupDefId = id;\n        this.getSubscriptionDetails();\n    }\n\n    getSubscriptionDetails() {\n        this.groupservice.getGroupDefinitionById(this.groupDefId).subscribe(response => {\n            this.groupDefinitionDetails = response;\n            this.form.patchValue({\n                description: this.groupDefinitionDetails.description,\n                name: this.groupDefinitionDetails.name\n            });\n        });\n    }\n\n    @ValidateForm('form')\n    saveGroupDefinition() {\n        const data = {\n            name: this.form.value.name,\n            description: this.form.value.description,\n            related_entity_id: this.id,\n            related_entity_type: TAG_ENTITY.SUBSCRIPTION,\n            is_private: this.form.value.is_private\n        };\n        this.groupservice.groupDefinitions(data).subscribe(() => {\n            this.toast.success(this.translation.translate('Admin.Shared.Definition.AddedMessage'));\n            this.form.reset();\n            this.getAllGroupDefinition();\n            this.viewDefinition = false;\n        });\n    }\n\n    onDelete(id: number) {\n        swal.fire({\n            title: 'Delete',\n            text: 'Are you sure you want to delete this label?',\n            showCancelButton: true,\n            reverseButtons: true,\n            icon: 'warning'\n        }).then(rep => {\n            if (rep.value) {\n                this.groupservice.groupDefinitionsDelete(id).subscribe(_ => {\n                    this.toast.success(\n                        this.translation.translate('Admin.Shared.Definition.DeletedMessage')\n                    );\n                    this.getAllGroupDefinition();\n                });\n            }\n        });\n    }\n\n    viewDefinitions() {\n        this.viewDefinition = true;\n        this.viewEdit = false;\n    }\n\n    previous() {\n        this.location.back();\n        this.data.changeMessage(1);\n    }\n\n    onCancel() {\n        this.form.reset();\n        this.viewDefinition = !this.viewDefinition;\n    }\n\n    override ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","<section>\n  <div class=\"row\">\n    <div class=\"col-12 mb-3\">\n      <h2>Enterprise Teams Categories</h2>\n\n      <p>\n        Here you can define the categories for your enterprise's groups. For example \"Sales\n        Department\", \"Development Department\", etc.\n        <br />\n        Once the category created, you'll be able to add teams 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=\"!viewDefinition\">\n    <div class=\"col-6 d-flex align-items-center text-start mb-sm-3 mb-lg-0\">\n      <a href=\"javascript:void(0)\"\n        (click)=\"previous()\"\n        class=\"previous\"><i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n    </div>\n    <div class=\"col-6\"\n      *ngIf=\"hasAccess\">\n      <button class=\"float-end btn btn-sm btn-outline-primary me-2\"\n        (click)=\"viewDefinitions()\">\n        <i class=\"fa fa-plus-circle\" aria-hidden=\"true\"></i> Create new Team Category\n      </button>\n    </div>\n  </div>\n\n  <div *ngIf=\"viewDefinition\">\n    <h4 class=\"card-title d-inline mb-5\">\n      {{ viewEdit ? 'Update the' : 'Create a new' }} category\n    </h4>\n\n    <div class=\"mt-4\"\n      *ngIf=\"!viewEdit\">\n      <form [formGroup]=\"form\"\n        (ngSubmit)=\"saveGroupDefinition()\">\n        <div class=\"row\">\n          <div class=\"mb-3 col-xs-12 col-sm-6 col-md-3\">\n            <label>{{ 'Label.Name' | 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.IsPrivate' | transloco }}</label>\n            <div class=\"display-block\">\n              <ui-switch size=\"small\"\n                checkedLabel=\"True\"\n                uncheckedLabel=\"false\"\n                formControlName=\"is_private\">\n              </ui-switch>\n            </div>\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)=\"onCancel()\">\n              {{ 'Button.Cancel' | transloco }}\n            </button>\n            <button type=\"submit\"\n              class=\"btn btn-primary\">Add Category</button>\n          </div>\n        </div>\n      </form>\n    </div>\n\n    <div class=\"mt-4\"\n      *ngIf=\"viewEdit\">\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>{{ 'Label.Name' | 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.IsPrivate' | transloco }}</label>\n            <div class=\"display-block\">\n              <ui-switch size=\"small\"\n                checkedLabel=\"True\"\n                uncheckedLabel=\"false\"\n                formControlName=\"is_private\">\n              </ui-switch>\n            </div>\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)=\"onCancel()\">\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=\"w-100 text-center mt-3\"\n    *ngIf=\"!isLoaded\">\n    <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n  </div>\n\n  <ng-container *ngIf=\"groupDefinition?.length !== 0\">\n    <div class=\"row mb-last-3 group-definitions-wrapper\"\n      *ngIf=\"!viewDefinition\">\n      <div class=\"col-12 col-md-6 col-xl-4 mt-3\"\n        *ngFor=\"let group of groupDefinition\">\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            </div>\n            <div class=\"card-footer\">\n              <div class=\"float-end px-2\">\n                <a class=\"btn btn-sm btn-outline-danger me-2\"\n                  *ngIf=\"hasAccess\"\n                  (click)=\"onDelete(group.id)\">{{ 'Button.Delete' | transloco }}</a>\n                <a class=\"btn btn-sm btn-outline-primary me-2\"\n                  *ngIf=\"hasAccess\"\n                  (click)=\"onGroupDefinitionEdit(group.id)\">{{ 'Button.Edit' | transloco }}</a>\n              </div>\n            </div>\n          </div>\n        </div>\n      </div>\n    </div>\n  </ng-container>\n  <div *ngIf=\"groupDefinition?.length === 0 && hasAccess && !viewDefinition && isLoaded\">\n    <pw-no-data [message]=\"'Enterprise.Teams.NoLabelsMessage' | transloco\"> </pw-no-data>\n  </div>\n  <div *ngIf=\"groupDefinition?.length === 0 && !hasAccess && isLoaded\">\n    <pw-no-data [message]=\"'Enterprise.Teams.NoLabelsUserMessage' | transloco\"> </pw-no-data>\n  </div>\n</section>\n"]}