@posiwise/admin-module 0.0.135 → 0.0.137

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.
@@ -5,6 +5,7 @@ import { AppBaseComponent } from '@posiwise/app-base-component';
5
5
  import { CommonService, PermissionService, ProductService } from '@posiwise/common-services';
6
6
  import { ROUTERS } from '../../../shared/routers/routers';
7
7
  import { groupBy } from 'lodash';
8
+ import { QuillHelper } from '@posiwise/utils';
8
9
  import { HelperService } from '@posiwise/helper-service';
9
10
  import * as i0 from "@angular/core";
10
11
  import * as i1 from "@posiwise/common-services";
@@ -49,8 +50,8 @@ export class AddFaqComponent extends AppBaseComponent {
49
50
  this.categoryForBadges = [];
50
51
  this.faqHashMap = {};
51
52
  this.page = 1;
52
- // QuillHelper.init();
53
- // this.editorConfig = QuillHelper.getEditorConfig();
53
+ QuillHelper.init();
54
+ this.editorConfig = QuillHelper.getEditorConfig();
54
55
  this.form = AppAdmin.getFaqForm();
55
56
  }
56
57
  ngOnInit() {
@@ -215,4 +216,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
215
216
  type: ViewChild,
216
217
  args: ['editForm', { static: false }]
217
218
  }] } });
218
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-faq.component.js","sourceRoot":"","sources":["../../../../../../../../libs/admin-module/src/lib/components/faqs/add-faq/add-faq.component.ts","../../../../../../../../libs/admin-module/src/lib/components/faqs/add-faq/add-faq.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, Injector, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { NgForm, UntypedFormGroup } from '@angular/forms';\nimport { AdminService, AppAdmin } from '@posiwise/admin-module-utils';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { CommonService, PermissionService, ProductService } from '@posiwise/common-services';\nimport { ROUTERS } from '../../../shared/routers/routers';\nimport { FAQ, Product } from '@posiwise/common-utilities';\nimport { groupBy } from 'lodash';\nimport { ProductList } from '../../../shared/interface/admin-module-shared.interface';\nimport { QuillHelper } from '@posiwise/utils';\nimport { HelperService } from '@posiwise/helper-service';\n\n@Component({\n    selector: 'pw-admin-add-edit-incident',\n    templateUrl: './add-faq.component.html',\n    styleUrls: ['./add-faq.component.scss']\n})\nexport class AddFaqComponent extends AppBaseComponent implements OnInit, OnDestroy, AfterViewInit {\n    form: UntypedFormGroup;\n    routers = ROUTERS;\n    faqs: FAQ[] = [];\n    editorConfig;\n    faqList: FAQ[] = [];\n    id: number;\n\n    backUpFAQ: FAQ[] = [];\n\n    submitted = false;\n\n    isLoaded = true;\n\n    @ViewChild('editForm', { static: false }) editForm: NgForm;\n    isEdit = false;\n\n    categories = [];\n\n    isProductEnabled = true;\n\n    productList: ProductList[] = [];\n\n    searchText = '';\n\n    allProducts: Product[] = [];\n\n    allFaqs = [];\n\n    showList = true;\n\n    showFilters = true;\n\n    defaultValue = null;\n\n    totalRecordsUnFiltered = 0;\n\n    totalRecords = 0;\n\n    subscriptionId: number;\n\n    featureKeysList = [];\n\n    selectedFeatureKeys = [];\n\n    buttonBusy = false;\n\n    categoryForBadges = [];\n\n    slug: string;\n\n    faqHashMap = {};\n    page = 1;\n\n    constructor(\n        private commonService: CommonService,\n        private adminService: AdminService,\n        private productService: ProductService,\n        injector: Injector\n    ) {\n        super(injector);\n        // QuillHelper.init();\n        // this.editorConfig = QuillHelper.getEditorConfig();\n        this.form = AppAdmin.getFaqForm();\n    }\n    ngOnInit() {\n        this.slug = PermissionService.selectedSubscription?.slug;\n        this.subscriptionId = PermissionService.selectedSubscription?.id;\n        this.getCategories();\n        this.getFaqs();\n    }\n    ngAfterViewInit() {\n        HelperService.subscribeToEditorChanges(this.form, 'answer');\n    }\n\n    get f() {\n        return this.form.controls;\n    }\n    private getFaqs() {\n        this.isLoaded = false;\n        this.categories = [];\n        this.faqHashMap = {};\n        const params = {\n            subscription_id: this.subscriptionId,\n            feature_key: this.selectedFeatureKeys.join(',') || ''\n        };\n        this.commonService.getFaq({ ...params }).subscribe(response => {\n            this.isLoaded = true;\n            this.faqs = response.faqs;\n            this.allFaqs = response.faqs;\n            this.totalRecords = response.object_count;\n            this.totalRecordsUnFiltered = response.unfiltered_count;\n            this.faqs = this.faqs.map(x => {\n                x.isEdit = false;\n\n                return x;\n            });\n\n            this.backUpFAQ = [...this.faqs];\n            response?.available_category?.forEach(x => {\n                this.faqHashMap[x.key] = x;\n            });\n            this.categoryForBadges = response.available_category.map(x => x.key);\n            this.categories = response.available_category.map(element => {\n                return { label: element.name || '', value: element.key };\n            });\n\n            this.allFaqs = this.faqs;\n            this.faqList = this.faqs;\n        });\n    }\n\n    onSubmit() {\n        this.form.markAllAsTouched();\n        if (this.form.valid) {\n            this.submitted = true;\n            this.buttonBusy = true;\n            this.addNew();\n        }\n    }\n\n    addNew() {\n        const rawHtml = HelperService.SaveRawHTML();\n        this.form.controls['answer'].setValue(rawHtml);\n        this.buttonBusy = true;\n        this.adminService\n            .postFaq(this.form.value, this.subscriptionId)\n            .subscribe(() => {\n                this.toast.success(this.translation.translate('Admin.Faq.AddMessage'));\n                this.router.navigate([`${this.routers.faqConfig}`]);\n            })\n            .add(() => (this.buttonBusy = false));\n    }\n\n    private getCategories() {\n        this.productService\n            .getProducts({\n                subscription_id: this.subscriptionId\n            })\n            .subscribe(resp => {\n                if (resp.products) {\n                    this.allProducts = resp.products;\n                    this.productList = this.groupProducts(resp.products);\n                    this.productList.unshift({ label: 'Select Product', value: null });\n                    this.form.get('product_id').setValue(this.productList[0].value);\n                    const featureKeys = Array.from(\n                        new Set(resp.products.map(item => item?.feature_key))\n                    );\n                    this.featureKeysList = featureKeys.map(element => {\n                        return {\n                            value: element,\n                            label: element || ''\n                        };\n                    });\n                }\n            });\n    }\n\n    private sortObj(obj) {\n        return Object.keys(obj)\n            .sort()\n            .reduce((result, key) => {\n                result[key] = obj[key];\n\n                return result;\n            }, {});\n    }\n\n    private groupProducts(products) {\n        if (products && products?.length) {\n            products = products.filter(x => x.dependency_products?.length < 1 && x.active);\n            products = groupBy(products, 'currency');\n            products = this.sortObj(products);\n            let groupedArray = [];\n            // eslint-disable-next-line no-restricted-syntax\n            for (const p in products) {\n                if (p in products) {\n                    const value = products[p].sort(\n                        (a, b) => Number(b.price_per_unit) - Number(a.price_per_unit)\n                    );\n                    groupedArray.push(...value);\n                }\n            }\n            groupedArray = groupedArray.map(x => {\n                return {\n                    value: x.id,\n                    label: `${x.name} | ${x.region} | ${x.billing_frequency} | ${x.min_units} x ${(\n                        x.price_per_unit / 100\n                    ).toFixed(2)} | ${x.currency}`\n                };\n            });\n\n            return groupedArray;\n        }\n\n        return [];\n    }\n\n    onProductChange(event) {\n        this.searchText = '';\n        this.selectedFeatureKeys = event.value;\n        this.getFaqs();\n    }\n\n    onChange(item) {\n        this.isProductEnabled = item.value !== 'product';\n        if (this.isProductEnabled) {\n            this.form.get('product_id').setValue(null);\n        } else {\n            this.form.get('product_id');\n        }\n    }\n\n    onValueChange(faq: FAQ, value: boolean) {\n        const data = {\n            id: faq.id,\n            visible: value\n        };\n\n        this.adminService.putFaq(data, this.subscriptionId).subscribe(() => {\n            this.toast.success(this.translation.translate('Admin.Faq.UpdatedMessage'));\n        });\n    }\n\n    onPublicValueChange(faq: FAQ, value: boolean) {\n        const data = {\n            id: faq.id,\n            public: value\n        };\n\n        this.adminService.putFaq(data, this.subscriptionId).subscribe(() => {\n            this.toast.success(this.translation.translate('Admin.Faq.UpdatedMessage'));\n        });\n    }\n\n    onCancel() {\n        this.router.navigate([`${this.routers.faqConfig}`]);\n    }\n\n    override ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","\n<div class=\"container-fluid pw-tab overflow-hidden\">\n  <div class=\"dashboard\">\n      <div class=\"dashboard-body\">\n          <div class=\"me-auto col-xs-6 mt-4\">\n              <a href=\"javascript:void(0)\" (click)=\"back()\" class=\"previous\"><i\n                      class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n              <h3 class=\"mt-3\">Add New FAQ</h3>\n          </div>\n          <div class=\"p-2 mt-3\">\n            <form [formGroup]=\"form\" (ngSubmit)=\"onSubmit()\">\n              <div class=\"row\">\n                <pw-input-container class=\"col-12\" [label]=\"'Admin.Faq.Question' | transloco\" name=\"question\"\n                  [errorMsg]=\"'Admin.Faq.Validation.FieldRequired' | transloco\">\n                  <input type=\"text\" formControlName=\"question\" class=\"form-control\"\n                    [ngClass]=\"{ 'is-invalid': submitted && f['question'].errors }\" />\n                </pw-input-container>\n              </div>\n              <div class=\"row\">\n                <pw-input-container class=\"col-12 quill-editor\"\n                  [label]=\"'Admin.Faq.Answer' | transloco\"\n                  name=\"answer\"\n                  [errorMsg]=\"'Admin.Faq.Validation.FieldRequired' | transloco\">\n                  <quill-editor [styles]=\"{ height: '200px'}\" formControlName=\"answer\" class=\"quillEditor quill-editor\" [modules]=\"editorConfig\"\n                    [ngClass]=\"{ 'is-invalid': submitted && f['answer'].errors, 'quill-container': true  }\">\n                  </quill-editor>\n                </pw-input-container>\n              </div>\n              <div class=\"row justify-content-between\">\n                <div class=\"col-lg-2\">\n                  <pw-input-container [showTooltip]=\"true\" [tooltipText]=\"'Admin.Faq.Tooltip.Category' | transloco\"\n                    [label]=\"'Admin.Faq.Category' | transloco\" name=\"category\"\n                    [errorMsg]=\"'Admin.Faq.Validation.FieldRequired' | transloco\">\n                    <p-dropdown [options]=\"categories\" class=\"dropdown-bg-transparent\" (onChange)=\"onChange($event)\"\n                      placeholder=\"Select\" formControlName=\"category\" id=\"category-dropdown\" [style]=\"{ width: '100%' }\">\n                    </p-dropdown>\n                  </pw-input-container>\n                </div>\n                <div class=\"col-lg-2\" *rbacAllow=\"'SubscriptionSuperAdmin'\">\n                  <pw-input-container [showTooltip]=\"true\" [tooltipText]=\"'Admin.Faq.Tooltip.Product' | transloco\"\n                    [label]=\"'Admin.Faq.Product' | transloco\" name=\"product_id\"\n                    [errorMsg]=\"'Admin.Faq.Validation.FieldRequired' | transloco\">\n                    <p-dropdown [options]=\"productList\" class=\"dropdown-bg-transparent\" formControlName=\"product_id\"\n                      [style]=\"{ width: '100%' }\">\n                    </p-dropdown>\n                  </pw-input-container>\n                </div>\n                <!-- Features keys-->\n                <div class=\"col-lg-2\">\n                  <pw-input-container [showTooltip]=\"true\" [tooltipText]=\"'Admin.Faq.Tooltip.Features' | transloco\"\n                    [label]=\"'Admin.Faq.Features' | transloco\" name=\"feature_keys\">\n                    <p-multiSelect [options]=\"featureKeysList\" placeholder=\"Select feature keys\" [showHeader]=\"true\"\n                      [showToggleAll]=\"true\" formControlName=\"feature_keys\" appendTo=\"body\"></p-multiSelect>\n                  </pw-input-container>\n                </div>\n                <div class=\"col-lg-2\">\n                  <div class=\"mb-3\">\n                    <pw-input-container [showTooltip]=\"true\" [tooltipText]=\"'Admin.Faq.Tooltip.Position' | transloco\"\n                      [label]=\"'Admin.Faq.Position' | transloco\" name=\"position\"\n                      [errorMsg]=\"'Admin.Faq.Validation.FieldRequired' | transloco\">\n                      <div class=\"position\">\n                        <input type=\"number\" min=\"0\" formControlName=\"position\" class=\"form-control\" />\n                      </div>\n                    </pw-input-container>\n                  </div>\n                </div>\n                <div class=\"col-4 col-lg-2\">\n                  <label>{{ 'Admin.Faq.Visible' | transloco}} <span class=\"tooltip-wrap\" [appendTo]=\"'body'\"\n                      [pTooltip]=\"'Admin.Faq.Tooltip.Visible' | transloco\" tooltipPosition=\"top\">\n                      <i class=\"fas fa-info-circle\"></i>\n                    </span>\n                  </label><br />\n                  <ui-switch formControlName=\"visible\"></ui-switch>\n                </div>\n                <div class=\"col-4 col-lg-2\">\n                  <label>{{ 'Admin.Faq.Public' | transloco}} <span class=\"tooltip-wrap\" [appendTo]=\"'body'\"\n                      [pTooltip]=\"'Admin.Faq.Tooltip.Public' | transloco\" tooltipPosition=\"top\">\n                      <i class=\"fas fa-info-circle\"></i>\n                    </span>\n                  </label><br />\n                  <ui-switch formControlName=\"public\"></ui-switch>\n                </div>\n              </div>\n              <div class=\"row\" *rbacAllow=\"'SuperAdmin'\">\n                <div class=\"col-4 col-lg-2\">\n                  <label class=\"text-warning\">{{ 'Admin.Faq.SharedFaq' | transloco}} <span class=\"tooltip-wrap\"\n                      [appendTo]=\"'body'\" [pTooltip]=\"'Admin.Faq.Tooltip.SharedFaq' | transloco\" tooltipPosition=\"top\">\n                      <i class=\"fas fa-info-circle\"></i>\n                    </span>\n                  </label><br />\n                  <ui-switch name=\"is_shared_faq\" formControlName=\"is_shared_faq\"></ui-switch>\n                </div>\n                <div class=\"col-4 col-lg-2\">\n                  <label class=\"text-warning\">{{ 'Admin.Faq.AdminFaq' | transloco}} <span class=\"tooltip-wrap\"\n                      [appendTo]=\"'body'\" [pTooltip]=\"'Admin.Faq.Tooltip.AdminFaq' | transloco\" tooltipPosition=\"top\">\n                      <i class=\"fas fa-info-circle\"></i>\n                    </span>\n                  </label><br />\n                  <ui-switch formControlName=\"is_admin_faq\" name=\"is_admin_faq\"></ui-switch>\n                </div>\n                <div class=\"col-4 col-lg-2\">\n                  <label class=\"text-warning\">{{ 'Admin.Faq.BuildFaq' | transloco}} <span class=\"tooltip-wrap\"\n                      [appendTo]=\"'body'\" [pTooltip]=\"'Admin.Faq.Tooltip.BuildFaq' | transloco\" tooltipPosition=\"top\">\n                      <i class=\"fas fa-info-circle\"></i>\n                    </span>\n                  </label><br />\n                  <ui-switch formControlName=\"is_build_faq\" name=\"is_build_faq\"></ui-switch>\n                </div>\n              </div>\n              <div class=\"row\">\n                <div class=\"col-12 mt-4\">\n                  <div class=\"mb-3 text-end\">\n                    <button type=\"button\" class=\"btn btn-outline-default me-2\" data-bs-toggle=\"collapse\" href=\"#faqCollapse\"\n                      role=\"button\" aria-expanded=\"false\" aria-controls=\"faqCollapse\" (click)=\"onCancel()\"> {{ 'Button.Cancel' | transloco }} </button>\n                    <button class=\"btn btn-primary\" [buttonBusy]=\"buttonBusy\">{{ 'Button.Save' | transloco }}</button>\n                  </div>\n                </div>\n              </div>\n            </form>\n\n          </div>\n      </div>\n  </div>\n</div>\n\n"]}
219
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-faq.component.js","sourceRoot":"","sources":["../../../../../../../../libs/admin-module/src/lib/components/faqs/add-faq/add-faq.component.ts","../../../../../../../../libs/admin-module/src/lib/components/faqs/add-faq/add-faq.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAE,QAAQ,EAAqB,SAAS,EAAE,MAAM,eAAe,CAAC;AACjG,OAAO,EAAE,MAAM,EAAoB,MAAM,gBAAgB,CAAC;AAC1D,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,8BAA8B,CAAC;AACtE,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAChE,OAAO,EAAE,aAAa,EAAE,iBAAiB,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC7F,OAAO,EAAE,OAAO,EAAE,MAAM,iCAAiC,CAAC;AAE1D,OAAO,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAC;AAEjC,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;;;;;;;;;;;;;;AAOzD,MAAM,OAAO,eAAgB,SAAQ,gBAAgB;IAsDjD,YACY,aAA4B,EAC5B,YAA0B,EAC1B,cAA8B,EACtC,QAAkB;QAElB,KAAK,CAAC,QAAQ,CAAC,CAAC;QALR,kBAAa,GAAb,aAAa,CAAe;QAC5B,iBAAY,GAAZ,YAAY,CAAc;QAC1B,mBAAc,GAAd,cAAc,CAAgB;QAvD1C,YAAO,GAAG,OAAO,CAAC;QAClB,SAAI,GAAU,EAAE,CAAC;QAEjB,YAAO,GAAU,EAAE,CAAC;QAGpB,cAAS,GAAU,EAAE,CAAC;QAEtB,cAAS,GAAG,KAAK,CAAC;QAElB,aAAQ,GAAG,IAAI,CAAC;QAGhB,WAAM,GAAG,KAAK,CAAC;QAEf,eAAU,GAAG,EAAE,CAAC;QAEhB,qBAAgB,GAAG,IAAI,CAAC;QAExB,gBAAW,GAAkB,EAAE,CAAC;QAEhC,eAAU,GAAG,EAAE,CAAC;QAEhB,gBAAW,GAAc,EAAE,CAAC;QAE5B,YAAO,GAAG,EAAE,CAAC;QAEb,aAAQ,GAAG,IAAI,CAAC;QAEhB,gBAAW,GAAG,IAAI,CAAC;QAEnB,iBAAY,GAAG,IAAI,CAAC;QAEpB,2BAAsB,GAAG,CAAC,CAAC;QAE3B,iBAAY,GAAG,CAAC,CAAC;QAIjB,oBAAe,GAAG,EAAE,CAAC;QAErB,wBAAmB,GAAG,EAAE,CAAC;QAEzB,eAAU,GAAG,KAAK,CAAC;QAEnB,sBAAiB,GAAG,EAAE,CAAC;QAIvB,eAAU,GAAG,EAAE,CAAC;QAChB,SAAI,GAAG,CAAC,CAAC;QASL,WAAW,CAAC,IAAI,EAAE,CAAC;QACnB,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC,eAAe,EAAE,CAAC;QAClD,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC,UAAU,EAAE,CAAC;IACtC,CAAC;IACD,QAAQ;QACJ,IAAI,CAAC,IAAI,GAAG,iBAAiB,CAAC,oBAAoB,EAAE,IAAI,CAAC;QACzD,IAAI,CAAC,cAAc,GAAG,iBAAiB,CAAC,oBAAoB,EAAE,EAAE,CAAC;QACjE,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,OAAO,EAAE,CAAC;IACnB,CAAC;IACD,eAAe;QACX,aAAa,CAAC,wBAAwB,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;IAChE,CAAC;IAED,IAAI,CAAC;QACD,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC;IAC9B,CAAC;IACO,OAAO;QACX,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,MAAM,MAAM,GAAG;YACX,eAAe,EAAE,IAAI,CAAC,cAAc;YACpC,WAAW,EAAE,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE;SACxD,CAAC;QACF,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,EAAE,GAAG,MAAM,EAAE,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;YAC1D,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;YACrB,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC;YAC1B,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC;YAC7B,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;YAC1C,IAAI,CAAC,sBAAsB,GAAG,QAAQ,CAAC,gBAAgB,CAAC;YACxD,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;gBAC1B,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC;gBAEjB,OAAO,CAAC,CAAC;YACb,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,SAAS,GAAG,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC;YAChC,QAAQ,EAAE,kBAAkB,EAAE,OAAO,CAAC,CAAC,CAAC,EAAE;gBACtC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YAC/B,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,iBAAiB,GAAG,QAAQ,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;YACrE,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC,kBAAkB,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;gBACxD,OAAO,EAAE,KAAK,EAAE,OAAO,CAAC,IAAI,IAAI,EAAE,EAAE,KAAK,EAAE,OAAO,CAAC,GAAG,EAAE,CAAC;YAC7D,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC;YACzB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC;QAC7B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC7B,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YAClB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACtB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,CAAC,MAAM,EAAE,CAAC;QAClB,CAAC;IACL,CAAC;IAED,MAAM;QACF,MAAM,OAAO,GAAG,aAAa,CAAC,WAAW,EAAE,CAAC;QAC5C,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QAC/C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,YAAY;aACZ,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,cAAc,CAAC;aAC7C,SAAS,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,sBAAsB,CAAC,CAAC,CAAC;YACvE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;QACxD,CAAC,CAAC;aACD,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,CAAC,CAAC;IAC9C,CAAC;IAEO,aAAa;QACjB,IAAI,CAAC,cAAc;aACd,WAAW,CAAC;YACT,eAAe,EAAE,IAAI,CAAC,cAAc;SACvC,CAAC;aACD,SAAS,CAAC,IAAI,CAAC,EAAE;YACd,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAChB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;gBACjC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBACrD,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,gBAAgB,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;gBACnE,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;gBAChE,MAAM,WAAW,GAAG,KAAK,CAAC,IAAI,CAC1B,IAAI,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC,CACxD,CAAC;gBACF,IAAI,CAAC,eAAe,GAAG,WAAW,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;oBAC7C,OAAO;wBACH,KAAK,EAAE,OAAO;wBACd,KAAK,EAAE,OAAO,IAAI,EAAE;qBACvB,CAAC;gBACN,CAAC,CAAC,CAAC;YACP,CAAC;QACL,CAAC,CAAC,CAAC;IACX,CAAC;IAEO,OAAO,CAAC,GAAG;QACf,OAAO,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC;aAClB,IAAI,EAAE;aACN,MAAM,CAAC,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE;YACpB,MAAM,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC;YAEvB,OAAO,MAAM,CAAC;QAClB,CAAC,EAAE,EAAE,CAAC,CAAC;IACf,CAAC;IAEO,aAAa,CAAC,QAAQ;QAC1B,IAAI,QAAQ,IAAI,QAAQ,EAAE,MAAM,EAAE,CAAC;YAC/B,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,mBAAmB,EAAE,MAAM,GAAG,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC;YAC/E,QAAQ,GAAG,OAAO,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;YACzC,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;YAClC,IAAI,YAAY,GAAG,EAAE,CAAC;YACtB,gDAAgD;YAChD,KAAK,MAAM,CAAC,IAAI,QAAQ,EAAE,CAAC;gBACvB,IAAI,CAAC,IAAI,QAAQ,EAAE,CAAC;oBAChB,MAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAC1B,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,cAAc,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,cAAc,CAAC,CAChE,CAAC;oBACF,YAAY,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,CAAC;gBAChC,CAAC;YACL,CAAC;YACD,YAAY,GAAG,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;gBAChC,OAAO;oBACH,KAAK,EAAE,CAAC,CAAC,EAAE;oBACX,KAAK,EAAE,GAAG,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,MAAM,MAAM,CAAC,CAAC,iBAAiB,MAAM,CAAC,CAAC,SAAS,MAAM,CAC1E,CAAC,CAAC,cAAc,GAAG,GAAG,CACzB,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE;iBACjC,CAAC;YACN,CAAC,CAAC,CAAC;YAEH,OAAO,YAAY,CAAC;QACxB,CAAC;QAED,OAAO,EAAE,CAAC;IACd,CAAC;IAED,eAAe,CAAC,KAAK;QACjB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC,KAAK,CAAC;QACvC,IAAI,CAAC,OAAO,EAAE,CAAC;IACnB,CAAC;IAED,QAAQ,CAAC,IAAI;QACT,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,KAAK,KAAK,SAAS,CAAC;QACjD,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QAC/C,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QAChC,CAAC;IACL,CAAC;IAED,aAAa,CAAC,GAAQ,EAAE,KAAc;QAClC,MAAM,IAAI,GAAG;YACT,EAAE,EAAE,GAAG,CAAC,EAAE;YACV,OAAO,EAAE,KAAK;SACjB,CAAC;QAEF,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC/D,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC,CAAC;QAC/E,CAAC,CAAC,CAAC;IACP,CAAC;IAED,mBAAmB,CAAC,GAAQ,EAAE,KAAc;QACxC,MAAM,IAAI,GAAG;YACT,EAAE,EAAE,GAAG,CAAC,EAAE;YACV,MAAM,EAAE,KAAK;SAChB,CAAC;QAEF,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC/D,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC,CAAC;QAC/E,CAAC,CAAC,CAAC;IACP,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;IACxD,CAAC;IAEQ,WAAW;QAChB,KAAK,CAAC,WAAW,EAAE,CAAC;IACxB,CAAC;+GAjPQ,eAAe;mGAAf,eAAe,+LCjB5B,igPA6HA;;4FD5Ga,eAAe;kBAL3B,SAAS;+BACI,4BAA4B;iKAkBI,QAAQ;sBAAjD,SAAS;uBAAC,UAAU,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE","sourcesContent":["import { AfterViewInit, Component, Injector, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { NgForm, UntypedFormGroup } from '@angular/forms';\nimport { AdminService, AppAdmin } from '@posiwise/admin-module-utils';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { CommonService, PermissionService, ProductService } from '@posiwise/common-services';\nimport { ROUTERS } from '../../../shared/routers/routers';\nimport { FAQ, Product } from '@posiwise/common-utilities';\nimport { groupBy } from 'lodash';\nimport { ProductList } from '../../../shared/interface/admin-module-shared.interface';\nimport { QuillHelper } from '@posiwise/utils';\nimport { HelperService } from '@posiwise/helper-service';\n\n@Component({\n    selector: 'pw-admin-add-edit-incident',\n    templateUrl: './add-faq.component.html',\n    styleUrls: ['./add-faq.component.scss']\n})\nexport class AddFaqComponent extends AppBaseComponent implements OnInit, OnDestroy, AfterViewInit {\n    form: UntypedFormGroup;\n    routers = ROUTERS;\n    faqs: FAQ[] = [];\n    editorConfig;\n    faqList: FAQ[] = [];\n    id: number;\n\n    backUpFAQ: FAQ[] = [];\n\n    submitted = false;\n\n    isLoaded = true;\n\n    @ViewChild('editForm', { static: false }) editForm: NgForm;\n    isEdit = false;\n\n    categories = [];\n\n    isProductEnabled = true;\n\n    productList: ProductList[] = [];\n\n    searchText = '';\n\n    allProducts: Product[] = [];\n\n    allFaqs = [];\n\n    showList = true;\n\n    showFilters = true;\n\n    defaultValue = null;\n\n    totalRecordsUnFiltered = 0;\n\n    totalRecords = 0;\n\n    subscriptionId: number;\n\n    featureKeysList = [];\n\n    selectedFeatureKeys = [];\n\n    buttonBusy = false;\n\n    categoryForBadges = [];\n\n    slug: string;\n\n    faqHashMap = {};\n    page = 1;\n\n    constructor(\n        private commonService: CommonService,\n        private adminService: AdminService,\n        private productService: ProductService,\n        injector: Injector\n    ) {\n        super(injector);\n        QuillHelper.init();\n        this.editorConfig = QuillHelper.getEditorConfig();\n        this.form = AppAdmin.getFaqForm();\n    }\n    ngOnInit() {\n        this.slug = PermissionService.selectedSubscription?.slug;\n        this.subscriptionId = PermissionService.selectedSubscription?.id;\n        this.getCategories();\n        this.getFaqs();\n    }\n    ngAfterViewInit() {\n        HelperService.subscribeToEditorChanges(this.form, 'answer');\n    }\n\n    get f() {\n        return this.form.controls;\n    }\n    private getFaqs() {\n        this.isLoaded = false;\n        this.categories = [];\n        this.faqHashMap = {};\n        const params = {\n            subscription_id: this.subscriptionId,\n            feature_key: this.selectedFeatureKeys.join(',') || ''\n        };\n        this.commonService.getFaq({ ...params }).subscribe(response => {\n            this.isLoaded = true;\n            this.faqs = response.faqs;\n            this.allFaqs = response.faqs;\n            this.totalRecords = response.object_count;\n            this.totalRecordsUnFiltered = response.unfiltered_count;\n            this.faqs = this.faqs.map(x => {\n                x.isEdit = false;\n\n                return x;\n            });\n\n            this.backUpFAQ = [...this.faqs];\n            response?.available_category?.forEach(x => {\n                this.faqHashMap[x.key] = x;\n            });\n            this.categoryForBadges = response.available_category.map(x => x.key);\n            this.categories = response.available_category.map(element => {\n                return { label: element.name || '', value: element.key };\n            });\n\n            this.allFaqs = this.faqs;\n            this.faqList = this.faqs;\n        });\n    }\n\n    onSubmit() {\n        this.form.markAllAsTouched();\n        if (this.form.valid) {\n            this.submitted = true;\n            this.buttonBusy = true;\n            this.addNew();\n        }\n    }\n\n    addNew() {\n        const rawHtml = HelperService.SaveRawHTML();\n        this.form.controls['answer'].setValue(rawHtml);\n        this.buttonBusy = true;\n        this.adminService\n            .postFaq(this.form.value, this.subscriptionId)\n            .subscribe(() => {\n                this.toast.success(this.translation.translate('Admin.Faq.AddMessage'));\n                this.router.navigate([`${this.routers.faqConfig}`]);\n            })\n            .add(() => (this.buttonBusy = false));\n    }\n\n    private getCategories() {\n        this.productService\n            .getProducts({\n                subscription_id: this.subscriptionId\n            })\n            .subscribe(resp => {\n                if (resp.products) {\n                    this.allProducts = resp.products;\n                    this.productList = this.groupProducts(resp.products);\n                    this.productList.unshift({ label: 'Select Product', value: null });\n                    this.form.get('product_id').setValue(this.productList[0].value);\n                    const featureKeys = Array.from(\n                        new Set(resp.products.map(item => item?.feature_key))\n                    );\n                    this.featureKeysList = featureKeys.map(element => {\n                        return {\n                            value: element,\n                            label: element || ''\n                        };\n                    });\n                }\n            });\n    }\n\n    private sortObj(obj) {\n        return Object.keys(obj)\n            .sort()\n            .reduce((result, key) => {\n                result[key] = obj[key];\n\n                return result;\n            }, {});\n    }\n\n    private groupProducts(products) {\n        if (products && products?.length) {\n            products = products.filter(x => x.dependency_products?.length < 1 && x.active);\n            products = groupBy(products, 'currency');\n            products = this.sortObj(products);\n            let groupedArray = [];\n            // eslint-disable-next-line no-restricted-syntax\n            for (const p in products) {\n                if (p in products) {\n                    const value = products[p].sort(\n                        (a, b) => Number(b.price_per_unit) - Number(a.price_per_unit)\n                    );\n                    groupedArray.push(...value);\n                }\n            }\n            groupedArray = groupedArray.map(x => {\n                return {\n                    value: x.id,\n                    label: `${x.name} | ${x.region} | ${x.billing_frequency} | ${x.min_units} x ${(\n                        x.price_per_unit / 100\n                    ).toFixed(2)} | ${x.currency}`\n                };\n            });\n\n            return groupedArray;\n        }\n\n        return [];\n    }\n\n    onProductChange(event) {\n        this.searchText = '';\n        this.selectedFeatureKeys = event.value;\n        this.getFaqs();\n    }\n\n    onChange(item) {\n        this.isProductEnabled = item.value !== 'product';\n        if (this.isProductEnabled) {\n            this.form.get('product_id').setValue(null);\n        } else {\n            this.form.get('product_id');\n        }\n    }\n\n    onValueChange(faq: FAQ, value: boolean) {\n        const data = {\n            id: faq.id,\n            visible: value\n        };\n\n        this.adminService.putFaq(data, this.subscriptionId).subscribe(() => {\n            this.toast.success(this.translation.translate('Admin.Faq.UpdatedMessage'));\n        });\n    }\n\n    onPublicValueChange(faq: FAQ, value: boolean) {\n        const data = {\n            id: faq.id,\n            public: value\n        };\n\n        this.adminService.putFaq(data, this.subscriptionId).subscribe(() => {\n            this.toast.success(this.translation.translate('Admin.Faq.UpdatedMessage'));\n        });\n    }\n\n    onCancel() {\n        this.router.navigate([`${this.routers.faqConfig}`]);\n    }\n\n    override ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","\n<div class=\"container-fluid pw-tab overflow-hidden\">\n  <div class=\"dashboard\">\n      <div class=\"dashboard-body\">\n          <div class=\"me-auto col-xs-6 mt-4\">\n              <a href=\"javascript:void(0)\" (click)=\"back()\" class=\"previous\"><i\n                      class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n              <h3 class=\"mt-3\">Add New FAQ</h3>\n          </div>\n          <div class=\"p-2 mt-3\">\n            <form [formGroup]=\"form\" (ngSubmit)=\"onSubmit()\">\n              <div class=\"row\">\n                <pw-input-container class=\"col-12\" [label]=\"'Admin.Faq.Question' | transloco\" name=\"question\"\n                  [errorMsg]=\"'Admin.Faq.Validation.FieldRequired' | transloco\">\n                  <input type=\"text\" formControlName=\"question\" class=\"form-control\"\n                    [ngClass]=\"{ 'is-invalid': submitted && f['question'].errors }\" />\n                </pw-input-container>\n              </div>\n              <div class=\"row\">\n                <pw-input-container class=\"col-12 quill-editor\"\n                  [label]=\"'Admin.Faq.Answer' | transloco\"\n                  name=\"answer\"\n                  [errorMsg]=\"'Admin.Faq.Validation.FieldRequired' | transloco\">\n                  <quill-editor [styles]=\"{ height: '200px'}\" formControlName=\"answer\" class=\"quillEditor quill-editor\" [modules]=\"editorConfig\"\n                    [ngClass]=\"{ 'is-invalid': submitted && f['answer'].errors, 'quill-container': true  }\">\n                  </quill-editor>\n                </pw-input-container>\n              </div>\n              <div class=\"row justify-content-between\">\n                <div class=\"col-lg-2\">\n                  <pw-input-container [showTooltip]=\"true\" [tooltipText]=\"'Admin.Faq.Tooltip.Category' | transloco\"\n                    [label]=\"'Admin.Faq.Category' | transloco\" name=\"category\"\n                    [errorMsg]=\"'Admin.Faq.Validation.FieldRequired' | transloco\">\n                    <p-dropdown [options]=\"categories\" class=\"dropdown-bg-transparent\" (onChange)=\"onChange($event)\"\n                      placeholder=\"Select\" formControlName=\"category\" id=\"category-dropdown\" [style]=\"{ width: '100%' }\">\n                    </p-dropdown>\n                  </pw-input-container>\n                </div>\n                <div class=\"col-lg-2\" *rbacAllow=\"'SubscriptionSuperAdmin'\">\n                  <pw-input-container [showTooltip]=\"true\" [tooltipText]=\"'Admin.Faq.Tooltip.Product' | transloco\"\n                    [label]=\"'Admin.Faq.Product' | transloco\" name=\"product_id\"\n                    [errorMsg]=\"'Admin.Faq.Validation.FieldRequired' | transloco\">\n                    <p-dropdown [options]=\"productList\" class=\"dropdown-bg-transparent\" formControlName=\"product_id\"\n                      [style]=\"{ width: '100%' }\">\n                    </p-dropdown>\n                  </pw-input-container>\n                </div>\n                <!-- Features keys-->\n                <div class=\"col-lg-2\">\n                  <pw-input-container [showTooltip]=\"true\" [tooltipText]=\"'Admin.Faq.Tooltip.Features' | transloco\"\n                    [label]=\"'Admin.Faq.Features' | transloco\" name=\"feature_keys\">\n                    <p-multiSelect [options]=\"featureKeysList\" placeholder=\"Select feature keys\" [showHeader]=\"true\"\n                      [showToggleAll]=\"true\" formControlName=\"feature_keys\" appendTo=\"body\"></p-multiSelect>\n                  </pw-input-container>\n                </div>\n                <div class=\"col-lg-2\">\n                  <div class=\"mb-3\">\n                    <pw-input-container [showTooltip]=\"true\" [tooltipText]=\"'Admin.Faq.Tooltip.Position' | transloco\"\n                      [label]=\"'Admin.Faq.Position' | transloco\" name=\"position\"\n                      [errorMsg]=\"'Admin.Faq.Validation.FieldRequired' | transloco\">\n                      <div class=\"position\">\n                        <input type=\"number\" min=\"0\" formControlName=\"position\" class=\"form-control\" />\n                      </div>\n                    </pw-input-container>\n                  </div>\n                </div>\n                <div class=\"col-4 col-lg-2\">\n                  <label>{{ 'Admin.Faq.Visible' | transloco}} <span class=\"tooltip-wrap\" [appendTo]=\"'body'\"\n                      [pTooltip]=\"'Admin.Faq.Tooltip.Visible' | transloco\" tooltipPosition=\"top\">\n                      <i class=\"fas fa-info-circle\"></i>\n                    </span>\n                  </label><br />\n                  <ui-switch formControlName=\"visible\"></ui-switch>\n                </div>\n                <div class=\"col-4 col-lg-2\">\n                  <label>{{ 'Admin.Faq.Public' | transloco}} <span class=\"tooltip-wrap\" [appendTo]=\"'body'\"\n                      [pTooltip]=\"'Admin.Faq.Tooltip.Public' | transloco\" tooltipPosition=\"top\">\n                      <i class=\"fas fa-info-circle\"></i>\n                    </span>\n                  </label><br />\n                  <ui-switch formControlName=\"public\"></ui-switch>\n                </div>\n              </div>\n              <div class=\"row\" *rbacAllow=\"'SuperAdmin'\">\n                <div class=\"col-4 col-lg-2\">\n                  <label class=\"text-warning\">{{ 'Admin.Faq.SharedFaq' | transloco}} <span class=\"tooltip-wrap\"\n                      [appendTo]=\"'body'\" [pTooltip]=\"'Admin.Faq.Tooltip.SharedFaq' | transloco\" tooltipPosition=\"top\">\n                      <i class=\"fas fa-info-circle\"></i>\n                    </span>\n                  </label><br />\n                  <ui-switch name=\"is_shared_faq\" formControlName=\"is_shared_faq\"></ui-switch>\n                </div>\n                <div class=\"col-4 col-lg-2\">\n                  <label class=\"text-warning\">{{ 'Admin.Faq.AdminFaq' | transloco}} <span class=\"tooltip-wrap\"\n                      [appendTo]=\"'body'\" [pTooltip]=\"'Admin.Faq.Tooltip.AdminFaq' | transloco\" tooltipPosition=\"top\">\n                      <i class=\"fas fa-info-circle\"></i>\n                    </span>\n                  </label><br />\n                  <ui-switch formControlName=\"is_admin_faq\" name=\"is_admin_faq\"></ui-switch>\n                </div>\n                <div class=\"col-4 col-lg-2\">\n                  <label class=\"text-warning\">{{ 'Admin.Faq.BuildFaq' | transloco}} <span class=\"tooltip-wrap\"\n                      [appendTo]=\"'body'\" [pTooltip]=\"'Admin.Faq.Tooltip.BuildFaq' | transloco\" tooltipPosition=\"top\">\n                      <i class=\"fas fa-info-circle\"></i>\n                    </span>\n                  </label><br />\n                  <ui-switch formControlName=\"is_build_faq\" name=\"is_build_faq\"></ui-switch>\n                </div>\n              </div>\n              <div class=\"row\">\n                <div class=\"col-12 mt-4\">\n                  <div class=\"mb-3 text-end\">\n                    <button type=\"button\" class=\"btn btn-outline-default me-2\" data-bs-toggle=\"collapse\" href=\"#faqCollapse\"\n                      role=\"button\" aria-expanded=\"false\" aria-controls=\"faqCollapse\" (click)=\"onCancel()\"> {{ 'Button.Cancel' | transloco }} </button>\n                    <button class=\"btn btn-primary\" [buttonBusy]=\"buttonBusy\">{{ 'Button.Save' | transloco }}</button>\n                  </div>\n                </div>\n              </div>\n            </form>\n\n          </div>\n      </div>\n  </div>\n</div>\n\n"]}
@@ -30,8 +30,10 @@ export class MailerDetailsComponent extends AppBaseComponent {
30
30
  this.editorConfig = QuillHelper.getEditorConfig();
31
31
  this.form = AppAdmin.getMailerForm();
32
32
  }
33
+ ngAfterViewInit() {
34
+ HelperService.subscribeToEditorChanges(this.form, 'body');
35
+ }
33
36
  ngOnInit() {
34
- console.log('In thismhkj,bknm');
35
37
  this.subscriptionId = PermissionService.selectedSubscription?.id;
36
38
  this.route.params.subscribe(params => {
37
39
  this.id = Number(params['id']);
@@ -111,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
111
113
  type: Component,
112
114
  args: [{ selector: 'pw-mailer-details', template: "<div class=\"container-fluid pw-tab overflow-hidden\">\n <div class=\"dashboard\">\n <div class=\"dashboard-body\">\n <div class=\"me-auto col-xs-6 mt-4\">\n <a href=\"javascript:void(0)\" [routerLink]=\"[routers.mailerDetails]\" class=\"previous\">\n <i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i>\n </a>\n <h3 class=\"m-subheader__title m-subheader__title--separator\">\n <span>Mailer: {{ isLoading ? '' : (data?.id ? \"Edit\" : 'Add New') }}</span>\n </h3>\n </div>\n\n <div class=\"w-100 text-center mt-3\" *ngIf=\"isLoading\">\n <p-progressSpinner strokeWidth=\"2\"></p-progressSpinner>\n </div>\n\n <div class=\"p-2 mt-3\" *ngIf=\"!isLoading\">\n <form [formGroup]=\"form\" (ngSubmit)=\"onSave()\">\n <div class=\"row\">\n <!-- Subject Field -->\n <!-- Subject Field -->\n<div class=\"col-12 col-md-6\">\n <pw-input-container [showTooltip]=\"true\" [tooltipText]=\"'Admin.Mailer.Tooltip.Subject' | transloco\"\n [label]=\"'Label.Subject' | transloco\" class=\"mb-3\" name=\"subject\" [errorMsg]=\"'Admin.Mailer.Validation.Subject' | transloco\">\n <input type=\"text\" class=\"form-control\" formControlName=\"subject\" [ngClass]=\"{ 'is-invalid': submitted && f['subject'].errors }\" />\n </pw-input-container>\n</div>\n\n<!-- Body Field -->\n<div class=\"col-12 col-md-6\">\n <pw-input-container [showTooltip]=\"true\" [tooltipText]=\"'Admin.Mailer.Tooltip.TemplateName' | transloco\"\n [label]=\"'Label.TemplateName' | transloco\" class=\"mb-3\" name=\"template_name\" [errorMsg]=\"'Admin.Mailer.Validation.TemplateName' | transloco\">\n <p-dropdown [options]=\"availableMailerTypes\"\n formControlName=\"template_name\"\n [style]=\"{ width: '100%' }\"\n [ngClass]=\"{ 'is-invalid': submitted && f['template_name'].errors }\">\n </p-dropdown>\n </pw-input-container>\n</div>\n<pw-input-container [showTooltip]=\"true\" [tooltipText]=\"'Admin.Mailer.Tooltip.Body' | transloco\"\n[label]=\"'Label.Body' | transloco\" class=\"mb-3\" name=\"body\" [errorMsg]=\"'Admin.Mailer.Validation.Body' | transloco\">\n<quill-editor [styles]=\"{ height: '450px' }\"\n class=\"quillEditor quill-editor\" [modules]=\"editorConfig\"\n formControlName=\"body\"\n [ngClass]=\"{ 'is-invalid': submitted && f['body'].errors, 'quill-container': true }\">\n</quill-editor>\n</pw-input-container>\n\n <!-- Form Actions -->\n <div class=\"col-12 text-end mt-3\">\n <button type=\"button\" class=\"btn btn-outline-default me-2\" (click)=\"back()\">\n {{ 'Button.Cancel' | transloco }}\n </button>\n <button type=\"submit\" [buttonBusy]=\"buttonBusy\" class=\"btn btn-primary\">\n {{ 'Button.Submit' | transloco }}\n </button>\n </div>\n </div>\n </form>\n </div>\n </div>\n</div>\n</div>" }]
113
115
  }], ctorParameters: () => [{ type: i1.AdminService }, { type: i0.Injector }], propDecorators: { onSave: [] } });
114
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mailer-details.component.js","sourceRoot":"","sources":["../../../../../../../../libs/admin-module/src/lib/components/mailer/mailer-details/mailer-details.component.ts","../../../../../../../../libs/admin-module/src/lib/components/mailer/mailer-details/mailer-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injector, OnDestroy, OnInit } from '@angular/core';\nimport { UntypedFormGroup } from '@angular/forms';\n\nimport { AdminService } from '@posiwise/admin-module-utils';\nimport { AppAdmin } from '@posiwise/admin-module-utils';\nimport { ROUTERS } from '../../../shared/routers/routers';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { PermissionService } from '@posiwise/common-services';\nimport { QuillHelper, ValidateForm } from '@posiwise/utils';\nimport { HelperService } from '@posiwise/helper-service';\n\n@Component({\n    selector: 'pw-mailer-details',\n    templateUrl: './mailer-details.component.html'\n})\nexport class MailerDetailsComponent extends AppBaseComponent implements OnInit, OnDestroy {\n    form: UntypedFormGroup;\n\n    submitted = false;\n\n    buttonBusy = false;\n\n    id: number;\n\n    data;\n\n    availableMailerTypes;\n\n    editorConfig;\n\n    routers = ROUTERS;\n\n    isLoading = true;\n\n    subscriptionId: number;\n\n    constructor(\n        private adminService: AdminService,\n        injector: Injector\n    ) {\n        super(injector);\n        QuillHelper.init();\n        this.editorConfig = QuillHelper.getEditorConfig();\n        this.form = AppAdmin.getMailerForm();\n    }\n\n    ngOnInit() {\n        console.log('In thismhkj,bknm');\n        this.subscriptionId = PermissionService.selectedSubscription?.id;\n        this.route.params.subscribe(params => {\n            this.id = Number(params['id']);\n            this.getMailerTypes();\n            if (!this.id) {\n                this.isLoading = false;\n            }\n        });\n    }\n\n    get f() {\n        return this.form.controls;\n    }\n\n    getMailerDetails() {\n        this.adminService\n            .getMailerById(this.id, this.subscriptionId)\n            .subscribe(response => {\n                this.data = response;\n                const { value } = this.availableMailerTypes.find(\n                    mailer => mailer.label === response.template_name\n                );\n                this.form.patchValue({ ...this.data, template_name: value });\n            })\n            .add(() => {\n                this.isLoading = false;\n            });\n    }\n\n    private getMailerTypes() {\n        this.adminService.getMailerTypes(this.subscriptionId).subscribe(response => {\n            this.availableMailerTypes = Object.entries(response.items).map(([key, value]) => ({\n                label: key,\n                value: value\n            }));\n            this.availableMailerTypes.unshift({\n                label: 'Select',\n                value: null\n            });\n            this.id && this.getMailerDetails();\n        });\n    }\n\n    @ValidateForm('form')\n    onSave() {\n        const rawHtml = HelperService.SaveRawHTML();\n        this.form.controls['body'].setValue(rawHtml);\n        const { label: templateName } = this.availableMailerTypes.find(\n            item => item.value === this.form.value.template_name\n        );\n        this.buttonBusy = true;\n        this.submitted = true;\n        const data = {\n            ...this.form.value,\n            template_name: templateName,\n            subscription_id: this.subscriptionId\n        };\n        const sub$ = this.id\n            ? this.adminService.updateMailer(data, this.id)\n            : this.adminService.addMailer(data);\n        sub$.subscribe({\n            next: _ => {\n                this.id\n                    ? this.toast.success(this.translation.translate('Admin.Mailer.UpdatedMessage'))\n                    : this.toast.success(this.translation.translate('Admin.Mailer.AddedMessage'));\n                this.back();\n            }\n        }).add(() => {\n            this.buttonBusy = false;\n            this.submitted = false;\n        });\n    }\n\n    override ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","<div class=\"container-fluid pw-tab overflow-hidden\">\n  <div class=\"dashboard\">\n    <div class=\"dashboard-body\">\n      <div class=\"me-auto col-xs-6 mt-4\">\n        <a href=\"javascript:void(0)\" [routerLink]=\"[routers.mailerDetails]\" class=\"previous\">\n          <i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i>\n        </a>\n        <h3 class=\"m-subheader__title m-subheader__title--separator\">\n          <span>Mailer: {{ isLoading ? '' : (data?.id ? \"Edit\" : 'Add New') }}</span>\n        </h3>\n      </div>\n\n    <div class=\"w-100 text-center mt-3\" *ngIf=\"isLoading\">\n      <p-progressSpinner strokeWidth=\"2\"></p-progressSpinner>\n    </div>\n\n    <div class=\"p-2 mt-3\" *ngIf=\"!isLoading\">\n      <form [formGroup]=\"form\" (ngSubmit)=\"onSave()\">\n        <div class=\"row\">\n          <!-- Subject Field -->\n         <!-- Subject Field -->\n<div class=\"col-12 col-md-6\">\n  <pw-input-container [showTooltip]=\"true\" [tooltipText]=\"'Admin.Mailer.Tooltip.Subject' | transloco\"\n    [label]=\"'Label.Subject' | transloco\" class=\"mb-3\" name=\"subject\" [errorMsg]=\"'Admin.Mailer.Validation.Subject' | transloco\">\n    <input type=\"text\" class=\"form-control\" formControlName=\"subject\" [ngClass]=\"{ 'is-invalid': submitted && f['subject'].errors }\" />\n  </pw-input-container>\n</div>\n\n<!-- Body Field -->\n<div class=\"col-12 col-md-6\">\n  <pw-input-container [showTooltip]=\"true\" [tooltipText]=\"'Admin.Mailer.Tooltip.TemplateName' | transloco\"\n  [label]=\"'Label.TemplateName' | transloco\" class=\"mb-3\" name=\"template_name\" [errorMsg]=\"'Admin.Mailer.Validation.TemplateName' | transloco\">\n              <p-dropdown [options]=\"availableMailerTypes\"\n                formControlName=\"template_name\"\n                [style]=\"{ width: '100%' }\"\n                [ngClass]=\"{ 'is-invalid': submitted && f['template_name'].errors }\">\n              </p-dropdown>\n            </pw-input-container>\n</div>\n<pw-input-container  [showTooltip]=\"true\" [tooltipText]=\"'Admin.Mailer.Tooltip.Body' | transloco\"\n[label]=\"'Label.Body' | transloco\" class=\"mb-3\" name=\"body\" [errorMsg]=\"'Admin.Mailer.Validation.Body' | transloco\">\n<quill-editor [styles]=\"{ height: '450px' }\"\n  class=\"quillEditor quill-editor\" [modules]=\"editorConfig\"\n  formControlName=\"body\"\n  [ngClass]=\"{ 'is-invalid': submitted && f['body'].errors, 'quill-container': true  }\">\n</quill-editor>\n</pw-input-container>\n\n          <!-- Form Actions -->\n          <div class=\"col-12 text-end mt-3\">\n            <button type=\"button\" class=\"btn btn-outline-default me-2\" (click)=\"back()\">\n              {{ 'Button.Cancel' | transloco }}\n            </button>\n            <button type=\"submit\" [buttonBusy]=\"buttonBusy\" class=\"btn btn-primary\">\n              {{ 'Button.Submit' | transloco }}\n            </button>\n          </div>\n        </div>\n      </form>\n    </div>\n  </div>\n</div>\n</div>"]}
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mailer-details.component.js","sourceRoot":"","sources":["../../../../../../../../libs/admin-module/src/lib/components/mailer/mailer-details/mailer-details.component.ts","../../../../../../../../libs/admin-module/src/lib/components/mailer/mailer-details/mailer-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, Injector, OnDestroy, OnInit } from '@angular/core';\nimport { UntypedFormGroup } from '@angular/forms';\n\nimport { AdminService } from '@posiwise/admin-module-utils';\nimport { AppAdmin } from '@posiwise/admin-module-utils';\nimport { ROUTERS } from '../../../shared/routers/routers';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { PermissionService } from '@posiwise/common-services';\nimport { QuillHelper, ValidateForm } from '@posiwise/utils';\nimport { HelperService } from '@posiwise/helper-service';\n\n@Component({\n    selector: 'pw-mailer-details',\n    templateUrl: './mailer-details.component.html'\n})\nexport class MailerDetailsComponent extends AppBaseComponent implements OnInit, OnDestroy, AfterViewInit {\n    form: UntypedFormGroup;\n\n    submitted = false;\n\n    buttonBusy = false;\n\n    id: number;\n\n    data;\n\n    availableMailerTypes;\n\n    editorConfig;\n\n    routers = ROUTERS;\n\n    isLoading = true;\n\n    subscriptionId: number;\n\n    constructor(\n        private adminService: AdminService,\n        injector: Injector\n    ) {\n        super(injector);\n        QuillHelper.init();\n        this.editorConfig = QuillHelper.getEditorConfig();\n        this.form = AppAdmin.getMailerForm();\n    }\n\n    ngAfterViewInit() {\n        HelperService.subscribeToEditorChanges(this.form, 'body');\n    }\n\n    ngOnInit() {\n        this.subscriptionId = PermissionService.selectedSubscription?.id;\n        this.route.params.subscribe(params => {\n            this.id = Number(params['id']);\n            this.getMailerTypes();\n            if (!this.id) {\n                this.isLoading = false;\n            }\n        });\n    }\n\n    get f() {\n        return this.form.controls;\n    }\n\n    getMailerDetails() {\n        this.adminService\n            .getMailerById(this.id, this.subscriptionId)\n            .subscribe(response => {\n                this.data = response;\n                const { value } = this.availableMailerTypes.find(\n                    mailer => mailer.label === response.template_name\n                );\n                this.form.patchValue({ ...this.data, template_name: value });\n            })\n            .add(() => {\n                this.isLoading = false;\n            });\n    }\n\n    private getMailerTypes() {\n        this.adminService.getMailerTypes(this.subscriptionId).subscribe(response => {\n            this.availableMailerTypes = Object.entries(response.items).map(([key, value]) => ({\n                label: key,\n                value: value\n            }));\n            this.availableMailerTypes.unshift({\n                label: 'Select',\n                value: null\n            });\n            this.id && this.getMailerDetails();\n        });\n    }\n\n    @ValidateForm('form')\n    onSave() {\n        const rawHtml = HelperService.SaveRawHTML();\n        this.form.controls['body'].setValue(rawHtml);\n        const { label: templateName } = this.availableMailerTypes.find(\n            item => item.value === this.form.value.template_name\n        );\n        this.buttonBusy = true;\n        this.submitted = true;\n        const data = {\n            ...this.form.value,\n            template_name: templateName,\n            subscription_id: this.subscriptionId\n        };\n        const sub$ = this.id\n            ? this.adminService.updateMailer(data, this.id)\n            : this.adminService.addMailer(data);\n        sub$.subscribe({\n            next: _ => {\n                this.id\n                    ? this.toast.success(this.translation.translate('Admin.Mailer.UpdatedMessage'))\n                    : this.toast.success(this.translation.translate('Admin.Mailer.AddedMessage'));\n                this.back();\n            }\n        }).add(() => {\n            this.buttonBusy = false;\n            this.submitted = false;\n        });\n    }\n\n    override ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","<div class=\"container-fluid pw-tab overflow-hidden\">\n  <div class=\"dashboard\">\n    <div class=\"dashboard-body\">\n      <div class=\"me-auto col-xs-6 mt-4\">\n        <a href=\"javascript:void(0)\" [routerLink]=\"[routers.mailerDetails]\" class=\"previous\">\n          <i class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i>\n        </a>\n        <h3 class=\"m-subheader__title m-subheader__title--separator\">\n          <span>Mailer: {{ isLoading ? '' : (data?.id ? \"Edit\" : 'Add New') }}</span>\n        </h3>\n      </div>\n\n    <div class=\"w-100 text-center mt-3\" *ngIf=\"isLoading\">\n      <p-progressSpinner strokeWidth=\"2\"></p-progressSpinner>\n    </div>\n\n    <div class=\"p-2 mt-3\" *ngIf=\"!isLoading\">\n      <form [formGroup]=\"form\" (ngSubmit)=\"onSave()\">\n        <div class=\"row\">\n          <!-- Subject Field -->\n         <!-- Subject Field -->\n<div class=\"col-12 col-md-6\">\n  <pw-input-container [showTooltip]=\"true\" [tooltipText]=\"'Admin.Mailer.Tooltip.Subject' | transloco\"\n    [label]=\"'Label.Subject' | transloco\" class=\"mb-3\" name=\"subject\" [errorMsg]=\"'Admin.Mailer.Validation.Subject' | transloco\">\n    <input type=\"text\" class=\"form-control\" formControlName=\"subject\" [ngClass]=\"{ 'is-invalid': submitted && f['subject'].errors }\" />\n  </pw-input-container>\n</div>\n\n<!-- Body Field -->\n<div class=\"col-12 col-md-6\">\n  <pw-input-container [showTooltip]=\"true\" [tooltipText]=\"'Admin.Mailer.Tooltip.TemplateName' | transloco\"\n  [label]=\"'Label.TemplateName' | transloco\" class=\"mb-3\" name=\"template_name\" [errorMsg]=\"'Admin.Mailer.Validation.TemplateName' | transloco\">\n              <p-dropdown [options]=\"availableMailerTypes\"\n                formControlName=\"template_name\"\n                [style]=\"{ width: '100%' }\"\n                [ngClass]=\"{ 'is-invalid': submitted && f['template_name'].errors }\">\n              </p-dropdown>\n            </pw-input-container>\n</div>\n<pw-input-container  [showTooltip]=\"true\" [tooltipText]=\"'Admin.Mailer.Tooltip.Body' | transloco\"\n[label]=\"'Label.Body' | transloco\" class=\"mb-3\" name=\"body\" [errorMsg]=\"'Admin.Mailer.Validation.Body' | transloco\">\n<quill-editor [styles]=\"{ height: '450px' }\"\n  class=\"quillEditor quill-editor\" [modules]=\"editorConfig\"\n  formControlName=\"body\"\n  [ngClass]=\"{ 'is-invalid': submitted && f['body'].errors, 'quill-container': true  }\">\n</quill-editor>\n</pw-input-container>\n\n          <!-- Form Actions -->\n          <div class=\"col-12 text-end mt-3\">\n            <button type=\"button\" class=\"btn btn-outline-default me-2\" (click)=\"back()\">\n              {{ 'Button.Cancel' | transloco }}\n            </button>\n            <button type=\"submit\" [buttonBusy]=\"buttonBusy\" class=\"btn btn-primary\">\n              {{ 'Button.Submit' | transloco }}\n            </button>\n          </div>\n        </div>\n      </form>\n    </div>\n  </div>\n</div>\n</div>"]}
@@ -7351,8 +7351,8 @@ class AddFaqComponent extends AppBaseComponent {
7351
7351
  this.categoryForBadges = [];
7352
7352
  this.faqHashMap = {};
7353
7353
  this.page = 1;
7354
- // QuillHelper.init();
7355
- // this.editorConfig = QuillHelper.getEditorConfig();
7354
+ QuillHelper.init();
7355
+ this.editorConfig = QuillHelper.getEditorConfig();
7356
7356
  this.form = AppAdmin.getFaqForm();
7357
7357
  }
7358
7358
  ngOnInit() {
@@ -8077,8 +8077,10 @@ class MailerDetailsComponent extends AppBaseComponent {
8077
8077
  this.editorConfig = QuillHelper.getEditorConfig();
8078
8078
  this.form = AppAdmin.getMailerForm();
8079
8079
  }
8080
+ ngAfterViewInit() {
8081
+ HelperService.subscribeToEditorChanges(this.form, 'body');
8082
+ }
8080
8083
  ngOnInit() {
8081
- console.log('In thismhkj,bknm');
8082
8084
  this.subscriptionId = PermissionService.selectedSubscription?.id;
8083
8085
  this.route.params.subscribe(params => {
8084
8086
  this.id = Number(params['id']);