@posiwise/shared-components 0.0.99 → 0.0.101
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/custom-uploader/custom-uploader.component.mjs +3 -2
- package/esm2022/lib/geo-template/geo-template.component.mjs +1 -1
- package/esm2022/lib/image-cropper/image-cropper.component.mjs +6 -3
- package/esm2022/lib/label-management/entity-group/entity-group.component.mjs +1 -1
- package/esm2022/lib/label-management/group-definition/group-definition.component.mjs +1 -1
- package/esm2022/lib/label-management/groups/groups.component.mjs +1 -1
- package/esm2022/lib/number-picker/number-picker.component.mjs +1 -1
- package/esm2022/lib/password-validation/password-validation.component.mjs +1 -1
- package/esm2022/lib/permission-tree/permission-tree.component.mjs +1 -1
- package/esm2022/lib/privacy-and-tos/privacy-and-tos.component.mjs +1 -1
- package/esm2022/lib/shared/shared-component.interface.mjs +2 -0
- package/esm2022/lib/terms-conditions/terms-conditions.component.mjs +8 -8
- package/fesm2022/posiwise-shared-components.mjs +14 -10
- package/fesm2022/posiwise-shared-components.mjs.map +1 -1
- package/lib/custom-uploader/custom-uploader.component.d.ts +4 -2
- package/lib/geo-template/geo-template.component.d.ts +1 -1
- package/lib/image-cropper/image-cropper.component.d.ts +5 -5
- package/lib/label-management/entity-group/entity-group.component.d.ts +7 -4
- package/lib/label-management/group-definition/group-definition.component.d.ts +4 -3
- package/lib/label-management/groups/groups.component.d.ts +16 -7
- package/lib/password-validation/password-validation.component.d.ts +2 -1
- package/lib/permission-tree/permission-tree.component.d.ts +2 -1
- package/lib/privacy-and-tos/privacy-and-tos.component.d.ts +6 -2
- package/lib/shared/shared-component.interface.d.ts +35 -0
- package/package.json +1 -1
|
@@ -76,7 +76,8 @@ export class CustomUploaderComponent extends AppBaseComponent {
|
|
|
76
76
|
}
|
|
77
77
|
onImgChange(event) {
|
|
78
78
|
if (event) {
|
|
79
|
-
|
|
79
|
+
const target = event.target;
|
|
80
|
+
target.src = 'assets/img/icons/imagenotavailable.png';
|
|
80
81
|
}
|
|
81
82
|
const el = this.document.querySelectorAll('pw-domain-config-interface,pw-domain-config-build div[matchheight="card"]');
|
|
82
83
|
el.forEach((item) => {
|
|
@@ -103,4 +104,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
103
104
|
}], title: [{
|
|
104
105
|
type: Input
|
|
105
106
|
}] } });
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-uploader.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/custom-uploader/custom-uploader.component.ts","../../../../../../libs/shared-components/src/lib/custom-uploader/custom-uploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport { Component, EventEmitter, Inject, Injector, Input, Output } from '@angular/core';\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { HelperService } from '@posiwise/helper-service';\n\n@Component({\n    selector: 'pw-custom-uploader',\n    templateUrl: './custom-uploader.component.html',\n    styleUrls: ['./custom-uploader.component.scss']\n})\nexport class CustomUploaderComponent extends AppBaseComponent {\n    @Output() saveEvent: EventEmitter<{ file: string; name: string }> = new EventEmitter<{\n        file: string;\n        name: string;\n    }>();\n\n    @Input() controlName: string;\n\n    @Input() previewData: any;\n\n    @Input() aspectRatio = 'auto';\n\n    @Input() title: string;\n\n    uploadedFile = null;\n\n    selectedFileName: string;\n\n    buttonBusy: boolean;\n\n    constructor(\n        injector: Injector,\n        private modalService: NgbModal,\n        @Inject(DOCUMENT) private document: Document\n    ) {\n        super(injector);\n    }\n\n    deleteExistingFile() {\n        HelperService.raiseDeletePopup().then(rep => {\n            if (rep.value) {\n                this.previewData = null;\n                this.onSaveFile();\n            }\n        });\n    }\n\n    onSaveFile() {\n        this.buttonBusy = true;\n        this.saveEvent.emit({\n            file: this.previewData?.url ? this.previewData : this.uploadedFile,\n            name: this.controlName\n        });\n    }\n\n    // modal image cropper\n\n    onFileChange(value) {\n        this.selectedFileName = value;\n    }\n\n    private dataURLtoBlob(dataUrl: string) {\n        const arr = dataUrl?.split(',');\n        // eslint-disable-next-line @typescript-eslint/prefer-regexp-exec\n        const mime = arr[0].match(/^[A-Z]*[a-z]*:(.*?);[A-Z]*/)[1];\n        const bStr = atob(arr[1]);\n        let n = bStr.length;\n        const u8arr = new Uint8Array(n);\n        // eslint-disable-next-line no-plusplus\n        while (n--) {\n            u8arr[n] = bStr.charCodeAt(n);\n        }\n\n        return new Blob([u8arr], { type: mime });\n    }\n\n    onImageSelection(event) {\n        const blob = this.dataURLtoBlob(event);\n        const file: File = new File([blob], this.selectedFileName);\n        this.uploadedFile = file;\n        this.onSaveFile();\n    }\n\n    openModal(content) {\n        this.modalService.open(content, { centered: true, windowClass: 'modal-holder' });\n    }\n\n    clearValues() {\n        this.uploadedFile = null;\n        this.selectedFileName = null;\n        this.updateHeight();\n    }\n\n    onClose() {\n        this.modalService.dismissAll();\n    }\n\n    updateHeight() {\n        // wait for update card height\n        setTimeout(() => {\n            this.onImgChange();\n        });\n    }\n\n    onImgChange(event?: any) {\n        if (event) {\n            event.target.src = 'assets/img/icons/imagenotavailable.png';\n        }\n        const el = this.document.querySelectorAll(\n            'pw-domain-config-interface,pw-domain-config-build div[matchheight=\"card\"]'\n        );\n        el.forEach((item: Element) => {\n            HelperService.matchHeights(item as HTMLElement, 'card');\n        });\n    }\n}\n","<div class=\"card pb-2\">\n  <div class=\"card-header upload-button-bar\">\n    <button pButton\n      type=\"button\"\n      [disabled]=\"previewData?.url || uploadedFile\"\n      (click)=\"openModal(content)\"\n      icon=\"pi pi-plus\"\n      label=\"Choose\"></button>\n  </div>\n  <div class=\"card-body\">\n    <!-- no files -->\n    <div class=\"d-flex preview-wrapper\"\n      *ngIf=\"!previewData?.url\">\n      <div>\n        <img src=\"assets/img/icons/nofilesfound.png\"\n          (load)=\"onImgChange()\"\n          class=\"mx-auto img-fluid\"\n          alt=\"\" />\n      </div>\n    </div>\n    <!-- exising images -->\n    <div class=\"d-flex preview-wrapper\"\n      *ngIf=\"previewData?.url\">\n      <div>\n        <a [href]=\"previewData?.url\"\n          target=\"_blank\">\n          <img [src]=\"previewData?.url\"\n            alt=\"\"\n            (load)=\"onImgChange()\"\n            (error)=\"onImgChange($event)\"\n            class=\"img-fluid\" />\n        </a>\n      </div>\n      <div class=\"ms-3\">\n        <i\n                    container=\"body\"\n                    ngbTooltip=\"Delete\"\n                    (click)=\"deleteExistingFile()\"\n                    class=\"fa fa-trash delete-icon\"\n                    aria-hidden=\"true\"\n                ></i>\n      </div>\n    </div>\n  </div>\n</div>\n<!-- image cropper -->\n<ng-template #content\n  let-modal>\n  <div class=\"card m-0\">\n    <div class=\"card-content\">\n      <div class=\"card-title\">\n        <h3 class=\"modal-title\">{{ title }}</h3>\n        <button type=\"button\"\n          class=\"btn-close float-end float-end\"\n          aria-label=\"Close\"\n          (click)=\"modal.dismiss()\">\n\n        </button>\n      </div>\n      <div class=\"card-header\">\n        <small> {{ 'User.Profile.PictureMessage' | transloco }}</small>\n        <pw-image-cropper #profile\n          [aspectRatio]=\"aspectRatio\"\n          (fileChangeEvent)=\"onFileChange($event)\"\n          (imageSelectionEvent)=\"onImageSelection($event)\"\n          (closeEvent)=\"onClose()\">\n        </pw-image-cropper>\n      </div>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
107
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-uploader.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/custom-uploader/custom-uploader.component.ts","../../../../../../libs/shared-components/src/lib/custom-uploader/custom-uploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport { Component, EventEmitter, Inject, Injector, Input, Output } from '@angular/core';\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { HelperService } from '@posiwise/helper-service';\n\n@Component({\n    selector: 'pw-custom-uploader',\n    templateUrl: './custom-uploader.component.html',\n    styleUrls: ['./custom-uploader.component.scss']\n})\nexport class CustomUploaderComponent extends AppBaseComponent {\n    @Output() saveEvent: EventEmitter<{ file: string; name: string }> = new EventEmitter<{\n        file: string;\n        name: string;\n    }>();\n\n    @Input() controlName: string;\n\n    @Input() previewData: { url: string };\n\n    @Input() aspectRatio = 'auto';\n\n    @Input() title: string;\n\n    uploadedFile = null;\n\n    selectedFileName: string;\n\n    buttonBusy: boolean;\n\n    constructor(\n        injector: Injector,\n        private modalService: NgbModal,\n        @Inject(DOCUMENT) private document: Document\n    ) {\n        super(injector);\n    }\n\n    deleteExistingFile() {\n        HelperService.raiseDeletePopup().then(rep => {\n            if (rep.value) {\n                this.previewData = null;\n                this.onSaveFile();\n            }\n        });\n    }\n\n    onSaveFile() {\n        this.buttonBusy = true;\n        this.saveEvent.emit({\n            file: this.previewData?.url ? this.previewData : this.uploadedFile,\n            name: this.controlName\n        });\n    }\n\n    // modal image cropper\n\n    onFileChange(value) {\n        this.selectedFileName = value;\n    }\n\n    private dataURLtoBlob(dataUrl: string) {\n        const arr = dataUrl?.split(',');\n        // eslint-disable-next-line @typescript-eslint/prefer-regexp-exec\n        const mime = arr[0].match(/^[A-Z]*[a-z]*:(.*?);[A-Z]*/)[1];\n        const bStr = atob(arr[1]);\n        let n = bStr.length;\n        const u8arr = new Uint8Array(n);\n        // eslint-disable-next-line no-plusplus\n        while (n--) {\n            u8arr[n] = bStr.charCodeAt(n);\n        }\n\n        return new Blob([u8arr], { type: mime });\n    }\n\n    onImageSelection(event) {\n        const blob = this.dataURLtoBlob(event);\n        const file: File = new File([blob], this.selectedFileName);\n        this.uploadedFile = file;\n        this.onSaveFile();\n    }\n\n    openModal(content) {\n        this.modalService.open(content, { centered: true, windowClass: 'modal-holder' });\n    }\n\n    clearValues() {\n        this.uploadedFile = null;\n        this.selectedFileName = null;\n        this.updateHeight();\n    }\n\n    onClose() {\n        this.modalService.dismissAll();\n    }\n\n    updateHeight() {\n        // wait for update card height\n        setTimeout(() => {\n            this.onImgChange();\n        });\n    }\n\n    onImgChange(event?: Event) {\n        if (event) {\n            const target = event.target as HTMLImageElement;\n            target.src = 'assets/img/icons/imagenotavailable.png';\n        }\n        const el = this.document.querySelectorAll(\n            'pw-domain-config-interface,pw-domain-config-build div[matchheight=\"card\"]'\n        );\n        el.forEach((item: Element) => {\n            HelperService.matchHeights(item as HTMLElement, 'card');\n        });\n    }\n}\n","<div class=\"card pb-2\">\n  <div class=\"card-header upload-button-bar\">\n    <button pButton\n      type=\"button\"\n      [disabled]=\"previewData?.url || uploadedFile\"\n      (click)=\"openModal(content)\"\n      icon=\"pi pi-plus\"\n      label=\"Choose\"></button>\n  </div>\n  <div class=\"card-body\">\n    <!-- no files -->\n    <div class=\"d-flex preview-wrapper\"\n      *ngIf=\"!previewData?.url\">\n      <div>\n        <img src=\"assets/img/icons/nofilesfound.png\"\n          (load)=\"onImgChange()\"\n          class=\"mx-auto img-fluid\"\n          alt=\"\" />\n      </div>\n    </div>\n    <!-- exising images -->\n    <div class=\"d-flex preview-wrapper\"\n      *ngIf=\"previewData?.url\">\n      <div>\n        <a [href]=\"previewData?.url\"\n          target=\"_blank\">\n          <img [src]=\"previewData?.url\"\n            alt=\"\"\n            (load)=\"onImgChange()\"\n            (error)=\"onImgChange($event)\"\n            class=\"img-fluid\" />\n        </a>\n      </div>\n      <div class=\"ms-3\">\n        <i\n                    container=\"body\"\n                    ngbTooltip=\"Delete\"\n                    (click)=\"deleteExistingFile()\"\n                    class=\"fa fa-trash delete-icon\"\n                    aria-hidden=\"true\"\n                ></i>\n      </div>\n    </div>\n  </div>\n</div>\n<!-- image cropper -->\n<ng-template #content\n  let-modal>\n  <div class=\"card m-0\">\n    <div class=\"card-content\">\n      <div class=\"card-title\">\n        <h3 class=\"modal-title\">{{ title }}</h3>\n        <button type=\"button\"\n          class=\"btn-close float-end float-end\"\n          aria-label=\"Close\"\n          (click)=\"modal.dismiss()\">\n\n        </button>\n      </div>\n      <div class=\"card-header\">\n        <small> {{ 'User.Profile.PictureMessage' | transloco }}</small>\n        <pw-image-cropper #profile\n          [aspectRatio]=\"aspectRatio\"\n          (fileChangeEvent)=\"onFileChange($event)\"\n          (imageSelectionEvent)=\"onImageSelection($event)\"\n          (closeEvent)=\"onClose()\">\n        </pw-image-cropper>\n      </div>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
@@ -21,4 +21,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
21
21
|
type: Component,
|
|
22
22
|
args: [{ selector: 'pw-geo-template', template: "<ng-content></ng-content>\n" }]
|
|
23
23
|
}], ctorParameters: () => [{ type: i1.GeoService }] });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VvLXRlbXBsYXRlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2hhcmVkLWNvbXBvbmVudHMvc3JjL2xpYi9nZW8tdGVtcGxhdGUvZ2VvLXRlbXBsYXRlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2hhcmVkLWNvbXBvbmVudHMvc3JjL2xpYi9nZW8tdGVtcGxhdGUvZ2VvLXRlbXBsYXRlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFFbEQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLDJCQUEyQixDQUFDOzs7QUFNdkQsTUFBTSxPQUFPLG9CQUFvQjtJQUc3QixZQUFvQixVQUFzQjtRQUF0QixlQUFVLEdBQVYsVUFBVSxDQUFZO0lBQUcsQ0FBQztJQUU5QyxRQUFRO1FBQ0osSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFFTyxjQUFjO1FBQ2xCLElBQUksQ0FBQyxVQUFVLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLEVBQUU7WUFDcEQsSUFBSSxDQUFDLElBQUksR0FBRyxRQUFRLENBQUM7UUFDekIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDOytHQWJRLG9CQUFvQjttR0FBcEIsb0JBQW9CLHVEQ1JqQyw2QkFDQTs7NEZET2Esb0JBQW9CO2tCQUpoQyxTQUFTOytCQUNJLGlCQUFpQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEdlb1NlcnZpY2UgfSBmcm9tICdAcG9zaXdpc2UvY29tbW9uLXNlcnZpY2VzJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdwdy1nZW8tdGVtcGxhdGUnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9nZW8tdGVtcGxhdGUuY29tcG9uZW50Lmh0bWwnXG59KVxuZXhwb3J0IGNsYXNzIEdlb1RlbXBsYXRlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBkYXRhOiBvYmplY3Q7XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGdlb1NlcnZpY2U6IEdlb1NlcnZpY2UpIHt9XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5nZXRDb3VudHJ5QnlJUCgpO1xuICAgIH1cblxuICAgIHByaXZhdGUgZ2V0Q291bnRyeUJ5SVAoKSB7XG4gICAgICAgIHRoaXMuZ2VvU2VydmljZS5nZXRDb3VudHJ5RnJvbUlQKCkuc3Vic2NyaWJlKHJlc3BvbnNlID0+IHtcbiAgICAgICAgICAgIHRoaXMuZGF0YSA9IHJlc3BvbnNlO1xuICAgICAgICB9KTtcbiAgICB9XG59XG4iLCI8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4iXX0=
|
|
@@ -17,8 +17,11 @@ export class ProfileImageCropperComponent {
|
|
|
17
17
|
this.showCropper = false;
|
|
18
18
|
}
|
|
19
19
|
onFileChange(event) {
|
|
20
|
-
|
|
21
|
-
|
|
20
|
+
const input = event.target;
|
|
21
|
+
if (input.files && input.files.length > 0) {
|
|
22
|
+
this.imageChangedEvent = event;
|
|
23
|
+
this.fileChangeEvent.emit(input.files[0].name);
|
|
24
|
+
}
|
|
22
25
|
}
|
|
23
26
|
imageCropped(event) {
|
|
24
27
|
const reader = new FileReader();
|
|
@@ -84,4 +87,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
84
87
|
}], aspectRatio: [{
|
|
85
88
|
type: Input
|
|
86
89
|
}] } });
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-cropper.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/image-cropper/image-cropper.component.ts","../../../../../../libs/shared-components/src/lib/image-cropper/image-cropper.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;AAQ1F,MAAM,OAAO,4BAA4B;IAqBrC,YAAoB,GAAsB;QAAtB,QAAG,GAAH,GAAG,CAAmB;QApB1C,sBAAiB,GAAG,EAAE,CAAC;QAEvB,iBAAY,GAAG,EAAE,CAAC;QAER,wBAAmB,GAAsB,IAAI,YAAY,EAAO,CAAC;QAEjE,eAAU,GAAsB,IAAI,YAAY,EAAO,CAAC;QAExD,oBAAe,GAAsB,IAAI,YAAY,EAAO,CAAC;QAI9D,gBAAW,GAAG,MAAM,CAAC;QAE9B,cAAS,GAAmB,EAAE,CAAC;QAE/B,mBAAc,GAAG,CAAC,CAAC;QAEnB,gBAAW,GAAG,KAAK,CAAC;IAEyB,CAAC;IAE9C,YAAY,CAAC,KAAU;QACnB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;IAC3D,CAAC;IAED,YAAY,CAAC,KAAwB;QACjC,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;QAChC,MAAM,CAAC,SAAS,GAAG,GAAG,EAAE;YACpB,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,MAAgB,CAAC;YAC5C,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC7B,CAAC,CAAC;QACF,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACrC,CAAC;IAED,WAAW;QACP,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC5B,CAAC;IAED,UAAU;QACN,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAED,WAAW;QACP,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAEO,eAAe;QACnB,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;QACtC,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;QACtC,IAAI,CAAC,SAAS,GAAG;YACb,GAAG,IAAI,CAAC,SAAS;YACjB,KAAK,EAAE,QAAQ;YACf,KAAK,EAAE,QAAQ;SAClB,CAAC;IACN,CAAC;IAED,cAAc;QACV,IAAI,CAAC,SAAS,GAAG;YACb,GAAG,IAAI,CAAC,SAAS;YACjB,KAAK,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK;SAC/B,CAAC;IACN,CAAC;IAED,YAAY;QACR,IAAI,CAAC,SAAS,GAAG;YACb,GAAG,IAAI,CAAC,SAAS;YACjB,KAAK,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK;SAC/B,CAAC;IACN,CAAC;IAED,kBAAkB;QACd,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACjD,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACrB,CAAC;IACL,CAAC;IAED,YAAY;QACR,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IAC3B,CAAC;+GApFQ,4BAA4B;mGAA5B,4BAA4B,uNCRzC,6xJA+HA;;4FDvHa,4BAA4B;kBALxC,SAAS;+BACI,kBAAkB;sFASlB,mBAAmB;sBAA5B,MAAM;gBAEG,UAAU;sBAAnB,MAAM;gBAEG,eAAe;sBAAxB,MAAM;gBAIE,WAAW;sBAAnB,KAAK","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, Output } from '@angular/core';\nimport { ImageCroppedEvent, ImageTransform } from 'ngx-image-cropper';\n\n@Component({\n    selector: 'pw-image-cropper',\n    templateUrl: './image-cropper.component.html',\n    styleUrls: ['./image-cropper.component.scss']\n})\nexport class ProfileImageCropperComponent {\n    imageChangedEvent = '';\n\n    croppedImage = '';\n\n    @Output() imageSelectionEvent: EventEmitter<any> = new EventEmitter<any>();\n\n    @Output() closeEvent: EventEmitter<any> = new EventEmitter<any>();\n\n    @Output() fileChangeEvent: EventEmitter<any> = new EventEmitter<any>();\n\n    busy: boolean;\n\n    @Input() aspectRatio = 'auto';\n\n    transform: ImageTransform = {};\n\n    canvasRotation = 0;\n\n    showCropper = false;\n\n    constructor(private cdr: ChangeDetectorRef) {}\n\n    onFileChange(event: any): void {\n        this.imageChangedEvent = event;\n        this.fileChangeEvent.emit(event.target.files[0]?.name);\n    }\n\n    imageCropped(event: ImageCroppedEvent) {\n        const reader = new FileReader();\n        reader.onloadend = () => {\n            this.croppedImage = reader.result as string;\n            this.cdr.detectChanges();\n        };\n        reader.readAsDataURL(event.blob);\n    }\n\n    imageLoaded() {\n        this.showCropper = true;\n    }\n\n    rotateLeft() {\n        this.canvasRotation--;\n        this.flipAfterRotate();\n    }\n\n    rotateRight() {\n        this.canvasRotation++;\n        this.flipAfterRotate();\n    }\n\n    private flipAfterRotate() {\n        const flippedH = this.transform.flipH;\n        const flippedV = this.transform.flipV;\n        this.transform = {\n            ...this.transform,\n            flipH: flippedV,\n            flipV: flippedH\n        };\n    }\n\n    flipHorizontal() {\n        this.transform = {\n            ...this.transform,\n            flipH: !this.transform.flipH\n        };\n    }\n\n    flipVertical() {\n        this.transform = {\n            ...this.transform,\n            flipV: !this.transform.flipV\n        };\n    }\n\n    saveProfilePicture() {\n        if (this.croppedImage) {\n            this.imageSelectionEvent.emit(this.croppedImage);\n            this.busy = true;\n        }\n    }\n\n    onCloseModal() {\n        this.closeEvent.emit();\n    }\n}\n","<section class=\"image-cropper\">\n  <div class=\"row text-start\">\n    <div class=\"col-12\">\n      <div class=\"card-block pb-0\">\n        <div class=\"row\">\n          <div class=\"col-12\">\n            <div class=\"file-upload my-2 float-start\">\n              <label>\n                Upload Pic\n                <input id=\"custom-input\"\n                  type=\"file\"\n                  (change)=\"onFileChange($event)\" />\n              </label>\n            </div>\n\n            <div class=\"float-end m-2\">\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Rotate Left\">\n                <i\n                                    class=\"fa fa-undo-alt\"\n                                    (click)=\"rotateLeft()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Rotate Right\">\n                <i\n                                    class=\"fa fa-redo-alt\"\n                                    (click)=\"rotateRight()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Flip Horizontal\">\n                <i\n                                    class=\"fa fa-arrows-alt-h\"\n                                    (click)=\"flipHorizontal()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Flip Vertical\">\n                <i\n                                    class=\"fa fa-arrows-alt-v\"\n                                    (click)=\"flipVertical()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n            </div>\n          </div>\n        </div>\n\n        <div class=\"row\">\n          <div class=\"col-8\">\n            <div *ngIf=\"aspectRatio === 'auto'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [canvasRotation]=\"canvasRotation\"\n                [aspectRatio]=\"4 / 4\"\n                [onlyScaleDown]=\"true\"\n                [transform]=\"transform\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n\n            <div *ngIf=\"aspectRatio === 'fullLogo'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [aspectRatio]=\"5 / 1.1\"\n                [onlyScaleDown]=\"true\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n\n            <div *ngIf=\"aspectRatio === 'custom'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [canvasRotation]=\"canvasRotation\"\n                [transform]=\"transform\"\n                [aspectRatio]=\"4 / 3\"\n                [onlyScaleDown]=\"true\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n          </div>\n          <div *ngIf=\"croppedImage\" class=\"col-4 mt-2\">\n            <img [src]=\"croppedImage\"\n              alt=\"cropped.png\"\n              width=\"128\" />\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n  <div class=\"card-footer px-3\">\n    <div class=\"float-end mt-2\">\n      <button type=\"button\"\n        class=\"btn btn-outline-default me-2\"\n        (click)=\"onCloseModal()\">\n        Close\n      </button>\n      <button type=\"button\"\n        class=\"btn btn-primary\"\n        (click)=\"saveProfilePicture()\"\n        [buttonBusy]=\"busy\">\n        Save\n      </button>\n    </div>\n  </div>\n</section>\n"]}
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-cropper.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/image-cropper/image-cropper.component.ts","../../../../../../libs/shared-components/src/lib/image-cropper/image-cropper.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, Output } from '@angular/core';\nimport { ImageCroppedEvent, ImageTransform } from 'ngx-image-cropper';\n\n@Component({\n    selector: 'pw-image-cropper',\n    templateUrl: './image-cropper.component.html',\n    styleUrls: ['./image-cropper.component.scss']\n})\nexport class ProfileImageCropperComponent {\n    imageChangedEvent: Event | string = '';\n\n    croppedImage = '';\n\n    @Output() imageSelectionEvent: EventEmitter<string> = new EventEmitter<string>();\n    @Output() closeEvent: EventEmitter<void> = new EventEmitter<void>();\n    @Output() fileChangeEvent: EventEmitter<string> = new EventEmitter<string>();\n\n    busy: boolean;\n\n    @Input() aspectRatio = 'auto';\n\n    transform: ImageTransform = {};\n\n    canvasRotation = 0;\n\n    showCropper = false;\n\n    constructor(private cdr: ChangeDetectorRef) {}\n\n    onFileChange(event: Event): void {\n        const input = event.target as HTMLInputElement;\n        if (input.files && input.files.length > 0) {\n            this.imageChangedEvent = event;\n            this.fileChangeEvent.emit(input.files[0].name);\n        }\n    }\n\n    imageCropped(event: ImageCroppedEvent) {\n        const reader = new FileReader();\n        reader.onloadend = () => {\n            this.croppedImage = reader.result as string;\n            this.cdr.detectChanges();\n        };\n        reader.readAsDataURL(event.blob);\n    }\n\n    imageLoaded() {\n        this.showCropper = true;\n    }\n\n    rotateLeft() {\n        this.canvasRotation--;\n        this.flipAfterRotate();\n    }\n\n    rotateRight() {\n        this.canvasRotation++;\n        this.flipAfterRotate();\n    }\n\n    private flipAfterRotate() {\n        const flippedH = this.transform.flipH;\n        const flippedV = this.transform.flipV;\n        this.transform = {\n            ...this.transform,\n            flipH: flippedV,\n            flipV: flippedH\n        };\n    }\n\n    flipHorizontal() {\n        this.transform = {\n            ...this.transform,\n            flipH: !this.transform.flipH\n        };\n    }\n\n    flipVertical() {\n        this.transform = {\n            ...this.transform,\n            flipV: !this.transform.flipV\n        };\n    }\n\n    saveProfilePicture() {\n        if (this.croppedImage) {\n            this.imageSelectionEvent.emit(this.croppedImage);\n            this.busy = true;\n        }\n    }\n\n    onCloseModal() {\n        this.closeEvent.emit();\n    }\n}\n","<section class=\"image-cropper\">\n  <div class=\"row text-start\">\n    <div class=\"col-12\">\n      <div class=\"card-block pb-0\">\n        <div class=\"row\">\n          <div class=\"col-12\">\n            <div class=\"file-upload my-2 float-start\">\n              <label>\n                Upload Pic\n                <input id=\"custom-input\"\n                  type=\"file\"\n                  (change)=\"onFileChange($event)\" />\n              </label>\n            </div>\n\n            <div class=\"float-end m-2\">\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Rotate Left\">\n                <i\n                                    class=\"fa fa-undo-alt\"\n                                    (click)=\"rotateLeft()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Rotate Right\">\n                <i\n                                    class=\"fa fa-redo-alt\"\n                                    (click)=\"rotateRight()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Flip Horizontal\">\n                <i\n                                    class=\"fa fa-arrows-alt-h\"\n                                    (click)=\"flipHorizontal()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Flip Vertical\">\n                <i\n                                    class=\"fa fa-arrows-alt-v\"\n                                    (click)=\"flipVertical()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n            </div>\n          </div>\n        </div>\n\n        <div class=\"row\">\n          <div class=\"col-8\">\n            <div *ngIf=\"aspectRatio === 'auto'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [canvasRotation]=\"canvasRotation\"\n                [aspectRatio]=\"4 / 4\"\n                [onlyScaleDown]=\"true\"\n                [transform]=\"transform\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n\n            <div *ngIf=\"aspectRatio === 'fullLogo'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [aspectRatio]=\"5 / 1.1\"\n                [onlyScaleDown]=\"true\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n\n            <div *ngIf=\"aspectRatio === 'custom'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [canvasRotation]=\"canvasRotation\"\n                [transform]=\"transform\"\n                [aspectRatio]=\"4 / 3\"\n                [onlyScaleDown]=\"true\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n          </div>\n          <div *ngIf=\"croppedImage\" class=\"col-4 mt-2\">\n            <img [src]=\"croppedImage\"\n              alt=\"cropped.png\"\n              width=\"128\" />\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n  <div class=\"card-footer px-3\">\n    <div class=\"float-end mt-2\">\n      <button type=\"button\"\n        class=\"btn btn-outline-default me-2\"\n        (click)=\"onCloseModal()\">\n        Close\n      </button>\n      <button type=\"button\"\n        class=\"btn btn-primary\"\n        (click)=\"saveProfilePicture()\"\n        [buttonBusy]=\"busy\">\n        Save\n      </button>\n    </div>\n  </div>\n</section>\n"]}
|
|
@@ -153,4 +153,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
153
153
|
type: ViewChild,
|
|
154
154
|
args: ['content', { static: true }]
|
|
155
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":"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","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      [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 [withImage]=\"true\" 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"]}
|
|
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":"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","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';\nimport { EnrolledUser, SharedModalContext } from '../../shared/shared-component.interface';\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<SharedModalContext>;\n\n    entityId: number;\n\n    selectedGroup: { name: string };\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: number;\n\n    enrolledUsers: EnrolledUser[];\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: { displayName: string }) => {\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      [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 [withImage]=\"true\" 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"]}
|
|
@@ -163,4 +163,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
163
163
|
type: Component,
|
|
164
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 [withImage]=\"true\" [message]=\"'Enterprise.Teams.NoLabelsMessage' | transloco\"> </pw-no-data>\n </div>\n <div *ngIf=\"groupDefinition?.length === 0 && !hasAccess && isLoaded\">\n <pw-no-data [withImage]=\"true\" [message]=\"'Enterprise.Teams.NoLabelsUserMessage' | transloco\"> </pw-no-data>\n </div>\n</section>\n", styles: [".mb-last-3{margin-bottom:3rem}\n"] }]
|
|
165
165
|
}], ctorParameters: () => [{ 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 [withImage]=\"true\" [message]=\"'Enterprise.Teams.NoLabelsMessage' | transloco\"> </pw-no-data>\n  </div>\n  <div *ngIf=\"groupDefinition?.length === 0 && !hasAccess && isLoaded\">\n    <pw-no-data [withImage]=\"true\" [message]=\"'Enterprise.Teams.NoLabelsUserMessage' | transloco\"> </pw-no-data>\n  </div>\n</section>\n"]}
|
|
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';\nimport { EnrolledUser, GroupDefination } from '../../shared/shared-component.interface';\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: object[];\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: GroupDefination;\n\n    hasAccess: boolean;\n\n    admins = [];\n\n    subscriptionInfo = [];\n\n    subscriptionOwner: number;\n\n    enrolledUsers: EnrolledUser[];\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 [withImage]=\"true\" [message]=\"'Enterprise.Teams.NoLabelsMessage' | transloco\"> </pw-no-data>\n  </div>\n  <div *ngIf=\"groupDefinition?.length === 0 && !hasAccess && isLoaded\">\n    <pw-no-data [withImage]=\"true\" [message]=\"'Enterprise.Teams.NoLabelsUserMessage' | transloco\"> </pw-no-data>\n  </div>\n</section>\n"]}
|
|
@@ -215,4 +215,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
215
215
|
type: Component,
|
|
216
216
|
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 [withImage]=\"true\" [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 [withImage]=\"true\" [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"] }]
|
|
217
217
|
}], ctorParameters: () => [{ type: i1.UntypedFormBuilder }, { type: i2.GroupService }, { type: i2.SubscriptionService }, { type: i2.DataService }, { type: i0.Injector }], propDecorators: { saveGroup: [] } });
|
|
218
|
-
//# 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.isLoaded = false;\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 [withImage]=\"true\" [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 [withImage]=\"true\" [message]=\"'Enterprise.Teams.NoTeamMessageIfUser' | transloco\"> </pw-no-data>\n</div>\n"]}
|
|
218
|
+
//# 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';\nimport { Group } from '../../shared/shared-component.interface';\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: Group[] = [];\n\n    id: number;\n\n    description: string;\n\n    name: string;\n\n    group_id: number;\n\n    hasAccess: boolean;\n\n    admins = [];\n\n    subscriptionInfo = [];\n\n    subscriptionOwner: number;\n\n    enrolledUsers: { is_owner: boolean; id: number }[];\n\n    user: User;\n\n    viewEdit = false;\n\n    groupDefinition: {\n        name: string;\n        groups: IterableIterator<object>;\n    }[] = [];\n\n    private groupsData: Group[] = [];\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.isLoaded = false;\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: { id: number }) {\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 [withImage]=\"true\" [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 [withImage]=\"true\" [message]=\"'Enterprise.Teams.NoTeamMessageIfUser' | transloco\"> </pw-no-data>\n</div>\n"]}
|