simpo-component-library 3.2.53 → 3.2.55
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/elements/add-section/add-section.component.mjs +2 -2
- package/esm2022/lib/elements/simpo-button/simpo-button.component.mjs +4 -4
- package/esm2022/lib/elements/text-editor/text-editor.component.mjs +3 -3
- package/esm2022/lib/sections/banner-carousel/banner-carousel.component.mjs +4 -4
- package/esm2022/lib/sections/banner-section/banner-section.component.mjs +4 -4
- package/esm2022/lib/sections/carousel-banner/carousel-banner.component.mjs +4 -4
- package/esm2022/lib/sections/faq-section/faq-section.component.mjs +3 -3
- package/esm2022/lib/sections/footer-section/footer-section.component.mjs +4 -4
- package/esm2022/lib/sections/header-section/header-section.component.mjs +3 -3
- package/esm2022/lib/sections/header-text/header-text.component.mjs +4 -4
- package/esm2022/lib/sections/image-section/image-section.component.mjs +4 -4
- package/esm2022/lib/sections/location-section/location-section.component.mjs +4 -4
- package/esm2022/lib/sections/logo-showcase/logo-showcase.component.mjs +4 -4
- package/esm2022/lib/sections/navbar-section/navbar-section.component.mjs +4 -4
- package/esm2022/lib/sections/testimonial-fullwidth/testimonial-fullwidth.component.mjs +8 -6
- package/esm2022/lib/sections/testimonial-section/testimonial-section.component.mjs +4 -4
- package/esm2022/lib/sections/text-image-section/text-image-section.component.mjs +4 -4
- package/esm2022/lib/sections/text-section/text-section.component.mjs +4 -4
- package/fesm2022/simpo-component-library.mjs +39 -38
- package/fesm2022/simpo-component-library.mjs.map +1 -1
- package/lib/directive/background-directive.d.ts +1 -1
- package/lib/directive/button-directive.directive.d.ts +1 -1
- package/lib/directive/color.directive.d.ts +1 -1
- package/lib/ecommerce/sections/authentication-required/authentication-required.component.d.ts +1 -1
- package/lib/sections/banner-carousel/banner-carousel.component.d.ts +2 -2
- package/lib/sections/carousel-banner/carousel-banner.component.d.ts +1 -1
- package/lib/sections/image-section/image-section.component.d.ts +2 -2
- package/lib/sections/logo-showcase/logo-showcase.component.d.ts +1 -1
- package/lib/sections/pricing-section/pricing-section.component.d.ts +1 -1
- package/package.json +1 -1
- package/simpo-component-library-3.2.55.tgz +0 -0
- package/simpo-component-library-3.2.53.tgz +0 -0
@@ -54,7 +54,7 @@ export class AddSectionComponent {
|
|
54
54
|
}
|
55
55
|
getAllSections() {
|
56
56
|
this.loader = true;
|
57
|
-
this.editorService.getComponentApi(this.businessType === '
|
57
|
+
this.editorService.getComponentApi(this.businessType === 'STATIC' ? this.businessType : undefined).subscribe((res) => {
|
58
58
|
this.sections = res.data;
|
59
59
|
this.dummySections = res.data;
|
60
60
|
this.selectedSectionName = Object.keys(this.sections)[0];
|
@@ -113,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImpor
|
|
113
113
|
type: Inject,
|
114
114
|
args: [MAT_DIALOG_DATA]
|
115
115
|
}] }, { type: i2.HttpClient }, { type: i3.EventsService }, { type: i4.ElementServiceService }, { type: i4.ElementServiceService }] });
|
116
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-section.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/elements/add-section/add-section.component.ts","../../../../../../projects/simpo-ui/src/lib/elements/add-section/add-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, Inject, NgModule } from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { EventsService } from '../../services/events.service';\r\nimport { ElementServiceService } from '../editor-service.service';\r\nimport { NgxSkeletonLoaderModule } from 'ngx-skeleton-loader';\r\nimport { FormControl, FormsModule, NgModel } from '@angular/forms';\r\nimport { debounceTime, distinctUntilChanged, startWith, switchMap } from 'rxjs';\r\n// import { RestService } from '@simpo-ui/services/rest.service';\r\n\r\n@Component({\r\n  selector: 'simpo-add-section',\r\n  standalone: true,\r\n  imports: [CommonModule, MatIconModule, NgxSkeletonLoaderModule, FormsModule],\r\n  templateUrl: './add-section.component.html',\r\n  styleUrl: './add-section.component.css'\r\n})\r\nexport class AddSectionComponent {\r\n\r\n  constructor(public dialog: MatDialogRef<AddSectionComponent>,\r\n    @Inject(MAT_DIALOG_DATA) public data: any,\r\n    private http: HttpClient,\r\n    private _eventService: EventsService,\r\n    private editorService: ElementServiceService,\r\n    // private  restService : RestService,\r\n    private elementService: ElementServiceService\r\n  ) {\r\n\r\n  }\r\n\r\n  businessType: 'STATIC' | 'E_COMMERCE' = 'STATIC';\r\n  ngOnInit() {\r\n    const business = localStorage.getItem('bDetails') || '';\r\n    this.businessType = business ? JSON.parse(business)?.type : 'STATIC'\r\n    this.getAllSections();\r\n  }\r\n\r\n  selectedTab: string = \"BASIC\"\r\n  tabs: any = [{ value: \"BASIC\", viewValue: \"Basic\" },\r\n  { value: \"INTEGRATIONS\", viewValue: \"Integrations\" },\r\n  { value: \"PRO\", viewValue: \"Pro\" }\r\n  ]\r\n\r\n\r\n  sections: any = []\r\n  selectedSection: any = this.sections[0]\r\n  selectedSectionName: any = \"\"\r\n  loader: boolean = false\r\n  tabShiftLoader: boolean = false\r\n  // searchControl = new FormControl('');\r\n\r\n  selectSection(ele: any) {\r\n    this.tabShiftLoader = true\r\n    this.selectedSection = this.sections[ele];\r\n    this.selectedSectionName = ele;\r\n    setTimeout(() => {\r\n      this.tabShiftLoader = false\r\n    }, 800);\r\n  }\r\n\r\n  getAllSections() {\r\n    this.loader = true\r\n    this.editorService.getComponentApi(this.businessType === 'E_COMMERCE' ? this.businessType : undefined).subscribe(\r\n      (res: any) => {\r\n        this.sections = res.data\r\n        this.dummySections = res.data\r\n        this.selectedSectionName = Object.keys(this.sections)[0]\r\n        this.selectedSection = this.sections[Object.keys(this.sections)[0]]\r\n        this.loader = false\r\n      }\r\n    )\r\n  }\r\n\r\n  getObjectKeys(obj: any): any[] {\r\n    return obj ? Object.keys(obj) : [];\r\n  }\r\n\r\n  addNewSection(componentId: any, sectionType: any, event: any) {\r\n    this._eventService.addNewSectionClick.emit({ componentId: componentId, index: this.data.index, position: this.data.position, status: true, sectionType: sectionType });\r\n    this.dialog.close();\r\n    event.stopPropagation();\r\n  }\r\n\r\n  searchText: string = \"\"\r\n  dummySections: any\r\n  dummy2: any = {}\r\n\r\n  // searchSectionComponents(){\r\n  //   this.searchControl.valueChanges\r\n  //   .pipe(\r\n  //     debounceTime(500),\r\n  //     distinctUntilChanged()\r\n  //   )\r\n  //   .subscribe(value => {\r\n  //     this.searchSections(value);\r\n  //   });\r\n  // }\r\n\r\n\r\n\r\n  searchSections() {\r\n    if (this.searchText.length == 0)\r\n      this.sections = this.dummySections\r\n    for (let ele of Object.keys(this.dummySections)) {\r\n      if (ele.toLowerCase().includes(this.searchText)) {\r\n        this.dummy2[ele] = [...this.dummySections[ele]];\r\n      }\r\n      else {\r\n        for (let j of this.dummySections[ele]) {\r\n          if (j.sectionName.toLowerCase().includes(this.searchText)) {\r\n            if (!this.dummy2[ele]) {\r\n              this.dummy2[ele] = [];\r\n            }\r\n            this.dummy2[ele].push(j)\r\n          }\r\n        }\r\n      }\r\n    }\r\n    this.sections = { ...this.dummy2 };\r\n    this.selectedSectionName = Object.keys(this.sections)[0]\r\n    this.selectedSection = this.sections[Object.keys(this.sections)[0]]\r\n    this.dummy2 = {}\r\n  }\r\n\r\n}\r\n","<section class=\"main-container\">\r\n    <div class=\"header-container d-flex align-items-center justify-content-between\">\r\n        <div>Select Template</div>\r\n        <mat-icon class=\"d-flex align-items-center justify-content-center f-18 cp\" (click)=\"dialog.close()\">\r\n            close\r\n        </mat-icon>\r\n    </div>\r\n    <div class=\"parent-container\">\r\n        <div class=\"search-bar-container\">\r\n            <div class=\"search-bar d-flex gap-10\">\r\n                <img src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/314661c1741844234442Vector%20%281%29.png\"\r\n                    alt=\"search-bar-icon\">\r\n                <input type=\"text\" placeholder=\"Search for Sections\" [(ngModel)]=\"searchText\" (ngModelChange)=\"searchSections()\">\r\n            </div>\r\n        </div>\r\n        <div class=\"tab-container d-flex justify-content-around align-items-center\">\r\n            <ng-container *ngFor=\"let ele of tabs\">\r\n                <div class=\"tabs\" (click)=\"selectedTab = ele.value\" [class.active-tab]=\"ele.value == selectedTab\">\r\n                    {{ele.viewValue}}\r\n                    <ng-container *ngIf=\"ele.value == 'PRO' && ele.value != selectedTab\">\r\n                        <img class=\"w-30\"\r\n                            src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/887493c1742273970151Frame%201244831740.png\"\r\n                            alt=\"pro-icon\">\r\n                    </ng-container>\r\n                </div>\r\n            </ng-container>\r\n        </div>\r\n        <div class=\"categories-container d-flex\">\r\n            <div class=\"categories-sidepanel\" *ngIf=\"!loader\">\r\n                <ng-container *ngFor=\"let ele of getObjectKeys(sections)\">\r\n                    <div class=\"side-section d-flex justify-content-center align-items-center flex-column\"\r\n                        (click)=\"selectSection(ele)\"\r\n                        [class.active-section]=\"selectedSection == sections[ele]\">\r\n                        <div class=\"image-container\">\r\n                            <ng-container *ngIf=\"selectedSection == sections[ele]\">\r\n                                <img src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/954383c1741850392802Group%201707481879.png\"\r\n                                    alt=\"icon text\">\r\n                            </ng-container>\r\n                            <ng-container *ngIf=\"selectedSection != sections[ele]\">\r\n                                <img src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/846145c1741850574864Icon%20%281%29.png\"\r\n                                    alt=\"icon text\">\r\n                            </ng-container>\r\n                        </div>\r\n                        <div class=\"section-text\">\r\n                            {{ele}}\r\n                        </div>\r\n                    </div>\r\n                </ng-container>\r\n            </div>\r\n            <div class=\"categories-render-section\" *ngIf=\" !loader && !tabShiftLoader\">\r\n                <div class=\"categories-head\">\r\n                    {{selectedSectionName}}\r\n                </div>\r\n                <div class=\"sub-text\">\r\n                    Select a section to add to your page\r\n                </div>\r\n                <div class=\"sections-container\">\r\n                    <ng-container *ngFor=\"let ele of selectedSection\">\r\n                        <div class=\"section\">\r\n                            <div class=\"section-header\">{{ele.sectionName}}</div>\r\n                            <div class=\"section-img-container cp\"\r\n                                (click)=\"addNewSection(ele.componentId,ele.sectionType,$event)\">\r\n                                <ng-container *ngIf=\"ele?.image; else noImage\">\r\n                                    <img [src]=\"ele?.image\" alt=\"section image\">\r\n                                </ng-container>\r\n                                <ng-template #noImage>\r\n                                    <img src=\"https://img.freepik.com/premium-vector/default-image-icon-vector-missing-picture-page-website-design-mobile-app-no-photo-available_87543-11093.jpg\"\r\n                                        alt=\"section image\" class=\"h-30\">\r\n                                </ng-template>\r\n                            </div>\r\n                        </div>\r\n                    </ng-container>\r\n                </div>\r\n            </div>\r\n            <div class=\"categories-sidepanel\" *ngIf=\"loader\">\r\n                <ng-container *ngFor=\"let ele of [1,1,1,1,1,1,1,1,1]\">\r\n                    <div class=\"d-flex justify-content-center align-items-center flex-column\">\r\n                        <ngx-skeleton-loader appearance=\"circle\" [theme]=\"{\r\n                            height: '8vh',\r\n                            width: '65%',\r\n                            'border-radius': '13px',\r\n                            'margin-bottom' : '10px',\r\n                          }\" class=\"d-flex justify-content-center w-100\">\r\n                        </ngx-skeleton-loader>\r\n                    </div>\r\n                </ng-container>\r\n            </div>\r\n            <div class=\"categories-render-section\" *ngIf=\"loader || tabShiftLoader\">\r\n                <div class=\"categories-head\">\r\n                    <ngx-skeleton-loader appearance=\"circle\" [theme]=\"{\r\n                        width: '20%',\r\n                        height : '3vh',\r\n                        'border-radius': '5px',\r\n                      }\">\r\n                    </ngx-skeleton-loader>\r\n                </div>\r\n                <div class=\"sub-text\">\r\n                    <ngx-skeleton-loader appearance=\"circle\" [theme]=\"{\r\n                        width: '60%',\r\n                        height : '2vh',\r\n                        'border-radius': '5px',\r\n                      }\">\r\n                    </ngx-skeleton-loader>\r\n                </div>\r\n                <div class=\"sections-container\">\r\n                    <ng-container *ngFor=\"let ele of [1,1,1,1]\">\r\n                        <div class=\"section\">\r\n                            <div>   <ngx-skeleton-loader appearance=\"circle\" [theme]=\"{\r\n                                width: '25%',\r\n                                height : '2vh',\r\n                                'border-radius': '5px',\r\n                              }\">\r\n                            </ngx-skeleton-loader></div>\r\n                            <div>\r\n                                <ngx-skeleton-loader [theme]=\"{\r\n                                    width: '100%',\r\n                                    height : '25vh',\r\n                                    'border-radius': '5px',\r\n                                    'margin':'2px'\r\n                                  }\">\r\n                                </ngx-skeleton-loader>\r\n                            </div>\r\n                        </div>\r\n                    </ng-container>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</section>"]}
|
116
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-section.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/elements/add-section/add-section.component.ts","../../../../../../projects/simpo-ui/src/lib/elements/add-section/add-section.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,MAAM,EAAY,MAAM,eAAe,CAAC;AAC5D,OAAO,EAAE,eAAe,EAAgB,MAAM,0BAA0B,CAAC;AACzE,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAIvD,OAAO,EAAE,uBAAuB,EAAE,MAAM,qBAAqB,CAAC;AAC9D,OAAO,EAAe,WAAW,EAAW,MAAM,gBAAgB,CAAC;;;;;;;;;;AAEnE,iEAAiE;AASjE,MAAM,OAAO,mBAAmB;IAE9B,YAAmB,MAAyC,EAC1B,IAAS,EACjC,IAAgB,EAChB,aAA4B,EAC5B,aAAoC;IAC5C,sCAAsC;IAC9B,cAAqC;QAN5B,WAAM,GAAN,MAAM,CAAmC;QAC1B,SAAI,GAAJ,IAAI,CAAK;QACjC,SAAI,GAAJ,IAAI,CAAY;QAChB,kBAAa,GAAb,aAAa,CAAe;QAC5B,kBAAa,GAAb,aAAa,CAAuB;QAEpC,mBAAc,GAAd,cAAc,CAAuB;QAK/C,iBAAY,GAA4B,QAAQ,CAAC;QAOjD,gBAAW,GAAW,OAAO,CAAA;QAC7B,SAAI,GAAQ,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE;YACnD,EAAE,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,cAAc,EAAE;YACpD,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE;SACjC,CAAA;QAGD,aAAQ,GAAQ,EAAE,CAAA;QAClB,oBAAe,GAAQ,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAA;QACvC,wBAAmB,GAAQ,EAAE,CAAA;QAC7B,WAAM,GAAY,KAAK,CAAA;QACvB,mBAAc,GAAY,KAAK,CAAA;QAmC/B,eAAU,GAAW,EAAE,CAAA;QAEvB,WAAM,GAAQ,EAAE,CAAA;IAzDhB,CAAC;IAGD,QAAQ;QACN,MAAM,QAAQ,GAAG,YAAY,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;QACxD,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAA;QACpE,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAcD,uCAAuC;IAEvC,aAAa,CAAC,GAAQ;QACpB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAA;QAC1B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QAC1C,IAAI,CAAC,mBAAmB,GAAG,GAAG,CAAC;QAC/B,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,cAAc,GAAG,KAAK,CAAA;QAC7B,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,MAAM,GAAG,IAAI,CAAA;QAClB,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,IAAI,CAAC,YAAY,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,SAAS,CAC1G,CAAC,GAAQ,EAAE,EAAE;YACX,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAC,IAAI,CAAA;YACxB,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC,IAAI,CAAA;YAC7B,IAAI,CAAC,mBAAmB,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAA;YACxD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;YACnE,IAAI,CAAC,MAAM,GAAG,KAAK,CAAA;QACrB,CAAC,CACF,CAAA;IACH,CAAC;IAED,aAAa,CAAC,GAAQ;QACpB,OAAO,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IACrC,CAAC;IAED,aAAa,CAAC,WAAgB,EAAE,WAAgB,EAAE,KAAU;QAC1D,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,IAAI,CAAC,EAAE,WAAW,EAAE,WAAW,EAAE,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,WAAW,EAAE,CAAC,CAAC;QACvK,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;QACpB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC1B,CAAC;IAMD,6BAA6B;IAC7B,oCAAoC;IACpC,WAAW;IACX,yBAAyB;IACzB,6BAA6B;IAC7B,MAAM;IACN,0BAA0B;IAC1B,kCAAkC;IAClC,QAAQ;IACR,IAAI;IAIJ,cAAc;QACZ,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,IAAI,CAAC;YAC7B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAA;QACpC,KAAK,IAAI,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC;YAChD,IAAI,GAAG,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;gBAChD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC;YAClD,CAAC;iBACI,CAAC;gBACJ,KAAK,IAAI,CAAC,IAAI,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC;oBACtC,IAAI,CAAC,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;wBAC1D,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC;4BACtB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC;wBACxB,CAAC;wBACD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;oBAC1B,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC;QACD,IAAI,CAAC,QAAQ,GAAG,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QACnC,IAAI,CAAC,mBAAmB,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAA;QACxD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;QACnE,IAAI,CAAC,MAAM,GAAG,EAAE,CAAA;IAClB,CAAC;8GAzGU,mBAAmB,8CAGpB,eAAe;kGAHd,mBAAmB,6ECnBhC,krOAgIU,q0EDjHE,YAAY,+PAAE,aAAa,mLAAE,uBAAuB,8MAAE,WAAW;;2FAIhE,mBAAmB;kBAP/B,SAAS;+BACE,mBAAmB,cACjB,IAAI,WACP,CAAC,YAAY,EAAE,aAAa,EAAE,uBAAuB,EAAE,WAAW,CAAC;;0BAOzE,MAAM;2BAAC,eAAe","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, Inject, NgModule } from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { HttpClient } from '@angular/common/http';\r\nimport { EventsService } from '../../services/events.service';\r\nimport { ElementServiceService } from '../editor-service.service';\r\nimport { NgxSkeletonLoaderModule } from 'ngx-skeleton-loader';\r\nimport { FormControl, FormsModule, NgModel } from '@angular/forms';\r\nimport { debounceTime, distinctUntilChanged, startWith, switchMap } from 'rxjs';\r\n// import { RestService } from '@simpo-ui/services/rest.service';\r\n\r\n@Component({\r\n  selector: 'simpo-add-section',\r\n  standalone: true,\r\n  imports: [CommonModule, MatIconModule, NgxSkeletonLoaderModule, FormsModule],\r\n  templateUrl: './add-section.component.html',\r\n  styleUrl: './add-section.component.css'\r\n})\r\nexport class AddSectionComponent {\r\n\r\n  constructor(public dialog: MatDialogRef<AddSectionComponent>,\r\n    @Inject(MAT_DIALOG_DATA) public data: any,\r\n    private http: HttpClient,\r\n    private _eventService: EventsService,\r\n    private editorService: ElementServiceService,\r\n    // private  restService : RestService,\r\n    private elementService: ElementServiceService\r\n  ) {\r\n\r\n  }\r\n\r\n  businessType: 'STATIC' | 'E_COMMERCE' = 'STATIC';\r\n  ngOnInit() {\r\n    const business = localStorage.getItem('bDetails') || '';\r\n    this.businessType = business ? JSON.parse(business)?.type : 'STATIC'\r\n    this.getAllSections();\r\n  }\r\n\r\n  selectedTab: string = \"BASIC\"\r\n  tabs: any = [{ value: \"BASIC\", viewValue: \"Basic\" },\r\n  { value: \"INTEGRATIONS\", viewValue: \"Integrations\" },\r\n  { value: \"PRO\", viewValue: \"Pro\" }\r\n  ]\r\n\r\n\r\n  sections: any = []\r\n  selectedSection: any = this.sections[0]\r\n  selectedSectionName: any = \"\"\r\n  loader: boolean = false\r\n  tabShiftLoader: boolean = false\r\n  // searchControl = new FormControl('');\r\n\r\n  selectSection(ele: any) {\r\n    this.tabShiftLoader = true\r\n    this.selectedSection = this.sections[ele];\r\n    this.selectedSectionName = ele;\r\n    setTimeout(() => {\r\n      this.tabShiftLoader = false\r\n    }, 800);\r\n  }\r\n\r\n  getAllSections() {\r\n    this.loader = true\r\n    this.editorService.getComponentApi(this.businessType === 'STATIC' ? this.businessType : undefined).subscribe(\r\n      (res: any) => {\r\n        this.sections = res.data\r\n        this.dummySections = res.data\r\n        this.selectedSectionName = Object.keys(this.sections)[0]\r\n        this.selectedSection = this.sections[Object.keys(this.sections)[0]]\r\n        this.loader = false\r\n      }\r\n    )\r\n  }\r\n\r\n  getObjectKeys(obj: any): any[] {\r\n    return obj ? Object.keys(obj) : [];\r\n  }\r\n\r\n  addNewSection(componentId: any, sectionType: any, event: any) {\r\n    this._eventService.addNewSectionClick.emit({ componentId: componentId, index: this.data.index, position: this.data.position, status: true, sectionType: sectionType });\r\n    this.dialog.close();\r\n    event.stopPropagation();\r\n  }\r\n\r\n  searchText: string = \"\"\r\n  dummySections: any\r\n  dummy2: any = {}\r\n\r\n  // searchSectionComponents(){\r\n  //   this.searchControl.valueChanges\r\n  //   .pipe(\r\n  //     debounceTime(500),\r\n  //     distinctUntilChanged()\r\n  //   )\r\n  //   .subscribe(value => {\r\n  //     this.searchSections(value);\r\n  //   });\r\n  // }\r\n\r\n\r\n\r\n  searchSections() {\r\n    if (this.searchText.length == 0)\r\n      this.sections = this.dummySections\r\n    for (let ele of Object.keys(this.dummySections)) {\r\n      if (ele.toLowerCase().includes(this.searchText)) {\r\n        this.dummy2[ele] = [...this.dummySections[ele]];\r\n      }\r\n      else {\r\n        for (let j of this.dummySections[ele]) {\r\n          if (j.sectionName.toLowerCase().includes(this.searchText)) {\r\n            if (!this.dummy2[ele]) {\r\n              this.dummy2[ele] = [];\r\n            }\r\n            this.dummy2[ele].push(j)\r\n          }\r\n        }\r\n      }\r\n    }\r\n    this.sections = { ...this.dummy2 };\r\n    this.selectedSectionName = Object.keys(this.sections)[0]\r\n    this.selectedSection = this.sections[Object.keys(this.sections)[0]]\r\n    this.dummy2 = {}\r\n  }\r\n\r\n}\r\n","<section class=\"main-container\">\r\n    <div class=\"header-container d-flex align-items-center justify-content-between\">\r\n        <div>Select Template</div>\r\n        <mat-icon class=\"d-flex align-items-center justify-content-center f-18 cp\" (click)=\"dialog.close()\">\r\n            close\r\n        </mat-icon>\r\n    </div>\r\n    <div class=\"parent-container\">\r\n        <div class=\"search-bar-container\">\r\n            <div class=\"search-bar d-flex gap-10\">\r\n                <img src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/314661c1741844234442Vector%20%281%29.png\"\r\n                    alt=\"search-bar-icon\">\r\n                <input type=\"text\" placeholder=\"Search for Sections\" [(ngModel)]=\"searchText\" (ngModelChange)=\"searchSections()\">\r\n            </div>\r\n        </div>\r\n        <div class=\"tab-container d-flex justify-content-around align-items-center\">\r\n            <ng-container *ngFor=\"let ele of tabs\">\r\n                <div class=\"tabs\" (click)=\"selectedTab = ele.value\" [class.active-tab]=\"ele.value == selectedTab\">\r\n                    {{ele.viewValue}}\r\n                    <ng-container *ngIf=\"ele.value == 'PRO' && ele.value != selectedTab\">\r\n                        <img class=\"w-30\"\r\n                            src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/887493c1742273970151Frame%201244831740.png\"\r\n                            alt=\"pro-icon\">\r\n                    </ng-container>\r\n                </div>\r\n            </ng-container>\r\n        </div>\r\n        <div class=\"categories-container d-flex\">\r\n            <div class=\"categories-sidepanel\" *ngIf=\"!loader\">\r\n                <ng-container *ngFor=\"let ele of getObjectKeys(sections)\">\r\n                    <div class=\"side-section d-flex justify-content-center align-items-center flex-column\"\r\n                        (click)=\"selectSection(ele)\"\r\n                        [class.active-section]=\"selectedSection == sections[ele]\">\r\n                        <div class=\"image-container\">\r\n                            <ng-container *ngIf=\"selectedSection == sections[ele]\">\r\n                                <img src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/954383c1741850392802Group%201707481879.png\"\r\n                                    alt=\"icon text\">\r\n                            </ng-container>\r\n                            <ng-container *ngIf=\"selectedSection != sections[ele]\">\r\n                                <img src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/846145c1741850574864Icon%20%281%29.png\"\r\n                                    alt=\"icon text\">\r\n                            </ng-container>\r\n                        </div>\r\n                        <div class=\"section-text\">\r\n                            {{ele}}\r\n                        </div>\r\n                    </div>\r\n                </ng-container>\r\n            </div>\r\n            <div class=\"categories-render-section\" *ngIf=\" !loader && !tabShiftLoader\">\r\n                <div class=\"categories-head\">\r\n                    {{selectedSectionName}}\r\n                </div>\r\n                <div class=\"sub-text\">\r\n                    Select a section to add to your page\r\n                </div>\r\n                <div class=\"sections-container\">\r\n                    <ng-container *ngFor=\"let ele of selectedSection\">\r\n                        <div class=\"section\">\r\n                            <div class=\"section-header\">{{ele.sectionName}}</div>\r\n                            <div class=\"section-img-container cp\"\r\n                                (click)=\"addNewSection(ele.componentId,ele.sectionType,$event)\">\r\n                                <ng-container *ngIf=\"ele?.image; else noImage\">\r\n                                    <img [src]=\"ele?.image\" alt=\"section image\">\r\n                                </ng-container>\r\n                                <ng-template #noImage>\r\n                                    <img src=\"https://img.freepik.com/premium-vector/default-image-icon-vector-missing-picture-page-website-design-mobile-app-no-photo-available_87543-11093.jpg\"\r\n                                        alt=\"section image\" class=\"h-30\">\r\n                                </ng-template>\r\n                            </div>\r\n                        </div>\r\n                    </ng-container>\r\n                </div>\r\n            </div>\r\n            <div class=\"categories-sidepanel\" *ngIf=\"loader\">\r\n                <ng-container *ngFor=\"let ele of [1,1,1,1,1,1,1,1,1]\">\r\n                    <div class=\"d-flex justify-content-center align-items-center flex-column\">\r\n                        <ngx-skeleton-loader appearance=\"circle\" [theme]=\"{\r\n                            height: '8vh',\r\n                            width: '65%',\r\n                            'border-radius': '13px',\r\n                            'margin-bottom' : '10px',\r\n                          }\" class=\"d-flex justify-content-center w-100\">\r\n                        </ngx-skeleton-loader>\r\n                    </div>\r\n                </ng-container>\r\n            </div>\r\n            <div class=\"categories-render-section\" *ngIf=\"loader || tabShiftLoader\">\r\n                <div class=\"categories-head\">\r\n                    <ngx-skeleton-loader appearance=\"circle\" [theme]=\"{\r\n                        width: '20%',\r\n                        height : '3vh',\r\n                        'border-radius': '5px',\r\n                      }\">\r\n                    </ngx-skeleton-loader>\r\n                </div>\r\n                <div class=\"sub-text\">\r\n                    <ngx-skeleton-loader appearance=\"circle\" [theme]=\"{\r\n                        width: '60%',\r\n                        height : '2vh',\r\n                        'border-radius': '5px',\r\n                      }\">\r\n                    </ngx-skeleton-loader>\r\n                </div>\r\n                <div class=\"sections-container\">\r\n                    <ng-container *ngFor=\"let ele of [1,1,1,1]\">\r\n                        <div class=\"section\">\r\n                            <div>   <ngx-skeleton-loader appearance=\"circle\" [theme]=\"{\r\n                                width: '25%',\r\n                                height : '2vh',\r\n                                'border-radius': '5px',\r\n                              }\">\r\n                            </ngx-skeleton-loader></div>\r\n                            <div>\r\n                                <ngx-skeleton-loader [theme]=\"{\r\n                                    width: '100%',\r\n                                    height : '25vh',\r\n                                    'border-radius': '5px',\r\n                                    'margin':'2px'\r\n                                  }\">\r\n                                </ngx-skeleton-loader>\r\n                            </div>\r\n                        </div>\r\n                    </ng-container>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</section>"]}
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import {
|
1
|
+
import { Component, Input } from '@angular/core';
|
2
2
|
import { ButtonDirectiveDirective } from '../..//directive/button-directive.directive';
|
3
3
|
import { ButtonEditorDirective } from '../../directive/button-editor.directive';
|
4
4
|
import * as i0 from "@angular/core";
|
@@ -18,11 +18,11 @@ export class SimpoButtonComponent {
|
|
18
18
|
this._eventService.buttonRedirection.emit({ data: this.buttonContent });
|
19
19
|
}
|
20
20
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: SimpoButtonComponent, deps: [{ token: i1.EventsService }], target: i0.ɵɵFactoryTarget.Component }); }
|
21
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: SimpoButtonComponent, isStandalone: true, selector: "app-button-element", inputs: { buttonContent: "buttonContent", buttonStyle: "buttonStyle", buttonId: "buttonId", color: "color", sectionId: "sectionId", edit: "edit" }, ngImport: i0, template: "<button class=\"button\" (click)=\"redirectTo()\" simpoButtonDirective [id]=\"sectionId+buttonId\" [buttonStyle]=\"buttonStyle\" [color]=\"color\" [appButtonEditor]=\"edit ?? false\" [buttonData]=\"buttonContent\">{{buttonContent?.label}}</button>\r\n", styles: [".button{font-size:14px!important;padding:8px 20px;display:inline-flex;align-items:center;justify-content:center;width:max-content!important;font-weight:600}\n"], dependencies: [{ kind: "directive", type: ButtonDirectiveDirective, selector: "[simpoButtonDirective]", inputs: ["buttonStyle", "color", "scrollValue"] }, { kind: "directive", type: ButtonEditorDirective, selector: "button[appButtonEditor]", inputs: ["appButtonEditor", "buttonData"] }]
|
21
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: SimpoButtonComponent, isStandalone: true, selector: "app-button-element", inputs: { buttonContent: "buttonContent", buttonStyle: "buttonStyle", buttonId: "buttonId", color: "color", sectionId: "sectionId", edit: "edit" }, ngImport: i0, template: "<button class=\"button\" (click)=\"redirectTo()\" simpoButtonDirective [id]=\"sectionId+buttonId\" [buttonStyle]=\"buttonStyle\" [color]=\"color\" [appButtonEditor]=\"edit ?? false\" [buttonData]=\"buttonContent\">{{buttonContent?.label}}</button>\r\n", styles: [".button{font-size:14px!important;padding:8px 20px;display:inline-flex;align-items:center;justify-content:center;width:max-content!important;font-weight:600}\n"], dependencies: [{ kind: "directive", type: ButtonDirectiveDirective, selector: "[simpoButtonDirective]", inputs: ["buttonStyle", "color", "scrollValue"] }, { kind: "directive", type: ButtonEditorDirective, selector: "button[appButtonEditor]", inputs: ["appButtonEditor", "buttonData"] }] }); }
|
22
22
|
}
|
23
23
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: SimpoButtonComponent, decorators: [{
|
24
24
|
type: Component,
|
25
|
-
args: [{ selector: 'app-button-element', standalone: true, imports: [ButtonDirectiveDirective, ButtonEditorDirective],
|
25
|
+
args: [{ selector: 'app-button-element', standalone: true, imports: [ButtonDirectiveDirective, ButtonEditorDirective], template: "<button class=\"button\" (click)=\"redirectTo()\" simpoButtonDirective [id]=\"sectionId+buttonId\" [buttonStyle]=\"buttonStyle\" [color]=\"color\" [appButtonEditor]=\"edit ?? false\" [buttonData]=\"buttonContent\">{{buttonContent?.label}}</button>\r\n", styles: [".button{font-size:14px!important;padding:8px 20px;display:inline-flex;align-items:center;justify-content:center;width:max-content!important;font-weight:600}\n"] }]
|
26
26
|
}], ctorParameters: () => [{ type: i1.EventsService }], propDecorators: { buttonContent: [{
|
27
27
|
type: Input
|
28
28
|
}], buttonStyle: [{
|
@@ -36,4 +36,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImpor
|
|
36
36
|
}], edit: [{
|
37
37
|
type: Input
|
38
38
|
}] } });
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2ltcG8tYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NpbXBvLXVpL3NyYy9saWIvZWxlbWVudHMvc2ltcG8tYnV0dG9uL3NpbXBvLWJ1dHRvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaW1wby11aS9zcmMvbGliL2VsZW1lbnRzL3NpbXBvLWJ1dHRvbi9zaW1wby1idXR0b24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFHdkYsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUNBQXlDLENBQUM7OztBQVNoRixNQUFNLE9BQU8sb0JBQW9CO0lBUy9CLFlBQW9CLGFBQTRCO1FBQTVCLGtCQUFhLEdBQWIsYUFBYSxDQUFlO1FBTnZDLGFBQVEsR0FBWSxFQUFFLENBQUM7UUFFdkIsY0FBUyxHQUFhLEVBQUUsQ0FBQztRQUN6QixTQUFJLEdBQWEsS0FBSyxDQUFDO0lBR2tCLENBQUM7SUFFbkQsUUFBUTtJQUNSLENBQUM7SUFFRCxVQUFVO1FBQ1IsSUFBRyxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxjQUFjO1lBQ25FLE9BQU87UUFDVCxJQUFJLENBQUMsYUFBYSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxFQUFDLElBQUksRUFBRSxJQUFJLENBQUMsYUFBYSxFQUFDLENBQUMsQ0FBQztJQUN4RSxDQUFDOzhHQWxCVSxvQkFBb0I7a0dBQXBCLG9CQUFvQixrT0NiakMsNlBBQ0Esd05EUVksd0JBQXdCLG9IQUFFLHFCQUFxQjs7MkZBSTlDLG9CQUFvQjtrQkFQaEMsU0FBUzsrQkFDRSxvQkFBb0IsY0FDbEIsSUFBSSxXQUNQLENBQUMsd0JBQXdCLEVBQUUscUJBQXFCLENBQUM7a0ZBS2pELGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQnV0dG9uRGlyZWN0aXZlRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vL2RpcmVjdGl2ZS9idXR0b24tZGlyZWN0aXZlLmRpcmVjdGl2ZSc7XHJcbmltcG9ydCB7IEJ1dHRvbiwgQnV0dG9uU3R5bGVNb2RlbCB9IGZyb20gJy4uLy4uL3N0eWxlcy9zdHlsZS5tb2RlbCc7XHJcbmltcG9ydCB7IEV2ZW50c1NlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9ldmVudHMuc2VydmljZSc7XHJcbmltcG9ydCB7IEJ1dHRvbkVkaXRvckRpcmVjdGl2ZSB9IGZyb20gJy4uLy4uL2RpcmVjdGl2ZS9idXR0b24tZWRpdG9yLmRpcmVjdGl2ZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2FwcC1idXR0b24tZWxlbWVudCcsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBpbXBvcnRzOiBbQnV0dG9uRGlyZWN0aXZlRGlyZWN0aXZlLCBCdXR0b25FZGl0b3JEaXJlY3RpdmVdLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9zaW1wby1idXR0b24uY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsOiAnLi9zaW1wby1idXR0b24uY29tcG9uZW50LmNzcydcclxufSlcclxuZXhwb3J0IGNsYXNzIFNpbXBvQnV0dG9uQ29tcG9uZW50IHtcclxuICBASW5wdXQoKSBidXR0b25Db250ZW50PyA6IEJ1dHRvbjtcclxuICBASW5wdXQoKSBidXR0b25TdHlsZT8gOiBCdXR0b25TdHlsZU1vZGVsO1xyXG4gIEBJbnB1dCgpIGJ1dHRvbklkIDogc3RyaW5nID0gJyc7XHJcbiAgQElucHV0KCkgY29sb3I/IDogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIHNlY3Rpb25JZD8gOiBzdHJpbmcgPSAnJztcclxuICBASW5wdXQoKSBlZGl0PzogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBfZXZlbnRTZXJ2aWNlOiBFdmVudHNTZXJ2aWNlKXt9XHJcblxyXG4gIG5nT25Jbml0KCl7XHJcbiAgfVxyXG5cclxuICByZWRpcmVjdFRvKCl7XHJcbiAgICBpZighdGhpcy5idXR0b25Db250ZW50Py5wYWdlSWQgJiYgIXRoaXMuYnV0dG9uQ29udGVudD8ucmVkaXJlY3Rpb25VcmwpXHJcbiAgICAgIHJldHVybjtcclxuICAgIHRoaXMuX2V2ZW50U2VydmljZS5idXR0b25SZWRpcmVjdGlvbi5lbWl0KHtkYXRhOiB0aGlzLmJ1dHRvbkNvbnRlbnR9KTtcclxuICB9XHJcbn1cclxuIiwiPGJ1dHRvbiBjbGFzcz1cImJ1dHRvblwiIChjbGljayk9XCJyZWRpcmVjdFRvKClcIiBzaW1wb0J1dHRvbkRpcmVjdGl2ZSBbaWRdPVwic2VjdGlvbklkK2J1dHRvbklkXCIgW2J1dHRvblN0eWxlXT1cImJ1dHRvblN0eWxlXCIgW2NvbG9yXT1cImNvbG9yXCIgW2FwcEJ1dHRvbkVkaXRvcl09XCJlZGl0ID8/IGZhbHNlXCIgW2J1dHRvbkRhdGFdPVwiYnV0dG9uQ29udGVudFwiPnt7YnV0dG9uQ29udGVudD8ubGFiZWx9fTwvYnV0dG9uPlxyXG4iXX0=
|
@@ -225,7 +225,7 @@ export class TextEditorComponent {
|
|
225
225
|
});
|
226
226
|
}
|
227
227
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: TextEditorComponent, deps: [{ token: i1.ElementServiceService }, { token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Component }); }
|
228
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: TextEditorComponent, isStandalone: true, selector: "simpo-text-editor", inputs: { value: "value", editable: "editable", sectionId: "sectionId", label: "label" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "toolbar", first: true, predicate: ["toolbar"], descendants: true }, { propertyName: "editor", first: true, predicate: ["editor"], descendants: true }, { propertyName: "colorPicker", first: true, predicate: ["colorPicker"], descendants: true }, { propertyName: "parentElement", first: true, predicate: ["parentElement"], descendants: true }, { propertyName: "suggestion", first: true, predicate: ["suggestion"], descendants: true }], ngImport: i0, template: "<div class=\"editor-container\" [ngClass]=\"{'border': editable}\" #parentElement>\r\n <div [contenteditable]=\"editable\" [(ngModel)]=\"value\" class=\"editable-text\" (mouseup)=\"showToolbar($event)\" #editor\r\n (ngModelChange)=\"updateText($event)\" (mousedown)=\"hideToolbar($event)\">\r\n </div>\r\n\r\n <div class=\"toolbar\" *ngIf=\"editable && show\" [ngStyle]=\"{'top.px': toolbarY}\" [style.right]=\"rightZero ? '0px' : 'auto'\" [style.left]=\"!rightZero ? '0px' : 'auto'\" #toolbar >\r\n <select class=\"tool\" (change)=\"onFormatChange($event)\" [(ngModel)]=\"toolbarData.selectedHeading\">\r\n <option value=\"H1\">Heading1</option>\r\n <option value=\"H2\">Heading2</option>\r\n <option value=\"H3\">Heading3</option>\r\n <option value=\"div\">Text</option>\r\n </select
|
228
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: TextEditorComponent, isStandalone: true, selector: "simpo-text-editor", inputs: { value: "value", editable: "editable", sectionId: "sectionId", label: "label" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "toolbar", first: true, predicate: ["toolbar"], descendants: true }, { propertyName: "editor", first: true, predicate: ["editor"], descendants: true }, { propertyName: "colorPicker", first: true, predicate: ["colorPicker"], descendants: true }, { propertyName: "parentElement", first: true, predicate: ["parentElement"], descendants: true }, { propertyName: "suggestion", first: true, predicate: ["suggestion"], descendants: true }], ngImport: i0, template: "<div class=\"editor-container\" [ngClass]=\"{'border': editable}\" #parentElement>\r\n <div [contenteditable]=\"editable\" [(ngModel)]=\"value\" class=\"editable-text\" (mouseup)=\"showToolbar($event)\" #editor\r\n (ngModelChange)=\"updateText($event)\" (mousedown)=\"hideToolbar($event)\">\r\n </div>\r\n\r\n <div class=\"toolbar\" *ngIf=\"editable && show\" [ngStyle]=\"{'top.px': toolbarY}\" [style.right]=\"rightZero ? '0px' : 'auto'\" [style.left]=\"!rightZero ? '0px' : 'auto'\" #toolbar >\r\n <!-- <select class=\"tool\" (change)=\"onFormatChange($event)\" [(ngModel)]=\"toolbarData.selectedHeading\">\r\n <option value=\"H1\">Heading1</option>\r\n <option value=\"H2\">Heading2</option>\r\n <option value=\"H3\">Heading3</option>\r\n <option value=\"div\">Text</option>\r\n </select> -->\r\n\r\n <button class=\"tool\" (click)=\"formatText('bold')\" [ngClass]=\"{'selectedTool': toolbarData.isBold}\"><mat-icon> format_bold</mat-icon></button>\r\n <button class=\"tool\" (click)=\"formatText('italic')\" [ngClass]=\"{'selectedTool': toolbarData.isItalic}\"><mat-icon> format_italic</mat-icon></button>\r\n <button class=\"tool\" (click)=\"formatText('underline')\" [ngClass]=\"{'selectedTool': toolbarData.isUnderlined}\"><mat-icon> format_underlined</mat-icon></button>\r\n\r\n <select class=\"tool\" (change)=\"changeFontSize($event)\" [(ngModel)]=\"toolbarData.selectedSize\">\r\n <option value=\"\" selected>Default</option>\r\n <option value=\"18px\">Small</option>\r\n <option value=\"24px\">Medium</option>\r\n <option value=\"32px\">Large</option>\r\n <option value=\"48px\">Extra Large</option>\r\n <option value=\"72px\">Huge</option>\r\n </select>\r\n\r\n <button class=\"tool\" (click)=\"formatText('insertOrderedList')\" [ngClass]=\"{'selectedTool': toolbarData.selectedList === 'insertOrderedList'}\"><mat-icon>format_list_numbered</mat-icon></button>\r\n <button class=\"tool\" (click)=\"formatText('insertUnorderedList')\" [ngClass]=\"{'selectedTool': toolbarData.selectedList === 'insertUnorderedList'}\"><mat-icon> format_list_bulleted</mat-icon></button>\r\n\r\n <button class=\"tool\" (click)=\"formatText('justifyLeft')\" [ngClass]=\"{'selectedTool': toolbarData.selectedAlignment === 'justifyLeft'}\"><mat-icon> format_align_left</mat-icon></button>\r\n <button class=\"tool\" (click)=\"formatText('justifyCenter')\" [ngClass]=\"{'selectedTool': toolbarData.selectedAlignment === 'justifyCenter'}\"><mat-icon> format_align_center</mat-icon></button>\r\n <button class=\"tool\" (click)=\"formatText('justifyRight')\" [ngClass]=\"{'selectedTool': toolbarData.selectedAlignment === 'justifyRight'}\"><mat-icon> format_align_right</mat-icon></button>\r\n\r\n <button class=\"tool color-picker-btn\" (click)=\"openColorPicker()\">\r\n <mat-icon>format_color_text</mat-icon>\r\n <input type=\"color\" #colorPicker class=\"hidden-color-picker\" (input)=\"changeColor($event)\" [(ngModel)]=\"toolbarData.selectedColor\">\r\n </button>\r\n </div>\r\n\r\n <div class=\"suggestion-box\" [ngStyle]=\"{'top.px': suggestionY}\" [style.right]=\"rightZero ? '0px' : 'auto'\" [style.left]=\"!rightZero ? '0px' : 'auto'\" *ngIf=\"editable && label && showSuggestion\" #suggestion>\r\n <div class=\"suggestion\" (click)=\"regenerateText()\">\r\n <img src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/887493c1742273970151Frame%201244831740.png\" alt=\"\">\r\n <div>\r\n <p class=\"name\">Regenerate Text</p>\r\n <p class=\"desc\">Get a fresh variation of a current text</p>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".toolbar,.tool option{font-family:var(--primary-font-family)}mat-icon{font-family:Material Icons!important}.editor-container{position:relative;display:inline-block;width:100%}.editor-container div{outline:none}.editable-text{padding:4px;cursor:text}.toolbar{position:absolute;background:#fff;border:1px solid #ccc;box-shadow:0 2px 5px #0003;display:flex;gap:5px;align-items:center;z-index:100000;box-shadow:#00000029 0 1px 4px;padding:5px 15px;border-radius:22px}.toolbar button{background:none;border:none;padding:5px 8px;cursor:pointer;font-weight:700;display:flex;align-items:center}.toolbar button:hover{background:#ddd}.toolbar select{padding:3px;border:none;outline:none;font-size:14px;font-weight:600;cursor:pointer}.toolbar input[type=color]{border:none;width:30px;height:30px;padding:0;cursor:pointer}.color-picker-btn{position:relative;background:none;border:none;cursor:pointer;padding:5px}.hidden-color-picker{position:absolute;left:0;top:0;width:100%;height:100%;opacity:0;cursor:pointer}.border{border:1px solid #E9E9E9!important;border-radius:8px}.selectedTool{background:linear-gradient(94.22deg,#283e90 -4.45%,#f000e8 111.88%)!important;color:#fff;border-radius:5px}p{margin-bottom:0rem!important}.suggestion-box{position:absolute;background:#fff;border:1px solid #ccc;box-shadow:0 2px 5px #0003;z-index:10000;box-shadow:#00000029 0 1px 4px;padding:5px 15px;border-radius:10px}.suggestion{display:flex;gap:10px;width:307px;align-items:center;cursor:pointer}.suggestion img{border-radius:5px;width:32px;height:32px;background:#faf1fc;padding:3px}.suggestion .name{color:#000;font-family:var(--primary-font-family)}.suggestion .desc{color:#000;font-size:12px;color:#918585;font-family:var(--primary-font-family)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i3.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i3.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: ContenteditableValueAccessor, selector: "[contenteditable][ngModel]", inputs: ["contenteditable"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] }); }
|
229
229
|
}
|
230
230
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: TextEditorComponent, decorators: [{
|
231
231
|
type: Component,
|
@@ -234,7 +234,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImpor
|
|
234
234
|
FormsModule,
|
235
235
|
ContenteditableValueAccessor,
|
236
236
|
MatIconModule
|
237
|
-
], template: "<div class=\"editor-container\" [ngClass]=\"{'border': editable}\" #parentElement>\r\n <div [contenteditable]=\"editable\" [(ngModel)]=\"value\" class=\"editable-text\" (mouseup)=\"showToolbar($event)\" #editor\r\n (ngModelChange)=\"updateText($event)\" (mousedown)=\"hideToolbar($event)\">\r\n </div>\r\n\r\n <div class=\"toolbar\" *ngIf=\"editable && show\" [ngStyle]=\"{'top.px': toolbarY}\" [style.right]=\"rightZero ? '0px' : 'auto'\" [style.left]=\"!rightZero ? '0px' : 'auto'\" #toolbar >\r\n <select class=\"tool\" (change)=\"onFormatChange($event)\" [(ngModel)]=\"toolbarData.selectedHeading\">\r\n <option value=\"H1\">Heading1</option>\r\n <option value=\"H2\">Heading2</option>\r\n <option value=\"H3\">Heading3</option>\r\n <option value=\"div\">Text</option>\r\n </select
|
237
|
+
], template: "<div class=\"editor-container\" [ngClass]=\"{'border': editable}\" #parentElement>\r\n <div [contenteditable]=\"editable\" [(ngModel)]=\"value\" class=\"editable-text\" (mouseup)=\"showToolbar($event)\" #editor\r\n (ngModelChange)=\"updateText($event)\" (mousedown)=\"hideToolbar($event)\">\r\n </div>\r\n\r\n <div class=\"toolbar\" *ngIf=\"editable && show\" [ngStyle]=\"{'top.px': toolbarY}\" [style.right]=\"rightZero ? '0px' : 'auto'\" [style.left]=\"!rightZero ? '0px' : 'auto'\" #toolbar >\r\n <!-- <select class=\"tool\" (change)=\"onFormatChange($event)\" [(ngModel)]=\"toolbarData.selectedHeading\">\r\n <option value=\"H1\">Heading1</option>\r\n <option value=\"H2\">Heading2</option>\r\n <option value=\"H3\">Heading3</option>\r\n <option value=\"div\">Text</option>\r\n </select> -->\r\n\r\n <button class=\"tool\" (click)=\"formatText('bold')\" [ngClass]=\"{'selectedTool': toolbarData.isBold}\"><mat-icon> format_bold</mat-icon></button>\r\n <button class=\"tool\" (click)=\"formatText('italic')\" [ngClass]=\"{'selectedTool': toolbarData.isItalic}\"><mat-icon> format_italic</mat-icon></button>\r\n <button class=\"tool\" (click)=\"formatText('underline')\" [ngClass]=\"{'selectedTool': toolbarData.isUnderlined}\"><mat-icon> format_underlined</mat-icon></button>\r\n\r\n <select class=\"tool\" (change)=\"changeFontSize($event)\" [(ngModel)]=\"toolbarData.selectedSize\">\r\n <option value=\"\" selected>Default</option>\r\n <option value=\"18px\">Small</option>\r\n <option value=\"24px\">Medium</option>\r\n <option value=\"32px\">Large</option>\r\n <option value=\"48px\">Extra Large</option>\r\n <option value=\"72px\">Huge</option>\r\n </select>\r\n\r\n <button class=\"tool\" (click)=\"formatText('insertOrderedList')\" [ngClass]=\"{'selectedTool': toolbarData.selectedList === 'insertOrderedList'}\"><mat-icon>format_list_numbered</mat-icon></button>\r\n <button class=\"tool\" (click)=\"formatText('insertUnorderedList')\" [ngClass]=\"{'selectedTool': toolbarData.selectedList === 'insertUnorderedList'}\"><mat-icon> format_list_bulleted</mat-icon></button>\r\n\r\n <button class=\"tool\" (click)=\"formatText('justifyLeft')\" [ngClass]=\"{'selectedTool': toolbarData.selectedAlignment === 'justifyLeft'}\"><mat-icon> format_align_left</mat-icon></button>\r\n <button class=\"tool\" (click)=\"formatText('justifyCenter')\" [ngClass]=\"{'selectedTool': toolbarData.selectedAlignment === 'justifyCenter'}\"><mat-icon> format_align_center</mat-icon></button>\r\n <button class=\"tool\" (click)=\"formatText('justifyRight')\" [ngClass]=\"{'selectedTool': toolbarData.selectedAlignment === 'justifyRight'}\"><mat-icon> format_align_right</mat-icon></button>\r\n\r\n <button class=\"tool color-picker-btn\" (click)=\"openColorPicker()\">\r\n <mat-icon>format_color_text</mat-icon>\r\n <input type=\"color\" #colorPicker class=\"hidden-color-picker\" (input)=\"changeColor($event)\" [(ngModel)]=\"toolbarData.selectedColor\">\r\n </button>\r\n </div>\r\n\r\n <div class=\"suggestion-box\" [ngStyle]=\"{'top.px': suggestionY}\" [style.right]=\"rightZero ? '0px' : 'auto'\" [style.left]=\"!rightZero ? '0px' : 'auto'\" *ngIf=\"editable && label && showSuggestion\" #suggestion>\r\n <div class=\"suggestion\" (click)=\"regenerateText()\">\r\n <img src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/887493c1742273970151Frame%201244831740.png\" alt=\"\">\r\n <div>\r\n <p class=\"name\">Regenerate Text</p>\r\n <p class=\"desc\">Get a fresh variation of a current text</p>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".toolbar,.tool option{font-family:var(--primary-font-family)}mat-icon{font-family:Material Icons!important}.editor-container{position:relative;display:inline-block;width:100%}.editor-container div{outline:none}.editable-text{padding:4px;cursor:text}.toolbar{position:absolute;background:#fff;border:1px solid #ccc;box-shadow:0 2px 5px #0003;display:flex;gap:5px;align-items:center;z-index:100000;box-shadow:#00000029 0 1px 4px;padding:5px 15px;border-radius:22px}.toolbar button{background:none;border:none;padding:5px 8px;cursor:pointer;font-weight:700;display:flex;align-items:center}.toolbar button:hover{background:#ddd}.toolbar select{padding:3px;border:none;outline:none;font-size:14px;font-weight:600;cursor:pointer}.toolbar input[type=color]{border:none;width:30px;height:30px;padding:0;cursor:pointer}.color-picker-btn{position:relative;background:none;border:none;cursor:pointer;padding:5px}.hidden-color-picker{position:absolute;left:0;top:0;width:100%;height:100%;opacity:0;cursor:pointer}.border{border:1px solid #E9E9E9!important;border-radius:8px}.selectedTool{background:linear-gradient(94.22deg,#283e90 -4.45%,#f000e8 111.88%)!important;color:#fff;border-radius:5px}p{margin-bottom:0rem!important}.suggestion-box{position:absolute;background:#fff;border:1px solid #ccc;box-shadow:0 2px 5px #0003;z-index:10000;box-shadow:#00000029 0 1px 4px;padding:5px 15px;border-radius:10px}.suggestion{display:flex;gap:10px;width:307px;align-items:center;cursor:pointer}.suggestion img{border-radius:5px;width:32px;height:32px;background:#faf1fc;padding:3px}.suggestion .name{color:#000;font-family:var(--primary-font-family)}.suggestion .desc{color:#000;font-size:12px;color:#918585;font-family:var(--primary-font-family)}\n"] }]
|
238
238
|
}], ctorParameters: () => [{ type: i1.ElementServiceService }, { type: Object, decorators: [{
|
239
239
|
type: Inject,
|
240
240
|
args: [PLATFORM_ID]
|
@@ -264,4 +264,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImpor
|
|
264
264
|
}], label: [{
|
265
265
|
type: Input
|
266
266
|
}] } });
|
267
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-editor.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/elements/text-editor/text-editor.component.ts","../../../../../../projects/simpo-ui/src/lib/elements/text-editor/text-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Inject, Input, Output, PLATFORM_ID, ViewChild } from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { ContenteditableValueAccessor } from '../../directive/contenteditable.directive';\r\nimport { CommonModule, isPlatformBrowser } from '@angular/common';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { RestService } from '../../services/rest.service';\r\nimport { ElementServiceService } from '../editor-service.service';\r\n\r\n@Component({\r\n  selector: 'simpo-text-editor',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ContenteditableValueAccessor,\r\n    MatIconModule\r\n  ],\r\n  templateUrl: './text-editor.component.html',\r\n  styleUrl: './text-editor.component.css'\r\n})\r\nexport class TextEditorComponent {\r\n  @ViewChild('toolbar', { static: false }) toolbar!: ElementRef;\r\n  @ViewChild('editor', { static: false }) editor!: ElementRef;\r\n  @ViewChild('colorPicker') colorPicker!: ElementRef;\r\n  @ViewChild('parentElement') parentElement!: ElementRef;\r\n  @ViewChild('suggestion', { static: false }) suggestion!: ElementRef;\r\n\r\n  @Input() value: string = '<p>Hello this is palash makhija</p>';\r\n  @Output() valueChange = new EventEmitter<string>();\r\n  @Input() editable: boolean = false;\r\n  @Input() sectionId?: string;\r\n  @Input() label?: string;\r\n\r\n  show = false;\r\n  toolbarY = 0;\r\n  suggestionY = 0;\r\n  rightZero: boolean = true;\r\n  showSuggestion: boolean = false;\r\n  toolbarData: any = {\r\n    selectedHeading: '',\r\n    isBold: false,\r\n    isItalic: false,\r\n    isUnderlined: false,\r\n    selectedSize: '',\r\n    selectedList: '',\r\n    selectedAlignment: '',\r\n    selectedColor: ''\r\n  }\r\n\r\n  constructor(private editorService : ElementServiceService,\r\n    @Inject(PLATFORM_ID) private platformId: Object\r\n  ) { }\r\n\r\n  ngOnInit() {\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      document.addEventListener('mousedown', this.hideToolbar.bind(this));\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      document.removeEventListener('mousedown', this.hideToolbar.bind(this));\r\n    }\r\n  }\r\n\r\n\r\n  showToolbar(event: MouseEvent) {\r\n    if (!isPlatformBrowser(this.platformId) || !this.editable) return;\r\n\r\n    const selection = window.getSelection();\r\n    if(selection == null)\r\n      return;\r\n\r\n    const range = selection.getRangeAt(0);\r\n    const rect = range.getBoundingClientRect();\r\n    const parentRect = this.parentElement.nativeElement.getBoundingClientRect();\r\n    const topFromParent = rect.top - parentRect.top;\r\n\r\n    if(selection && selection.rangeCount > 0) {\r\n      this.suggestionY = topFromParent + 30;\r\n      this.showSuggestion = true;\r\n    }\r\n\r\n    if (selection && selection.toString().trim() !== '') {\r\n      const toolbarWidth = 630;\r\n\r\n      const viewportWidth = window.innerWidth;\r\n      const rightPositon = viewportWidth - parentRect.left;\r\n      if(rightPositon + toolbarWidth > viewportWidth){\r\n        this.rightZero = false;\r\n      } else{\r\n        this.rightZero = true;\r\n      }\r\n\r\n      this.toolbarY = topFromParent + 30;\r\n\r\n      this.reFormattingData();\r\n      this.readFormattingProperties();\r\n\r\n      this.show = true;\r\n    } else {\r\n      this.show = false;\r\n    }\r\n  }\r\n\r\n  hideToolbar(event: MouseEvent) {\r\n    if (!isPlatformBrowser(this.platformId) || !this.editable) return;\r\n\r\n    const clickedInsideEditor = this.editor?.nativeElement.contains(event.target);\r\n    const clickedInsideToolbar = this.toolbar?.nativeElement.contains(event.target);\r\n    const clickedInsideSuggestion = this.suggestion?.nativeElement.contains(event.target);\r\n\r\n    // Hide the toolbar if the click is outside both the editor and toolbar\r\n    if (!clickedInsideEditor && !clickedInsideToolbar) {\r\n      this.show = false;\r\n    }\r\n    if(!clickedInsideEditor && !clickedInsideSuggestion){\r\n      this.showSuggestion = false;\r\n    }\r\n  }\r\n\r\n  formatText(command: string, value: string = '') {\r\n    if (!isPlatformBrowser(this.platformId)) return;\r\n\r\n    //   if (command === 'formatBlock') {\r\n  //     const selection = window.getSelection();\r\n  //     if (!selection || selection.rangeCount === 0) return;\r\n\r\n  //     const range = selection.getRangeAt(0);\r\n  //     const selectedText = selection.toString();\r\n\r\n  //     if (selectedText) {\r\n  //         const newElement = document.createElement(value);\r\n  //         newElement.textContent = selectedText;\r\n\r\n  //         range.deleteContents();\r\n  //         range.insertNode(newElement);\r\n\r\n  //         this.toolbarData.selectedHeading = value;\r\n  //         return;\r\n  //     }\r\n  // }\r\n    document.execCommand(command, false, value);\r\n\r\n    if(command === 'bold')\r\n      this.toolbarData.isBold = !this.toolbarData.isBold;\r\n    if(command === 'italic')\r\n      this.toolbarData.isItalic = !this.toolbarData.isItalic;\r\n    if(command === 'underline')\r\n      this.toolbarData.isUnderlined = !this.toolbarData.isUnderlined\r\n    if(command === 'insertOrderedList' || command === 'insertUnorderedList')\r\n      this.toolbarData.selectedList = command === this.toolbarData.selectedList ? '' : command;\r\n    if(command === 'justifyLeft' || command === 'justifyCenter' || command === 'justifyRight')\r\n      this.toolbarData.selectedAlignment = command === this.toolbarData.selectedAlignment ? '' : command;\r\n    if(command === 'formatBlock')\r\n      this.toolbarData.selectedHeading = value;\r\n  }\r\n\r\n  changeFontSize(event: any) {\r\n    if (!isPlatformBrowser(this.platformId)) return;\r\n\r\n    const size = event.target.value;\r\n\r\n    // Apply a default size of 4 (needed for execCommand to work)\r\n    document.execCommand('fontSize', false, '4');\r\n\r\n    // Convert selected font elements to have actual font-size instead of \"size\" attribute\r\n    const elements = document.querySelectorAll(\"font[size='4']\");\r\n    elements.forEach(el => {\r\n      const htmlElement = el as HTMLElement; // ✅ Explicitly cast to HTMLElement\r\n      htmlElement.removeAttribute('size'); // Remove old size attribute\r\n      htmlElement.style.fontSize = size; // Apply CSS font size\r\n    });\r\n    this.toolbarData.selectedSize = size;\r\n    this.valueChange.emit(this.editor.nativeElement.innerHTML);\r\n    // this.show = false; // Hide toolbar after action\r\n  }\r\n\r\n  changeColor(event: any) {\r\n    if (!isPlatformBrowser(this.platformId)) return;\r\n\r\n    const color = event.target.value;\r\n    document.execCommand('foreColor', false, color);\r\n    this.toolbarData.selectedColor = color;\r\n    // this.show = false;\r\n  }\r\n\r\n  updateText(event: Event) {\r\n    // console.log(this.editor.nativeElement.innerHTML)\r\n    this.valueChange.emit(this.editor.nativeElement.innerHTML);\r\n  }\r\n\r\n  onFormatChange(event: Event) {\r\n    const selectedValue = (event.target as HTMLSelectElement).value;\r\n    this.formatText('formatBlock', selectedValue);\r\n  }\r\n\r\n\r\n  openColorPicker() {\r\n    this.colorPicker.nativeElement.click(); // Programmatically trigger input\r\n  }\r\n\r\n  readFormattingProperties() {\r\n    if (!isPlatformBrowser(this.platformId)) return;\r\n\r\n    const selection = window.getSelection();\r\n    if (!selection) return;\r\n    const node = selection.focusNode as HTMLElement;\r\n\r\n    // Check if node is null\r\n    if (!node) return;\r\n\r\n    let element = node.parentElement;\r\n    while (element) {\r\n      const nodeName = element.nodeName;\r\n\r\n      if (nodeName === 'H1' || nodeName === 'H2' || nodeName === 'H3') {\r\n        this.toolbarData.selectedHeading = nodeName;\r\n      } else if (nodeName === 'B' || nodeName === 'STRONG') {\r\n        this.toolbarData.isBold = true;\r\n      } else if (nodeName === 'I' || nodeName === 'EM') {\r\n        this.toolbarData.isItalic = true;\r\n      } else if (nodeName === 'U') {\r\n        this.toolbarData.isUnderlined = true;\r\n      } else if (nodeName === 'OL') {\r\n        this.toolbarData.selectedList = 'insertOrderedList';\r\n      } else if (nodeName === 'UL') {\r\n        this.toolbarData.selectedList = 'insertUnorderedList';\r\n      } else if (element.style.textAlign) {\r\n        this.toolbarData.selectedAlignment = `justify${element.style.textAlign.charAt(0).toUpperCase() + element.style.textAlign.slice(1)}`;\r\n      } else if (element.style.fontSize) {\r\n        this.toolbarData.selectedSize = element.style.fontSize;\r\n      } else if(element.style.color) {\r\n        this.toolbarData.selectedColor = element.style.color\r\n      }\r\n\r\n\r\n      element = element.parentElement;\r\n    }\r\n  }\r\n\r\n  reFormattingData() {\r\n    this.toolbarData = {\r\n      selectedHeading: '',\r\n      isBold: false,\r\n      isItalic: false,\r\n      isUnderlined: false,\r\n      selectedSize: '',\r\n      selectedList: '',\r\n      selectedAlignment: '',\r\n      selectedColor: ''\r\n    }\r\n  }\r\n\r\n  regenerateText() {\r\n    let payload = {\r\n      businessId: localStorage.getItem('businessId'),\r\n      dataId: this.sectionId,\r\n      subIndustryId: localStorage.getItem('subIndustryId'),\r\n      suggestedDataType: 'COMPONENT',\r\n      tone: 'PROFESSIONAL',\r\n      value: this.value ,\r\n      label: this.label\r\n    }\r\n\r\n    this.editorService.regenerateText(payload).subscribe((res: any) => {\r\n      this.value = res.data;\r\n    })\r\n  }\r\n}\r\n","<div class=\"editor-container\" [ngClass]=\"{'border': editable}\" #parentElement>\r\n  <div [contenteditable]=\"editable\" [(ngModel)]=\"value\" class=\"editable-text\" (mouseup)=\"showToolbar($event)\" #editor\r\n    (ngModelChange)=\"updateText($event)\" (mousedown)=\"hideToolbar($event)\">\r\n  </div>\r\n\r\n  <div class=\"toolbar\" *ngIf=\"editable && show\" [ngStyle]=\"{'top.px': toolbarY}\" [style.right]=\"rightZero ? '0px' : 'auto'\" [style.left]=\"!rightZero ? '0px' : 'auto'\" #toolbar >\r\n    <select class=\"tool\" (change)=\"onFormatChange($event)\" [(ngModel)]=\"toolbarData.selectedHeading\">\r\n      <option value=\"H1\">Heading1</option>\r\n      <option value=\"H2\">Heading2</option>\r\n      <option value=\"H3\">Heading3</option>\r\n      <option value=\"div\">Text</option>\r\n    </select>\r\n\r\n    <button class=\"tool\" (click)=\"formatText('bold')\" [ngClass]=\"{'selectedTool': toolbarData.isBold}\"><mat-icon> format_bold</mat-icon></button>\r\n    <button class=\"tool\" (click)=\"formatText('italic')\" [ngClass]=\"{'selectedTool': toolbarData.isItalic}\"><mat-icon> format_italic</mat-icon></button>\r\n    <button class=\"tool\" (click)=\"formatText('underline')\" [ngClass]=\"{'selectedTool': toolbarData.isUnderlined}\"><mat-icon> format_underlined</mat-icon></button>\r\n\r\n    <select class=\"tool\" (change)=\"changeFontSize($event)\" [(ngModel)]=\"toolbarData.selectedSize\">\r\n      <option value=\"\" selected>Default</option>\r\n      <option value=\"18px\">Small</option>\r\n      <option value=\"24px\">Medium</option>\r\n      <option value=\"32px\">Large</option>\r\n      <option value=\"48px\">Extra Large</option>\r\n      <option value=\"72px\">Huge</option>\r\n    </select>\r\n\r\n    <button class=\"tool\" (click)=\"formatText('insertOrderedList')\" [ngClass]=\"{'selectedTool': toolbarData.selectedList === 'insertOrderedList'}\"><mat-icon>format_list_numbered</mat-icon></button>\r\n    <button class=\"tool\" (click)=\"formatText('insertUnorderedList')\" [ngClass]=\"{'selectedTool': toolbarData.selectedList === 'insertUnorderedList'}\"><mat-icon> format_list_bulleted</mat-icon></button>\r\n\r\n    <button class=\"tool\" (click)=\"formatText('justifyLeft')\" [ngClass]=\"{'selectedTool': toolbarData.selectedAlignment === 'justifyLeft'}\"><mat-icon> format_align_left</mat-icon></button>\r\n    <button class=\"tool\" (click)=\"formatText('justifyCenter')\" [ngClass]=\"{'selectedTool': toolbarData.selectedAlignment === 'justifyCenter'}\"><mat-icon> format_align_center</mat-icon></button>\r\n    <button class=\"tool\" (click)=\"formatText('justifyRight')\" [ngClass]=\"{'selectedTool': toolbarData.selectedAlignment === 'justifyRight'}\"><mat-icon> format_align_right</mat-icon></button>\r\n\r\n    <button class=\"tool color-picker-btn\" (click)=\"openColorPicker()\">\r\n      <mat-icon>format_color_text</mat-icon>\r\n      <input type=\"color\" #colorPicker class=\"hidden-color-picker\" (input)=\"changeColor($event)\" [(ngModel)]=\"toolbarData.selectedColor\">\r\n    </button>\r\n  </div>\r\n\r\n  <div class=\"suggestion-box\" [ngStyle]=\"{'top.px': suggestionY}\" [style.right]=\"rightZero ? '0px' : 'auto'\" [style.left]=\"!rightZero ? '0px' : 'auto'\" *ngIf=\"editable && label && showSuggestion\" #suggestion>\r\n    <div class=\"suggestion\" (click)=\"regenerateText()\">\r\n      <img src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/887493c1742273970151Frame%201244831740.png\" alt=\"\">\r\n      <div>\r\n        <p class=\"name\">Regenerate Text</p>\r\n        <p class=\"desc\">Get a fresh variation of a current text</p>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|
267
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-editor.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/elements/text-editor/text-editor.component.ts","../../../../../../projects/simpo-ui/src/lib/elements/text-editor/text-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Inject, Input, Output, PLATFORM_ID, ViewChild } from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { ContenteditableValueAccessor } from '../../directive/contenteditable.directive';\r\nimport { CommonModule, isPlatformBrowser } from '@angular/common';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { RestService } from '../../services/rest.service';\r\nimport { ElementServiceService } from '../editor-service.service';\r\n\r\n@Component({\r\n  selector: 'simpo-text-editor',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ContenteditableValueAccessor,\r\n    MatIconModule\r\n  ],\r\n  templateUrl: './text-editor.component.html',\r\n  styleUrl: './text-editor.component.css'\r\n})\r\nexport class TextEditorComponent {\r\n  @ViewChild('toolbar', { static: false }) toolbar!: ElementRef;\r\n  @ViewChild('editor', { static: false }) editor!: ElementRef;\r\n  @ViewChild('colorPicker') colorPicker!: ElementRef;\r\n  @ViewChild('parentElement') parentElement!: ElementRef;\r\n  @ViewChild('suggestion', { static: false }) suggestion!: ElementRef;\r\n\r\n  @Input() value: string = '<p>Hello this is palash makhija</p>';\r\n  @Output() valueChange = new EventEmitter<string>();\r\n  @Input() editable: boolean = false;\r\n  @Input() sectionId?: string;\r\n  @Input() label?: string;\r\n\r\n  show = false;\r\n  toolbarY = 0;\r\n  suggestionY = 0;\r\n  rightZero: boolean = true;\r\n  showSuggestion: boolean = false;\r\n  toolbarData: any = {\r\n    selectedHeading: '',\r\n    isBold: false,\r\n    isItalic: false,\r\n    isUnderlined: false,\r\n    selectedSize: '',\r\n    selectedList: '',\r\n    selectedAlignment: '',\r\n    selectedColor: ''\r\n  }\r\n\r\n  constructor(private editorService : ElementServiceService,\r\n    @Inject(PLATFORM_ID) private platformId: Object\r\n  ) { }\r\n\r\n  ngOnInit() {\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      document.addEventListener('mousedown', this.hideToolbar.bind(this));\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (isPlatformBrowser(this.platformId)) {\r\n      document.removeEventListener('mousedown', this.hideToolbar.bind(this));\r\n    }\r\n  }\r\n\r\n\r\n  showToolbar(event: MouseEvent) {\r\n    if (!isPlatformBrowser(this.platformId) || !this.editable) return;\r\n\r\n    const selection = window.getSelection();\r\n    if(selection == null)\r\n      return;\r\n\r\n    const range = selection.getRangeAt(0);\r\n    const rect = range.getBoundingClientRect();\r\n    const parentRect = this.parentElement.nativeElement.getBoundingClientRect();\r\n    const topFromParent = rect.top - parentRect.top;\r\n\r\n    if(selection && selection.rangeCount > 0) {\r\n      this.suggestionY = topFromParent + 30;\r\n      this.showSuggestion = true;\r\n    }\r\n\r\n    if (selection && selection.toString().trim() !== '') {\r\n      const toolbarWidth = 630;\r\n\r\n      const viewportWidth = window.innerWidth;\r\n      const rightPositon = viewportWidth - parentRect.left;\r\n      if(rightPositon + toolbarWidth > viewportWidth){\r\n        this.rightZero = false;\r\n      } else{\r\n        this.rightZero = true;\r\n      }\r\n\r\n      this.toolbarY = topFromParent + 30;\r\n\r\n      this.reFormattingData();\r\n      this.readFormattingProperties();\r\n\r\n      this.show = true;\r\n    } else {\r\n      this.show = false;\r\n    }\r\n  }\r\n\r\n  hideToolbar(event: MouseEvent) {\r\n    if (!isPlatformBrowser(this.platformId) || !this.editable) return;\r\n\r\n    const clickedInsideEditor = this.editor?.nativeElement.contains(event.target);\r\n    const clickedInsideToolbar = this.toolbar?.nativeElement.contains(event.target);\r\n    const clickedInsideSuggestion = this.suggestion?.nativeElement.contains(event.target);\r\n\r\n    // Hide the toolbar if the click is outside both the editor and toolbar\r\n    if (!clickedInsideEditor && !clickedInsideToolbar) {\r\n      this.show = false;\r\n    }\r\n    if(!clickedInsideEditor && !clickedInsideSuggestion){\r\n      this.showSuggestion = false;\r\n    }\r\n  }\r\n\r\n  formatText(command: string, value: string = '') {\r\n    if (!isPlatformBrowser(this.platformId)) return;\r\n\r\n    //   if (command === 'formatBlock') {\r\n  //     const selection = window.getSelection();\r\n  //     if (!selection || selection.rangeCount === 0) return;\r\n\r\n  //     const range = selection.getRangeAt(0);\r\n  //     const selectedText = selection.toString();\r\n\r\n  //     if (selectedText) {\r\n  //         const newElement = document.createElement(value);\r\n  //         newElement.textContent = selectedText;\r\n\r\n  //         range.deleteContents();\r\n  //         range.insertNode(newElement);\r\n\r\n  //         this.toolbarData.selectedHeading = value;\r\n  //         return;\r\n  //     }\r\n  // }\r\n    document.execCommand(command, false, value);\r\n\r\n    if(command === 'bold')\r\n      this.toolbarData.isBold = !this.toolbarData.isBold;\r\n    if(command === 'italic')\r\n      this.toolbarData.isItalic = !this.toolbarData.isItalic;\r\n    if(command === 'underline')\r\n      this.toolbarData.isUnderlined = !this.toolbarData.isUnderlined\r\n    if(command === 'insertOrderedList' || command === 'insertUnorderedList')\r\n      this.toolbarData.selectedList = command === this.toolbarData.selectedList ? '' : command;\r\n    if(command === 'justifyLeft' || command === 'justifyCenter' || command === 'justifyRight')\r\n      this.toolbarData.selectedAlignment = command === this.toolbarData.selectedAlignment ? '' : command;\r\n    if(command === 'formatBlock')\r\n      this.toolbarData.selectedHeading = value;\r\n  }\r\n\r\n  changeFontSize(event: any) {\r\n    if (!isPlatformBrowser(this.platformId)) return;\r\n\r\n    const size = event.target.value;\r\n\r\n    // Apply a default size of 4 (needed for execCommand to work)\r\n    document.execCommand('fontSize', false, '4');\r\n\r\n    // Convert selected font elements to have actual font-size instead of \"size\" attribute\r\n    const elements = document.querySelectorAll(\"font[size='4']\");\r\n    elements.forEach(el => {\r\n      const htmlElement = el as HTMLElement; // ✅ Explicitly cast to HTMLElement\r\n      htmlElement.removeAttribute('size'); // Remove old size attribute\r\n      htmlElement.style.fontSize = size; // Apply CSS font size\r\n    });\r\n    this.toolbarData.selectedSize = size;\r\n    this.valueChange.emit(this.editor.nativeElement.innerHTML);\r\n    // this.show = false; // Hide toolbar after action\r\n  }\r\n\r\n  changeColor(event: any) {\r\n    if (!isPlatformBrowser(this.platformId)) return;\r\n\r\n    const color = event.target.value;\r\n    document.execCommand('foreColor', false, color);\r\n    this.toolbarData.selectedColor = color;\r\n    // this.show = false;\r\n  }\r\n\r\n  updateText(event: Event) {\r\n    // console.log(this.editor.nativeElement.innerHTML)\r\n    this.valueChange.emit(this.editor.nativeElement.innerHTML);\r\n  }\r\n\r\n  onFormatChange(event: Event) {\r\n    const selectedValue = (event.target as HTMLSelectElement).value;\r\n    this.formatText('formatBlock', selectedValue);\r\n  }\r\n\r\n\r\n  openColorPicker() {\r\n    this.colorPicker.nativeElement.click(); // Programmatically trigger input\r\n  }\r\n\r\n  readFormattingProperties() {\r\n    if (!isPlatformBrowser(this.platformId)) return;\r\n\r\n    const selection = window.getSelection();\r\n    if (!selection) return;\r\n    const node = selection.focusNode as HTMLElement;\r\n\r\n    // Check if node is null\r\n    if (!node) return;\r\n\r\n    let element = node.parentElement;\r\n    while (element) {\r\n      const nodeName = element.nodeName;\r\n\r\n      if (nodeName === 'H1' || nodeName === 'H2' || nodeName === 'H3') {\r\n        this.toolbarData.selectedHeading = nodeName;\r\n      } else if (nodeName === 'B' || nodeName === 'STRONG') {\r\n        this.toolbarData.isBold = true;\r\n      } else if (nodeName === 'I' || nodeName === 'EM') {\r\n        this.toolbarData.isItalic = true;\r\n      } else if (nodeName === 'U') {\r\n        this.toolbarData.isUnderlined = true;\r\n      } else if (nodeName === 'OL') {\r\n        this.toolbarData.selectedList = 'insertOrderedList';\r\n      } else if (nodeName === 'UL') {\r\n        this.toolbarData.selectedList = 'insertUnorderedList';\r\n      } else if (element.style.textAlign) {\r\n        this.toolbarData.selectedAlignment = `justify${element.style.textAlign.charAt(0).toUpperCase() + element.style.textAlign.slice(1)}`;\r\n      } else if (element.style.fontSize) {\r\n        this.toolbarData.selectedSize = element.style.fontSize;\r\n      } else if(element.style.color) {\r\n        this.toolbarData.selectedColor = element.style.color\r\n      }\r\n\r\n\r\n      element = element.parentElement;\r\n    }\r\n  }\r\n\r\n  reFormattingData() {\r\n    this.toolbarData = {\r\n      selectedHeading: '',\r\n      isBold: false,\r\n      isItalic: false,\r\n      isUnderlined: false,\r\n      selectedSize: '',\r\n      selectedList: '',\r\n      selectedAlignment: '',\r\n      selectedColor: ''\r\n    }\r\n  }\r\n\r\n  regenerateText() {\r\n    let payload = {\r\n      businessId: localStorage.getItem('businessId'),\r\n      dataId: this.sectionId,\r\n      subIndustryId: localStorage.getItem('subIndustryId'),\r\n      suggestedDataType: 'COMPONENT',\r\n      tone: 'PROFESSIONAL',\r\n      value: this.value ,\r\n      label: this.label\r\n    }\r\n\r\n    this.editorService.regenerateText(payload).subscribe((res: any) => {\r\n      this.value = res.data;\r\n    })\r\n  }\r\n}\r\n","<div class=\"editor-container\" [ngClass]=\"{'border': editable}\" #parentElement>\r\n  <div [contenteditable]=\"editable\" [(ngModel)]=\"value\" class=\"editable-text\" (mouseup)=\"showToolbar($event)\" #editor\r\n    (ngModelChange)=\"updateText($event)\" (mousedown)=\"hideToolbar($event)\">\r\n  </div>\r\n\r\n  <div class=\"toolbar\" *ngIf=\"editable && show\" [ngStyle]=\"{'top.px': toolbarY}\" [style.right]=\"rightZero ? '0px' : 'auto'\" [style.left]=\"!rightZero ? '0px' : 'auto'\" #toolbar >\r\n    <!-- <select class=\"tool\" (change)=\"onFormatChange($event)\" [(ngModel)]=\"toolbarData.selectedHeading\">\r\n      <option value=\"H1\">Heading1</option>\r\n      <option value=\"H2\">Heading2</option>\r\n      <option value=\"H3\">Heading3</option>\r\n      <option value=\"div\">Text</option>\r\n    </select> -->\r\n\r\n    <button class=\"tool\" (click)=\"formatText('bold')\" [ngClass]=\"{'selectedTool': toolbarData.isBold}\"><mat-icon> format_bold</mat-icon></button>\r\n    <button class=\"tool\" (click)=\"formatText('italic')\" [ngClass]=\"{'selectedTool': toolbarData.isItalic}\"><mat-icon> format_italic</mat-icon></button>\r\n    <button class=\"tool\" (click)=\"formatText('underline')\" [ngClass]=\"{'selectedTool': toolbarData.isUnderlined}\"><mat-icon> format_underlined</mat-icon></button>\r\n\r\n    <select class=\"tool\" (change)=\"changeFontSize($event)\" [(ngModel)]=\"toolbarData.selectedSize\">\r\n      <option value=\"\" selected>Default</option>\r\n      <option value=\"18px\">Small</option>\r\n      <option value=\"24px\">Medium</option>\r\n      <option value=\"32px\">Large</option>\r\n      <option value=\"48px\">Extra Large</option>\r\n      <option value=\"72px\">Huge</option>\r\n    </select>\r\n\r\n    <button class=\"tool\" (click)=\"formatText('insertOrderedList')\" [ngClass]=\"{'selectedTool': toolbarData.selectedList === 'insertOrderedList'}\"><mat-icon>format_list_numbered</mat-icon></button>\r\n    <button class=\"tool\" (click)=\"formatText('insertUnorderedList')\" [ngClass]=\"{'selectedTool': toolbarData.selectedList === 'insertUnorderedList'}\"><mat-icon> format_list_bulleted</mat-icon></button>\r\n\r\n    <button class=\"tool\" (click)=\"formatText('justifyLeft')\" [ngClass]=\"{'selectedTool': toolbarData.selectedAlignment === 'justifyLeft'}\"><mat-icon> format_align_left</mat-icon></button>\r\n    <button class=\"tool\" (click)=\"formatText('justifyCenter')\" [ngClass]=\"{'selectedTool': toolbarData.selectedAlignment === 'justifyCenter'}\"><mat-icon> format_align_center</mat-icon></button>\r\n    <button class=\"tool\" (click)=\"formatText('justifyRight')\" [ngClass]=\"{'selectedTool': toolbarData.selectedAlignment === 'justifyRight'}\"><mat-icon> format_align_right</mat-icon></button>\r\n\r\n    <button class=\"tool color-picker-btn\" (click)=\"openColorPicker()\">\r\n      <mat-icon>format_color_text</mat-icon>\r\n      <input type=\"color\" #colorPicker class=\"hidden-color-picker\" (input)=\"changeColor($event)\" [(ngModel)]=\"toolbarData.selectedColor\">\r\n    </button>\r\n  </div>\r\n\r\n  <div class=\"suggestion-box\" [ngStyle]=\"{'top.px': suggestionY}\" [style.right]=\"rightZero ? '0px' : 'auto'\" [style.left]=\"!rightZero ? '0px' : 'auto'\" *ngIf=\"editable && label && showSuggestion\" #suggestion>\r\n    <div class=\"suggestion\" (click)=\"regenerateText()\">\r\n      <img src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/887493c1742273970151Frame%201244831740.png\" alt=\"\">\r\n      <div>\r\n        <p class=\"name\">Regenerate Text</p>\r\n        <p class=\"desc\">Get a fresh variation of a current text</p>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|