simpo-component-library 3.0.37 → 3.0.39

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.
@@ -0,0 +1,83 @@
1
+ import { Directive, ElementRef, forwardRef, HostListener, Inject, Input, Renderer2 } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import * as i0 from "@angular/core";
4
+ export class ContenteditableValueAccessor {
5
+ constructor(elementRef, renderer) {
6
+ this.elementRef = elementRef;
7
+ this.renderer = renderer;
8
+ this.onTouched = () => { };
9
+ this.contenteditable = true; // Allow dynamic input
10
+ this.onChange = (_value) => { };
11
+ this.renderer.setAttribute(this.elementRef.nativeElement, 'contenteditable', 'true');
12
+ }
13
+ ngAfterViewInit() {
14
+ this.renderer.setAttribute(this.elementRef.nativeElement, 'contenteditable', this.contenteditable ? 'true' : 'false');
15
+ this.observer = new MutationObserver(() => {
16
+ this.onChange(this.elementRef.nativeElement.innerHTML);
17
+ });
18
+ this.observer.observe(this.elementRef.nativeElement, {
19
+ characterData: true,
20
+ childList: true,
21
+ subtree: true,
22
+ });
23
+ }
24
+ ngOnDestroy() {
25
+ this.observer?.disconnect();
26
+ }
27
+ onInput() {
28
+ this.observer?.disconnect();
29
+ this.onChange(this.elementRef.nativeElement.innerHTML);
30
+ }
31
+ onBlur() {
32
+ this.onTouched();
33
+ }
34
+ writeValue(value) {
35
+ this.renderer.setProperty(this.elementRef.nativeElement, 'innerHTML', value || '');
36
+ }
37
+ registerOnChange(onChange) {
38
+ this.onChange = onChange;
39
+ }
40
+ registerOnTouched(onTouched) {
41
+ this.onTouched = onTouched;
42
+ }
43
+ setDisabledState(disabled) {
44
+ this.renderer.setAttribute(this.elementRef.nativeElement, 'contenteditable', String(!disabled));
45
+ }
46
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ContenteditableValueAccessor, deps: [{ token: ElementRef }, { token: Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
47
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.1.4", type: ContenteditableValueAccessor, isStandalone: true, selector: "[contenteditable][ngModel]", inputs: { contenteditable: "contenteditable" }, host: { listeners: { "input": "onInput()", "blur": "onBlur()" } }, providers: [
48
+ {
49
+ provide: NG_VALUE_ACCESSOR,
50
+ useExisting: forwardRef(() => ContenteditableValueAccessor),
51
+ multi: true,
52
+ },
53
+ ], ngImport: i0 }); }
54
+ }
55
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ContenteditableValueAccessor, decorators: [{
56
+ type: Directive,
57
+ args: [{
58
+ selector: '[contenteditable][ngModel]',
59
+ providers: [
60
+ {
61
+ provide: NG_VALUE_ACCESSOR,
62
+ useExisting: forwardRef(() => ContenteditableValueAccessor),
63
+ multi: true,
64
+ },
65
+ ],
66
+ standalone: true
67
+ }]
68
+ }], ctorParameters: () => [{ type: i0.ElementRef, decorators: [{
69
+ type: Inject,
70
+ args: [ElementRef]
71
+ }] }, { type: i0.Renderer2, decorators: [{
72
+ type: Inject,
73
+ args: [Renderer2]
74
+ }] }], propDecorators: { contenteditable: [{
75
+ type: Input
76
+ }], onInput: [{
77
+ type: HostListener,
78
+ args: ['input']
79
+ }], onBlur: [{
80
+ type: HostListener,
81
+ args: ['blur']
82
+ }] } });
83
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGVudGVkaXRhYmxlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NpbXBvLXVpL3NyYy9saWIvZGlyZWN0aXZlL2NvbnRlbnRlZGl0YWJsZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFDVCxVQUFVLEVBQ1YsVUFBVSxFQUNWLFlBQVksRUFDWixNQUFNLEVBQ04sS0FBSyxFQUVMLFNBQVMsRUFDVixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQXVCLGlCQUFpQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7O0FBY3ZFLE1BQU0sT0FBTyw0QkFBNEI7SUFTdkMsWUFDdUMsVUFBK0IsRUFDaEMsUUFBbUI7UUFEbEIsZUFBVSxHQUFWLFVBQVUsQ0FBcUI7UUFDaEMsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQVRqRCxjQUFTLEdBQUcsR0FBRyxFQUFFLEdBQUUsQ0FBQyxDQUFDO1FBQ3BCLG9CQUFlLEdBQUcsSUFBSSxDQUFDLENBQUMsc0JBQXNCO1FBRS9DLGFBQVEsR0FBRyxDQUFDLE1BQWMsRUFBRSxFQUFFLEdBQUUsQ0FBQyxDQUFDO1FBUXhDLElBQUksQ0FBQyxRQUFRLENBQUMsWUFBWSxDQUN4QixJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsRUFDN0IsaUJBQWlCLEVBQ2pCLE1BQU0sQ0FDUCxDQUFDO0lBQ0osQ0FBQztJQUVELGVBQWU7UUFDYixJQUFJLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FDeEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEVBQzdCLGlCQUFpQixFQUNqQixJQUFJLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FDeEMsQ0FBQztRQUVGLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxnQkFBZ0IsQ0FBQyxHQUFHLEVBQUU7WUFDeEMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUN6RCxDQUFDLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxFQUFFO1lBQ2pELGFBQWEsRUFBRSxJQUFJO1lBQ25CLFNBQVMsRUFBRSxJQUFJO1lBQ2YsT0FBTyxFQUFFLElBQUk7U0FDaEIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsUUFBUSxFQUFFLFVBQVUsRUFBRSxDQUFDO0lBQzlCLENBQUM7SUFHRCxPQUFPO1FBQ0wsSUFBSSxDQUFDLFFBQVEsRUFBRSxVQUFVLEVBQUUsQ0FBQztRQUM1QixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxDQUFDO0lBQ3pELENBQUM7SUFHRCxNQUFNO1FBQ0osSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ25CLENBQUM7SUFFRCxVQUFVLENBQUMsS0FBYTtRQUN0QixJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FDdkIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEVBQzdCLFdBQVcsRUFDWCxLQUFLLElBQUksRUFBRSxDQUNaLENBQUM7SUFDSixDQUFDO0lBRUQsZ0JBQWdCLENBQUMsUUFBaUM7UUFDaEQsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUM7SUFDM0IsQ0FBQztJQUVELGlCQUFpQixDQUFDLFNBQXFCO1FBQ3JDLElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO0lBQzdCLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxRQUFpQjtRQUNoQyxJQUFJLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FDeEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEVBQzdCLGlCQUFpQixFQUNqQixNQUFNLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FDbEIsQ0FBQztJQUNKLENBQUM7OEdBM0VVLDRCQUE0QixrQkFVN0IsVUFBVSxhQUNWLFNBQVM7a0dBWFIsNEJBQTRCLDRMQVQ1QjtZQUNUO2dCQUNFLE9BQU8sRUFBRSxpQkFBaUI7Z0JBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsNEJBQTRCLENBQUM7Z0JBQzNELEtBQUssRUFBRSxJQUFJO2FBQ1o7U0FDRjs7MkZBR1UsNEJBQTRCO2tCQVp4QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFDTiw0QkFBNEI7b0JBQzlCLFNBQVMsRUFBRTt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSw2QkFBNkIsQ0FBQzs0QkFDM0QsS0FBSyxFQUFFLElBQUk7eUJBQ1o7cUJBQ0Y7b0JBQ0QsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOzswQkFXSSxNQUFNOzJCQUFDLFVBQVU7OzBCQUNqQixNQUFNOzJCQUFDLFNBQVM7eUNBUlYsZUFBZTtzQkFBdkIsS0FBSztnQkF3Q04sT0FBTztzQkFETixZQUFZO3VCQUFDLE9BQU87Z0JBT3JCLE1BQU07c0JBREwsWUFBWTt1QkFBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBBZnRlclZpZXdJbml0LFxyXG4gIERpcmVjdGl2ZSxcclxuICBFbGVtZW50UmVmLFxyXG4gIGZvcndhcmRSZWYsXHJcbiAgSG9zdExpc3RlbmVyLFxyXG4gIEluamVjdCxcclxuICBJbnB1dCxcclxuICBPbkRlc3Ryb3ksXHJcbiAgUmVuZGVyZXIyXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7Q29udHJvbFZhbHVlQWNjZXNzb3IsIE5HX1ZBTFVFX0FDQ0VTU09SfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICBzZWxlY3RvcjpcclxuICAgICdbY29udGVudGVkaXRhYmxlXVtuZ01vZGVsXScsXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICB7XHJcbiAgICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxyXG4gICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBDb250ZW50ZWRpdGFibGVWYWx1ZUFjY2Vzc29yKSxcclxuICAgICAgbXVsdGk6IHRydWUsXHJcbiAgICB9LFxyXG4gIF0sXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ29udGVudGVkaXRhYmxlVmFsdWVBY2Nlc3NvclxyXG4gIGltcGxlbWVudHMgQ29udHJvbFZhbHVlQWNjZXNzb3IsIEFmdGVyVmlld0luaXQsIE9uRGVzdHJveSB7XHJcbiAgcHJpdmF0ZSBvblRvdWNoZWQgPSAoKSA9PiB7fTtcclxuICBASW5wdXQoKSBjb250ZW50ZWRpdGFibGUgPSB0cnVlOyAvLyBBbGxvdyBkeW5hbWljIGlucHV0XHJcblxyXG4gIHByaXZhdGUgb25DaGFuZ2UgPSAoX3ZhbHVlOiBzdHJpbmcpID0+IHt9O1xyXG5cclxuICBwcml2YXRlIG9ic2VydmVyPzogTXV0YXRpb25PYnNlcnZlcjtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBASW5qZWN0KEVsZW1lbnRSZWYpIHByaXZhdGUgcmVhZG9ubHkgZWxlbWVudFJlZjogRWxlbWVudFJlZjxFbGVtZW50PixcclxuICAgIEBJbmplY3QoUmVuZGVyZXIyKSBwcml2YXRlIHJlYWRvbmx5IHJlbmRlcmVyOiBSZW5kZXJlcjIsXHJcbiAgKSB7XHJcbiAgICB0aGlzLnJlbmRlcmVyLnNldEF0dHJpYnV0ZShcclxuICAgICAgdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQsXHJcbiAgICAgICdjb250ZW50ZWRpdGFibGUnLFxyXG4gICAgICAndHJ1ZSdcclxuICAgICk7XHJcbiAgfVxyXG5cclxuICBuZ0FmdGVyVmlld0luaXQoKSB7XHJcbiAgICB0aGlzLnJlbmRlcmVyLnNldEF0dHJpYnV0ZShcclxuICAgICAgdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQsXHJcbiAgICAgICdjb250ZW50ZWRpdGFibGUnLFxyXG4gICAgICB0aGlzLmNvbnRlbnRlZGl0YWJsZSA/ICd0cnVlJyA6ICdmYWxzZSdcclxuICAgICk7XHJcblxyXG4gICAgdGhpcy5vYnNlcnZlciA9IG5ldyBNdXRhdGlvbk9ic2VydmVyKCgpID0+IHtcclxuICAgICAgdGhpcy5vbkNoYW5nZSh0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5pbm5lckhUTUwpO1xyXG4gICAgfSk7XHJcblxyXG4gICAgdGhpcy5vYnNlcnZlci5vYnNlcnZlKHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LCB7XHJcbiAgICAgICAgY2hhcmFjdGVyRGF0YTogdHJ1ZSxcclxuICAgICAgICBjaGlsZExpc3Q6IHRydWUsXHJcbiAgICAgICAgc3VidHJlZTogdHJ1ZSxcclxuICAgIH0pO1xyXG4gIH1cclxuXHJcbiAgbmdPbkRlc3Ryb3koKSB7XHJcbiAgICB0aGlzLm9ic2VydmVyPy5kaXNjb25uZWN0KCk7XHJcbiAgfVxyXG5cclxuICBASG9zdExpc3RlbmVyKCdpbnB1dCcpXHJcbiAgb25JbnB1dCgpIHtcclxuICAgIHRoaXMub2JzZXJ2ZXI/LmRpc2Nvbm5lY3QoKTtcclxuICAgIHRoaXMub25DaGFuZ2UodGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuaW5uZXJIVE1MKTtcclxuICB9XHJcblxyXG4gIEBIb3N0TGlzdGVuZXIoJ2JsdXInKVxyXG4gIG9uQmx1cigpIHtcclxuICAgIHRoaXMub25Ub3VjaGVkKCk7XHJcbiAgfVxyXG5cclxuICB3cml0ZVZhbHVlKHZhbHVlOiBzdHJpbmcpIHtcclxuICAgIHRoaXMucmVuZGVyZXIuc2V0UHJvcGVydHkoXHJcbiAgICAgIHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LFxyXG4gICAgICAnaW5uZXJIVE1MJyxcclxuICAgICAgdmFsdWUgfHwgJydcclxuICAgICk7XHJcbiAgfVxyXG5cclxuICByZWdpc3Rlck9uQ2hhbmdlKG9uQ2hhbmdlOiAodmFsdWU6IHN0cmluZykgPT4gdm9pZCkge1xyXG4gICAgdGhpcy5vbkNoYW5nZSA9IG9uQ2hhbmdlO1xyXG4gIH1cclxuXHJcbiAgcmVnaXN0ZXJPblRvdWNoZWQob25Ub3VjaGVkOiAoKSA9PiB2b2lkKSB7XHJcbiAgICB0aGlzLm9uVG91Y2hlZCA9IG9uVG91Y2hlZDtcclxuICB9XHJcblxyXG4gIHNldERpc2FibGVkU3RhdGUoZGlzYWJsZWQ6IGJvb2xlYW4pOiB2b2lkIHtcclxuICAgIHRoaXMucmVuZGVyZXIuc2V0QXR0cmlidXRlKFxyXG4gICAgICB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudCxcclxuICAgICAgJ2NvbnRlbnRlZGl0YWJsZScsXHJcbiAgICAgIFN0cmluZyghZGlzYWJsZWQpXHJcbiAgICApO1xyXG4gIH1cclxufVxyXG4iXX0=
@@ -0,0 +1,215 @@
1
+ import { Component, Input, ViewChild } from '@angular/core';
2
+ import { FormsModule } from '@angular/forms';
3
+ import { ContenteditableValueAccessor } from '../../directive/contenteditable.directive';
4
+ import { CommonModule } from '@angular/common';
5
+ import { MatIconModule } from '@angular/material/icon';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/common";
8
+ import * as i2 from "@angular/forms";
9
+ import * as i3 from "@angular/material/icon";
10
+ export class TextEditorComponent {
11
+ constructor() {
12
+ this.value = '<p>Hello this is palash makhija</p>';
13
+ this.editable = false;
14
+ this.show = false;
15
+ this.toolbarX = 0;
16
+ this.toolbarY = 0;
17
+ this.toolbarData = {
18
+ selectedHeading: '',
19
+ isBold: false,
20
+ isItalic: false,
21
+ isUnderlined: false,
22
+ selectedSize: '',
23
+ selectedList: '',
24
+ selectedAlignment: '',
25
+ selectedColor: ''
26
+ };
27
+ }
28
+ ngOnInit() {
29
+ document.addEventListener('mousedown', this.hideToolbar.bind(this));
30
+ }
31
+ ngOnDestroy() {
32
+ document.removeEventListener('mousedown', this.hideToolbar.bind(this));
33
+ }
34
+ showToolbar(event) {
35
+ const selection = window.getSelection();
36
+ if (selection && selection.toString().trim() !== '') {
37
+ const range = selection.getRangeAt(0);
38
+ const rect = range.getBoundingClientRect();
39
+ // Toolbar dimensions (adjust if necessary)
40
+ const toolbarWidth = 630; // Replace with actual width
41
+ const toolbarHeight = 45; // Replace with actual height
42
+ const margin = 10;
43
+ // Get viewport dimensions
44
+ const viewportWidth = window.innerWidth;
45
+ // Always center horizontally on X-axis
46
+ let newXViewport = rect.left + (rect.width / 2) - (toolbarWidth / 2); // Center horizontally
47
+ // Prevent X-axis overflow
48
+ if (newXViewport + toolbarWidth > viewportWidth) {
49
+ newXViewport = Math.max(0, viewportWidth - toolbarWidth - margin); // Adjust for right overflow
50
+ }
51
+ else if (newXViewport < 0) {
52
+ newXViewport = margin; // Adjust for left overflow
53
+ }
54
+ // Keep Y-axis position fixed above the selection by default
55
+ let newYViewport = rect.top - toolbarHeight - margin;
56
+ // Adjust Y-axis if there’s no space above the selection
57
+ if (newYViewport < 0) {
58
+ newYViewport = rect.bottom + margin; // Move below selection
59
+ }
60
+ // Convert to page coordinates
61
+ this.toolbarX = newXViewport + window.scrollX;
62
+ this.toolbarY = newYViewport + window.scrollY;
63
+ this.reFormattingData();
64
+ this.readFormattingProperties();
65
+ this.show = true;
66
+ }
67
+ else {
68
+ this.show = false;
69
+ }
70
+ }
71
+ hideToolbar(event) {
72
+ const clickedInsideEditor = this.editor?.nativeElement.contains(event.target);
73
+ const clickedInsideToolbar = this.toolbar?.nativeElement.contains(event.target);
74
+ // Hide the toolbar if the click is outside both the editor and toolbar
75
+ if (!clickedInsideEditor && !clickedInsideToolbar) {
76
+ this.show = false;
77
+ }
78
+ }
79
+ formatText(command, value = '') {
80
+ // if (command === 'formatBlock') {
81
+ // const selection = window.getSelection();
82
+ // if (!selection || selection.rangeCount === 0) return;
83
+ // const range = selection.getRangeAt(0);
84
+ // const selectedText = selection.toString();
85
+ // if (selectedText) {
86
+ // const newElement = document.createElement(value);
87
+ // newElement.textContent = selectedText;
88
+ // range.deleteContents();
89
+ // range.insertNode(newElement);
90
+ // this.toolbarData.selectedHeading = value;
91
+ // return;
92
+ // }
93
+ // }
94
+ document.execCommand(command, false, value);
95
+ if (command === 'bold')
96
+ this.toolbarData.isBold = !this.toolbarData.isBold;
97
+ if (command === 'italic')
98
+ this.toolbarData.isItalic = !this.toolbarData.isItalic;
99
+ if (command === 'underline')
100
+ this.toolbarData.isUnderlined = !this.toolbarData.isUnderlined;
101
+ if (command === 'insertOrderedList' || command === 'insertUnorderedList')
102
+ this.toolbarData.selectedList = command === this.toolbarData.selectedList ? '' : command;
103
+ if (command === 'justifyLeft' || command === 'justifyCenter' || command === 'justifyRight')
104
+ this.toolbarData.selectedAlignment = command === this.toolbarData.selectedAlignment ? '' : command;
105
+ if (command === 'formatBlock')
106
+ this.toolbarData.selectedHeading = value;
107
+ }
108
+ changeFontSize(event) {
109
+ const size = event.target.value;
110
+ // Apply a default size of 4 (needed for execCommand to work)
111
+ document.execCommand('fontSize', false, '4');
112
+ // Convert selected font elements to have actual font-size instead of "size" attribute
113
+ const elements = document.querySelectorAll("font[size='4']");
114
+ elements.forEach(el => {
115
+ const htmlElement = el; // ✅ Explicitly cast to HTMLElement
116
+ htmlElement.removeAttribute('size'); // Remove old size attribute
117
+ htmlElement.style.fontSize = size; // Apply CSS font size
118
+ });
119
+ this.toolbarData.selectedSize = size;
120
+ // this.show = false; // Hide toolbar after action
121
+ }
122
+ changeColor(event) {
123
+ const color = event.target.value;
124
+ document.execCommand('foreColor', false, color);
125
+ this.toolbarData.selectedColor = color;
126
+ // this.show = false;
127
+ }
128
+ updateText(event) {
129
+ }
130
+ onFormatChange(event) {
131
+ const selectedValue = event.target.value;
132
+ this.formatText('formatBlock', selectedValue);
133
+ }
134
+ openColorPicker() {
135
+ this.colorPicker.nativeElement.click(); // Programmatically trigger input
136
+ }
137
+ readFormattingProperties() {
138
+ const selection = window.getSelection();
139
+ if (!selection)
140
+ return;
141
+ const node = selection.focusNode;
142
+ // Check if node is null
143
+ if (!node)
144
+ return;
145
+ let element = node.parentElement;
146
+ while (element) {
147
+ const nodeName = element.nodeName;
148
+ if (nodeName === 'H1' || nodeName === 'H2' || nodeName === 'H3') {
149
+ this.toolbarData.selectedHeading = nodeName;
150
+ }
151
+ else if (nodeName === 'B' || nodeName === 'STRONG') {
152
+ this.toolbarData.isBold = true;
153
+ }
154
+ else if (nodeName === 'I' || nodeName === 'EM') {
155
+ this.toolbarData.isItalic = true;
156
+ }
157
+ else if (nodeName === 'U') {
158
+ this.toolbarData.isUnderlined = true;
159
+ }
160
+ else if (nodeName === 'OL') {
161
+ this.toolbarData.selectedList = 'insertOrderedList';
162
+ }
163
+ else if (nodeName === 'UL') {
164
+ this.toolbarData.selectedList = 'insertUnorderedList';
165
+ }
166
+ else if (element.style.textAlign) {
167
+ this.toolbarData.selectedAlignment = `justify${element.style.textAlign.charAt(0).toUpperCase() + element.style.textAlign.slice(1)}`;
168
+ }
169
+ else if (element.style.fontSize) {
170
+ this.toolbarData.selectedSize = element.style.fontSize;
171
+ }
172
+ else if (element.style.color) {
173
+ this.toolbarData.selectedColor = element.style.color;
174
+ }
175
+ element = element.parentElement;
176
+ }
177
+ }
178
+ reFormattingData() {
179
+ this.toolbarData = {
180
+ selectedHeading: '',
181
+ isBold: false,
182
+ isItalic: false,
183
+ isUnderlined: false,
184
+ selectedSize: '',
185
+ selectedList: '',
186
+ selectedAlignment: '',
187
+ selectedColor: ''
188
+ };
189
+ }
190
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: TextEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
191
+ 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" }, 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 }], ngImport: i0, template: "<div class=\"editor-container\" [ngClass]=\"{'border': editable}\">\r\n <div [contenteditable]=\"editable\" [(ngModel)]=\"value\" class=\"editable-text\" (mouseup)=\"showToolbar($event)\" #editor\r\n (input)=\"updateText($event)\" (mousedown)=\"hideToolbar($event)\">\r\n </div>\r\n\r\n <div class=\"toolbar\" *ngIf=\"editable && show\" [ngStyle]=\"{'top.px': toolbarY, 'left.px': toolbarX}\" #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>\r\n", styles: [".editor-container{display:inline-block;width:100%}.editor-container div{outline:none}.editable-text{padding:4px;border-bottom:1px dashed #ccc;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-color:#0496ff!important;color:#fff;border-radius:5px}p{margin-bottom:0rem!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.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: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }] }); }
192
+ }
193
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: TextEditorComponent, decorators: [{
194
+ type: Component,
195
+ args: [{ selector: 'simpo-text-editor', standalone: true, imports: [
196
+ CommonModule,
197
+ FormsModule,
198
+ ContenteditableValueAccessor,
199
+ MatIconModule
200
+ ], template: "<div class=\"editor-container\" [ngClass]=\"{'border': editable}\">\r\n <div [contenteditable]=\"editable\" [(ngModel)]=\"value\" class=\"editable-text\" (mouseup)=\"showToolbar($event)\" #editor\r\n (input)=\"updateText($event)\" (mousedown)=\"hideToolbar($event)\">\r\n </div>\r\n\r\n <div class=\"toolbar\" *ngIf=\"editable && show\" [ngStyle]=\"{'top.px': toolbarY, 'left.px': toolbarX}\" #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>\r\n", styles: [".editor-container{display:inline-block;width:100%}.editor-container div{outline:none}.editable-text{padding:4px;border-bottom:1px dashed #ccc;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-color:#0496ff!important;color:#fff;border-radius:5px}p{margin-bottom:0rem!important}\n"] }]
201
+ }], ctorParameters: () => [], propDecorators: { toolbar: [{
202
+ type: ViewChild,
203
+ args: ['toolbar', { static: false }]
204
+ }], editor: [{
205
+ type: ViewChild,
206
+ args: ['editor', { static: false }]
207
+ }], colorPicker: [{
208
+ type: ViewChild,
209
+ args: ['colorPicker']
210
+ }], value: [{
211
+ type: Input
212
+ }], editable: [{
213
+ type: Input
214
+ }] } });
215
+ //# 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, Input, ViewChild } from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { ContenteditableValueAccessor } from '../../directive/contenteditable.directive';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MatIconModule } from '@angular/material/icon';\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\r\n  @Input() value: string = '<p>Hello this is palash makhija</p>';\r\n  @Input() editable: boolean = false;\r\n\r\n  show = false;\r\n  toolbarX = 0;\r\n  toolbarY = 0;\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() { }\r\n\r\n  ngOnInit() {\r\n    document.addEventListener('mousedown', this.hideToolbar.bind(this));\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    document.removeEventListener('mousedown', this.hideToolbar.bind(this));\r\n  }\r\n\r\n  showToolbar(event: MouseEvent) {\r\n    const selection = window.getSelection();\r\n    if (selection && selection.toString().trim() !== '') {\r\n      const range = selection.getRangeAt(0);\r\n      const rect = range.getBoundingClientRect();\r\n\r\n      // Toolbar dimensions (adjust if necessary)\r\n      const toolbarWidth = 630; // Replace with actual width\r\n      const toolbarHeight = 45; // Replace with actual height\r\n      const margin = 10;\r\n\r\n      // Get viewport dimensions\r\n      const viewportWidth = window.innerWidth;\r\n\r\n      // Always center horizontally on X-axis\r\n      let newXViewport = rect.left + (rect.width / 2) - (toolbarWidth / 2); // Center horizontally\r\n\r\n      // Prevent X-axis overflow\r\n      if (newXViewport + toolbarWidth > viewportWidth) {\r\n        newXViewport = Math.max(0, viewportWidth - toolbarWidth - margin); // Adjust for right overflow\r\n      } else if (newXViewport < 0) {\r\n        newXViewport = margin; // Adjust for left overflow\r\n      }\r\n\r\n      // Keep Y-axis position fixed above the selection by default\r\n      let newYViewport = rect.top - toolbarHeight - margin;\r\n\r\n      // Adjust Y-axis if there’s no space above the selection\r\n      if (newYViewport < 0) {\r\n        newYViewport = rect.bottom + margin; // Move below selection\r\n      }\r\n\r\n      // Convert to page coordinates\r\n      this.toolbarX = newXViewport + window.scrollX;\r\n      this.toolbarY = newYViewport + window.scrollY;\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    const clickedInsideEditor = this.editor?.nativeElement.contains(event.target);\r\n    const clickedInsideToolbar = this.toolbar?.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  }\r\n\r\n  formatText(command: string, value: string = '') {\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    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.show = false; // Hide toolbar after action\r\n  }\r\n\r\n  changeColor(event: any) {\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  }\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    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","<div class=\"editor-container\" [ngClass]=\"{'border': editable}\">\r\n  <div [contenteditable]=\"editable\" [(ngModel)]=\"value\" class=\"editable-text\" (mouseup)=\"showToolbar($event)\" #editor\r\n    (input)=\"updateText($event)\" (mousedown)=\"hideToolbar($event)\">\r\n  </div>\r\n\r\n  <div class=\"toolbar\" *ngIf=\"editable && show\" [ngStyle]=\"{'top.px': toolbarY, 'left.px': toolbarX}\" #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>\r\n"]}
@@ -0,0 +1,66 @@
1
+ import { Component, HostListener, Input } from '@angular/core';
2
+ import { ColorDirective } from '../../directive/color.directive';
3
+ import { CommonModule } from '@angular/common';
4
+ import { SociaIconsComponent } from './../../elements/socia-icons/socia-icons.component';
5
+ import { SanitizeHtmlPipe } from '../../services/sanitizeHtml';
6
+ import { FormsModule } from '@angular/forms';
7
+ import { BackgroundDirective } from '../../directive/background-directive';
8
+ import { SpacingHorizontalDirective } from '../../directive/spacing-horizontal.directive';
9
+ import { ContentFitDirective } from '../../directive/content-fit-directive';
10
+ import { TextEditorComponent } from '../../elements/text-editor/text-editor.component';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "@angular/common";
13
+ export class FooterComponent {
14
+ constructor() {
15
+ this.edit = true;
16
+ this.delete = false;
17
+ this.footerType = "1";
18
+ this.screenWidth = 475;
19
+ this.pageLink = "About Us";
20
+ this.pages = ["Mission", "Our Team", "Awards", "Testimonials", "Privacy Policy"];
21
+ this.getScreenSize();
22
+ }
23
+ async ngOnInit() {
24
+ this.style = this.data?.styles;
25
+ this.content = this.data?.content;
26
+ }
27
+ getScreenSize(event) {
28
+ if (typeof window !== 'undefined') {
29
+ this.screenWidth = window.innerWidth;
30
+ }
31
+ }
32
+ get stylesLayout() {
33
+ return { ...this.style?.layout };
34
+ }
35
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: FooterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
36
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: FooterComponent, isStandalone: true, selector: "simpo-footer", inputs: { data: "data", index: "index", edit: "edit", delete: "delete" }, host: { listeners: { "window:resize": "getScreenSize($event)" } }, ngImport: i0, template: "<section class=\"total-container\">\r\n <div [spacingHorizontal]=\"stylesLayout\" [simpoBackground]=\"style?.background\" [simpoLayout]=\"style?.layout\">\r\n <ng-container *ngTemplateOutlet=\"footer1\"></ng-container>\r\n </div>\r\n</section>\r\n\r\n<ng-template #footer1>\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-md-4\">\r\n <div>\r\n <ng-container *ngTemplateOutlet=\"logoSection\"></ng-container>\r\n </div>\r\n <div>\r\n <ng-container *ngTemplateOutlet=\"descSection\"></ng-container>\r\n </div>\r\n <div *ngIf=\"content?.socialLinks?.display && screenWidth > 475\">\r\n <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n </div>\r\n </div>\r\n <div class=\"col-md-8\">\r\n <div class=\"row\">\r\n <ng-container *ngTemplateOutlet=\"pagesVertical\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"foldersVertical\"></ng-container>\r\n </div>\r\n <div *ngIf=\"content?.socialLinks?.display && screenWidth < 475\" class=\"d-flex justify-content-center\">\r\n <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n <hr *ngIf=\"content?.displayBranding\">\r\n <div *ngIf=\"content?.displayBranding\">\r\n <ng-container *ngTemplateOutlet=\"branding\"></ng-container>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #footer2>\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-md-3\">\r\n <div>\r\n <ng-container *ngTemplateOutlet=\"logoSection\"></ng-container>\r\n </div>\r\n <div>\r\n <ng-container *ngTemplateOutlet=\"descSection\"></ng-container>\r\n </div>\r\n <div *ngIf=\"content?.socialLinks?.display && screenWidth > 475\" >\r\n <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n </div>\r\n </div>\r\n <div class=\"col-md-9\">\r\n <div class=\"row\">\r\n <ng-container *ngTemplateOutlet=\"pagesHorizontal\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"foldersHorizontal\"></ng-container>\r\n </div>\r\n <div *ngIf=\"content?.socialLinks?.display && screenWidth < 475\" class=\"d-flex justify-content-center\">\r\n <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n <hr *ngIf=\"content?.displayBranding\">\r\n <div *ngIf=\"content?.displayBranding\">\r\n <ng-container *ngTemplateOutlet=\"branding\"></ng-container>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #footer3>\r\n <div class=\"row\" [class.align-items-start]=\"screenWidth < 475\">\r\n <ng-container *ngTemplateOutlet=\"pagesVertical\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"foldersVertical\"></ng-container>\r\n </div>\r\n <hr>\r\n <div class=\"row justify-content-between\">\r\n <div class=\"col-md-4\" [class.w-30]=\"screenWidth < 475\">\r\n <ng-container *ngTemplateOutlet=\"logoSection\"></ng-container>\r\n </div>\r\n <div class=\"col-md-4 d-flex justify-content-center align-items-start\" *ngIf=\"content?.socialLinks?.display\" [class.w-30]=\"screenWidth < 475\">\r\n <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n </div>\r\n <div class=\"col-md-4 d-flex justify-content-end\" *ngIf=\"content?.displayBranding\" [class.w-30]=\"screenWidth < 475\">\r\n <ng-container *ngTemplateOutlet=\"branding\"></ng-container>\r\n </div>\r\n </div>\r\n\r\n</ng-template>\r\n\r\n<ng-template #footer4>\r\n <div class=\"row align-items-center\">\r\n <ng-container *ngTemplateOutlet=\"pagesHorizontal\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"foldersHorizontal\"></ng-container>\r\n </div>\r\n <hr>\r\n <div class=\"row justify-content-between\">\r\n <div class=\"col-md-4\">\r\n <ng-container *ngTemplateOutlet=\"logoSection\"></ng-container>\r\n </div>\r\n <div class=\"col-md-4 d-flex justify-content-center align-items-start\" *ngIf=\"content?.socialLinks?.display\">\r\n <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n </div>\r\n <div class=\"col-md-4 d-flex justify-content-end\" *ngIf=\"content?.displayBranding\">\r\n <ng-container *ngTemplateOutlet=\"branding\"></ng-container>\r\n </div>\r\n </div>\r\n\r\n</ng-template>\r\n\r\n<ng-template #logoSection>\r\n <div class=\"d-flex\" [class.justify-content-center]=\"screenWidth < 475\">\r\n <div class=\"d-flex gap-3 align-items-lg-center cursor-pointer mb-4\"\r\n *ngIf=\"!content?.logo?.isImage || !content?.logo?.image?.url\">\r\n <div *ngIf=\"content?.logo?.text?.isIcon && content?.logo?.text?.url\">\r\n <img loading=\"lazy\" [src]=\"content?.logo?.text?.url\" alt=\"logo\" [width]=\"content?.logo?.size\" loading=\"lazy\">\r\n </div>\r\n <div class=\"heading-small\" *ngIf=\"content?.logo?.text?.isText\" [simpoColor]=\"style?.background?.color\">\r\n <b [ngStyle]=\"{'font-family': content?.logo?.text?.fontFamily}\">{{content?.siteName?.value}}</b>\r\n </div>\r\n </div>\r\n <div class=\"d-flex gap-3 align-items-lg-center cursor-pointer mb-4\"\r\n *ngIf=\"content?.logo?.isImage && content?.logo?.image?.url\">\r\n <img loading=\"lazy\" [src]=\"content?.logo?.image?.url\" alt=\"logo\"\r\n [style.width.%]=\"screenWidth > 475 || (content?.logo?.size || 10) < 50 ? content?.logo?.size : ((content?.logo?.size || 10) - 10)\"\r\n loading=\"lazy\">\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #descSection>\r\n <simpo-text-editor [value]=\"content?.additionalDetails?.value || ''\" [editable]=\"edit || false\"></simpo-text-editor>\r\n <!-- <div class=\"description\" [innerHTML]=\"content?.additionalDetails?.value ?? '' | sanitizeHtml\"></div> -->\r\n</ng-template>\r\n\r\n<ng-template #socialIcons>\r\n <div class=\"d-flex align-items-start align-items-lg-center flex-column flex-lg-row gap-lg-0 gap-3\"\r\n [ngClass]=\"content?.socialLinks?.display ? 'justify-content-between' : 'justify-content-end'\">\r\n <div class=\"d-flex mt-0\" *ngIf=\"content?.socialLinks?.display\">\r\n <ng-container *ngFor=\"let item of content?.socialLinks?.channels\">\r\n <div class=\"icons\">\r\n <simpo-socia-icons [iconColor]=\"data?.styles?.background?.accentColor\" [socialIconData]=\"item\"\r\n [color]=\"style?.background?.color\" [sectionId]=\"data?.id\"></simpo-socia-icons>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #branding>\r\n <div class=\"heading-small text-center branding-text\">Made with <a class=\"branding-text fw-600\"\r\n href=\"https://simpo.ai\" target=\"_blank\">Simpo</a></div>\r\n</ng-template>\r\n\r\n<ng-template #pagesHorizontal>\r\n <div class=\"col-md-3 mb-3 pageType\" [class.w-50]=\"screenWidth < 475\" [class.text-center]=\"screenWidth < 475\">\r\n {{pageLink}}\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #foldersHorizontal>\r\n <div class=\"pageType col-md-3 mb-3\" *ngFor=\"let folder of content?.folder\" [class.w-50]=\"screenWidth < 475\" [class.text-center]=\"screenWidth < 475\">\r\n {{folder.label}}\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #pagesVertical>\r\n <div class=\"page-container col-md-3 mb-3\" [class.w-50]=\"screenWidth < 475\">\r\n <div class=\"pageType mb-3\">{{pageLink}}</div>\r\n <ng-container *ngFor=\"let page of pages\">\r\n <div class=\"pages mb-2\">{{page}}</div>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #foldersVertical>\r\n <div class=\"page-container col-md-3 mb-3\" *ngFor=\"let folder of content?.folder\" [class.w-50]=\"screenWidth < 475\">\r\n <!-- <div class=\"pageType mb-3\">{{folder.label}}</div> -->\r\n <simpo-text-editor [value]=\"folder.label\" [editable]=\"edit || false\"></simpo-text-editor>\r\n <div class=\"mt-15\">\r\n <ng-container *ngFor=\"let page of folder.links\">\r\n <div class=\"pages mb-2\">{{page.label}}</div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n</ng-template>\r\n", styles: [".pageType{font-size:16px;font-weight:600;line-height:22px}.pages{font-size:16px;font-weight:400;line-height:22px}.branding-text{font-size:16px;font-weight:400;line-height:22px;text-decoration:unset}.fw-600{font-weight:600!important}.w-50{width:50%!important}.w-30{width:30%!important}.align-items-start{align-items:start!important}.mt-15{margin-top:15px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: ColorDirective, selector: "[simpoColor]", inputs: ["simpoColor"] }, { kind: "component", type: SociaIconsComponent, selector: "simpo-socia-icons", inputs: ["socialIconData", "color", "sectionId", "iconColor"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type:
37
+ //directives
38
+ SpacingHorizontalDirective, selector: "[spacingHorizontal]", inputs: ["spacingHorizontal", "isHeader"] }, { kind: "directive", type: BackgroundDirective, selector: "[simpoBackground]", inputs: ["simpoBackground", "scrollValue"] }, { kind: "directive", type: ContentFitDirective, selector: "[simpoLayout]", inputs: ["simpoLayout"] }, { kind: "component", type: TextEditorComponent, selector: "simpo-text-editor", inputs: ["value", "editable"] }] }); }
39
+ }
40
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: FooterComponent, decorators: [{
41
+ type: Component,
42
+ args: [{ selector: 'simpo-footer', standalone: true, imports: [
43
+ CommonModule,
44
+ ColorDirective,
45
+ SociaIconsComponent,
46
+ FormsModule,
47
+ SanitizeHtmlPipe,
48
+ //directives
49
+ SpacingHorizontalDirective,
50
+ BackgroundDirective,
51
+ ContentFitDirective,
52
+ TextEditorComponent
53
+ ], template: "<section class=\"total-container\">\r\n <div [spacingHorizontal]=\"stylesLayout\" [simpoBackground]=\"style?.background\" [simpoLayout]=\"style?.layout\">\r\n <ng-container *ngTemplateOutlet=\"footer1\"></ng-container>\r\n </div>\r\n</section>\r\n\r\n<ng-template #footer1>\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-md-4\">\r\n <div>\r\n <ng-container *ngTemplateOutlet=\"logoSection\"></ng-container>\r\n </div>\r\n <div>\r\n <ng-container *ngTemplateOutlet=\"descSection\"></ng-container>\r\n </div>\r\n <div *ngIf=\"content?.socialLinks?.display && screenWidth > 475\">\r\n <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n </div>\r\n </div>\r\n <div class=\"col-md-8\">\r\n <div class=\"row\">\r\n <ng-container *ngTemplateOutlet=\"pagesVertical\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"foldersVertical\"></ng-container>\r\n </div>\r\n <div *ngIf=\"content?.socialLinks?.display && screenWidth < 475\" class=\"d-flex justify-content-center\">\r\n <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n <hr *ngIf=\"content?.displayBranding\">\r\n <div *ngIf=\"content?.displayBranding\">\r\n <ng-container *ngTemplateOutlet=\"branding\"></ng-container>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #footer2>\r\n <div class=\"row align-items-center\">\r\n <div class=\"col-md-3\">\r\n <div>\r\n <ng-container *ngTemplateOutlet=\"logoSection\"></ng-container>\r\n </div>\r\n <div>\r\n <ng-container *ngTemplateOutlet=\"descSection\"></ng-container>\r\n </div>\r\n <div *ngIf=\"content?.socialLinks?.display && screenWidth > 475\" >\r\n <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n </div>\r\n </div>\r\n <div class=\"col-md-9\">\r\n <div class=\"row\">\r\n <ng-container *ngTemplateOutlet=\"pagesHorizontal\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"foldersHorizontal\"></ng-container>\r\n </div>\r\n <div *ngIf=\"content?.socialLinks?.display && screenWidth < 475\" class=\"d-flex justify-content-center\">\r\n <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n <hr *ngIf=\"content?.displayBranding\">\r\n <div *ngIf=\"content?.displayBranding\">\r\n <ng-container *ngTemplateOutlet=\"branding\"></ng-container>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #footer3>\r\n <div class=\"row\" [class.align-items-start]=\"screenWidth < 475\">\r\n <ng-container *ngTemplateOutlet=\"pagesVertical\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"foldersVertical\"></ng-container>\r\n </div>\r\n <hr>\r\n <div class=\"row justify-content-between\">\r\n <div class=\"col-md-4\" [class.w-30]=\"screenWidth < 475\">\r\n <ng-container *ngTemplateOutlet=\"logoSection\"></ng-container>\r\n </div>\r\n <div class=\"col-md-4 d-flex justify-content-center align-items-start\" *ngIf=\"content?.socialLinks?.display\" [class.w-30]=\"screenWidth < 475\">\r\n <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n </div>\r\n <div class=\"col-md-4 d-flex justify-content-end\" *ngIf=\"content?.displayBranding\" [class.w-30]=\"screenWidth < 475\">\r\n <ng-container *ngTemplateOutlet=\"branding\"></ng-container>\r\n </div>\r\n </div>\r\n\r\n</ng-template>\r\n\r\n<ng-template #footer4>\r\n <div class=\"row align-items-center\">\r\n <ng-container *ngTemplateOutlet=\"pagesHorizontal\"></ng-container>\r\n <ng-container *ngTemplateOutlet=\"foldersHorizontal\"></ng-container>\r\n </div>\r\n <hr>\r\n <div class=\"row justify-content-between\">\r\n <div class=\"col-md-4\">\r\n <ng-container *ngTemplateOutlet=\"logoSection\"></ng-container>\r\n </div>\r\n <div class=\"col-md-4 d-flex justify-content-center align-items-start\" *ngIf=\"content?.socialLinks?.display\">\r\n <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n </div>\r\n <div class=\"col-md-4 d-flex justify-content-end\" *ngIf=\"content?.displayBranding\">\r\n <ng-container *ngTemplateOutlet=\"branding\"></ng-container>\r\n </div>\r\n </div>\r\n\r\n</ng-template>\r\n\r\n<ng-template #logoSection>\r\n <div class=\"d-flex\" [class.justify-content-center]=\"screenWidth < 475\">\r\n <div class=\"d-flex gap-3 align-items-lg-center cursor-pointer mb-4\"\r\n *ngIf=\"!content?.logo?.isImage || !content?.logo?.image?.url\">\r\n <div *ngIf=\"content?.logo?.text?.isIcon && content?.logo?.text?.url\">\r\n <img loading=\"lazy\" [src]=\"content?.logo?.text?.url\" alt=\"logo\" [width]=\"content?.logo?.size\" loading=\"lazy\">\r\n </div>\r\n <div class=\"heading-small\" *ngIf=\"content?.logo?.text?.isText\" [simpoColor]=\"style?.background?.color\">\r\n <b [ngStyle]=\"{'font-family': content?.logo?.text?.fontFamily}\">{{content?.siteName?.value}}</b>\r\n </div>\r\n </div>\r\n <div class=\"d-flex gap-3 align-items-lg-center cursor-pointer mb-4\"\r\n *ngIf=\"content?.logo?.isImage && content?.logo?.image?.url\">\r\n <img loading=\"lazy\" [src]=\"content?.logo?.image?.url\" alt=\"logo\"\r\n [style.width.%]=\"screenWidth > 475 || (content?.logo?.size || 10) < 50 ? content?.logo?.size : ((content?.logo?.size || 10) - 10)\"\r\n loading=\"lazy\">\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #descSection>\r\n <simpo-text-editor [value]=\"content?.additionalDetails?.value || ''\" [editable]=\"edit || false\"></simpo-text-editor>\r\n <!-- <div class=\"description\" [innerHTML]=\"content?.additionalDetails?.value ?? '' | sanitizeHtml\"></div> -->\r\n</ng-template>\r\n\r\n<ng-template #socialIcons>\r\n <div class=\"d-flex align-items-start align-items-lg-center flex-column flex-lg-row gap-lg-0 gap-3\"\r\n [ngClass]=\"content?.socialLinks?.display ? 'justify-content-between' : 'justify-content-end'\">\r\n <div class=\"d-flex mt-0\" *ngIf=\"content?.socialLinks?.display\">\r\n <ng-container *ngFor=\"let item of content?.socialLinks?.channels\">\r\n <div class=\"icons\">\r\n <simpo-socia-icons [iconColor]=\"data?.styles?.background?.accentColor\" [socialIconData]=\"item\"\r\n [color]=\"style?.background?.color\" [sectionId]=\"data?.id\"></simpo-socia-icons>\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #branding>\r\n <div class=\"heading-small text-center branding-text\">Made with <a class=\"branding-text fw-600\"\r\n href=\"https://simpo.ai\" target=\"_blank\">Simpo</a></div>\r\n</ng-template>\r\n\r\n<ng-template #pagesHorizontal>\r\n <div class=\"col-md-3 mb-3 pageType\" [class.w-50]=\"screenWidth < 475\" [class.text-center]=\"screenWidth < 475\">\r\n {{pageLink}}\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #foldersHorizontal>\r\n <div class=\"pageType col-md-3 mb-3\" *ngFor=\"let folder of content?.folder\" [class.w-50]=\"screenWidth < 475\" [class.text-center]=\"screenWidth < 475\">\r\n {{folder.label}}\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #pagesVertical>\r\n <div class=\"page-container col-md-3 mb-3\" [class.w-50]=\"screenWidth < 475\">\r\n <div class=\"pageType mb-3\">{{pageLink}}</div>\r\n <ng-container *ngFor=\"let page of pages\">\r\n <div class=\"pages mb-2\">{{page}}</div>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #foldersVertical>\r\n <div class=\"page-container col-md-3 mb-3\" *ngFor=\"let folder of content?.folder\" [class.w-50]=\"screenWidth < 475\">\r\n <!-- <div class=\"pageType mb-3\">{{folder.label}}</div> -->\r\n <simpo-text-editor [value]=\"folder.label\" [editable]=\"edit || false\"></simpo-text-editor>\r\n <div class=\"mt-15\">\r\n <ng-container *ngFor=\"let page of folder.links\">\r\n <div class=\"pages mb-2\">{{page.label}}</div>\r\n </ng-container>\r\n </div>\r\n </div>\r\n</ng-template>\r\n", styles: [".pageType{font-size:16px;font-weight:600;line-height:22px}.pages{font-size:16px;font-weight:400;line-height:22px}.branding-text{font-size:16px;font-weight:400;line-height:22px;text-decoration:unset}.fw-600{font-weight:600!important}.w-50{width:50%!important}.w-30{width:30%!important}.align-items-start{align-items:start!important}.mt-15{margin-top:15px}\n"] }]
54
+ }], ctorParameters: () => [], propDecorators: { data: [{
55
+ type: Input
56
+ }], index: [{
57
+ type: Input
58
+ }], edit: [{
59
+ type: Input
60
+ }], delete: [{
61
+ type: Input
62
+ }], getScreenSize: [{
63
+ type: HostListener,
64
+ args: ['window:resize', ['$event']]
65
+ }] } });
66
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"footer.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/sections/footer/footer.component.ts","../../../../../../projects/simpo-ui/src/lib/sections/footer/footer.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAqB,SAAS,EAAE,YAAY,EAAU,KAAK,EAAuB,MAAM,eAAe,CAAC;AAG/G,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,YAAY,EAAqB,MAAM,iBAAiB,CAAC;AAClE,OAAO,EAAE,mBAAmB,EAAE,MAAM,oDAAoD,CAAC;AACzF,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAE7C,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAC3E,OAAO,EAAE,0BAA0B,EAAE,MAAM,8CAA8C,CAAC;AAC1F,OAAO,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAC;AAC5E,OAAO,EAAE,mBAAmB,EAAE,MAAM,kDAAkD,CAAC;;;AAuBvF,MAAM,OAAO,eAAe;IAY1B;QATS,SAAI,GAAa,IAAI,CAAC;QACtB,WAAM,GAAI,KAAK,CAAC;QAKzB,eAAU,GAAW,GAAG,CAAC;QACzB,gBAAW,GAAW,GAAG,CAAC;QAuB1B,aAAQ,GAAY,UAAU,CAAA;QAC9B,UAAK,GAAe,CAAC,SAAS,EAAC,UAAU,EAAC,QAAQ,EAAC,cAAc,EAAC,gBAAgB,CAAC,CAAA;QArBjF,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;IAED,KAAK,CAAC,QAAQ;QACZ,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC;QAC/B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC;IAEpC,CAAC;IAGD,aAAa,CAAC,KAAc;QAC1B,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE,CAAC;YAClC,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,UAAU,CAAC;QACvC,CAAC;IACH,CAAC;IAEA,IAAI,YAAY;QACb,OAAO,EAAE,GAAG,IAAI,CAAC,KAAK,EAAE,MAAM,EAAiB,CAAC;IAClD,CAAC;8GA/BQ,eAAe;kGAAf,eAAe,qNCnC5B,s+PAoLA,6ZDjKI,YAAY,0lBACZ,cAAc,iFACd,mBAAmB,4HACnB,WAAW;gBAIX,YAAY;gBACZ,0BAA0B,2GAC1B,mBAAmB,0GACnB,mBAAmB,mFACnB,mBAAmB;;2FAKV,eAAe;kBApB3B,SAAS;+BACE,cAAc,cACZ,IAAI,WACP;wBACP,YAAY;wBACZ,cAAc;wBACd,mBAAmB;wBACnB,WAAW;wBACX,gBAAgB;wBAGhB,YAAY;wBACZ,0BAA0B;wBAC1B,mBAAmB;wBACnB,mBAAmB;wBACnB,mBAAmB;qBACpB;wDAKQ,IAAI;sBAAZ,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,MAAM;sBAAd,KAAK;gBAmBN,aAAa;sBADZ,YAAY;uBAAC,eAAe,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { ChangeDetectorRef, Component, HostListener, Inject, Input, NgZone, PLATFORM_ID } from '@angular/core';\r\nimport { FooterContentModel, FooterSectionModel, FooterStylesModel } from './footer.modal';\r\nimport {  LayOutModel  } from '../../styles/style.model';\r\nimport { ColorDirective } from '../../directive/color.directive';\r\nimport { CommonModule, isPlatformBrowser } from '@angular/common';\r\nimport { SociaIconsComponent } from './../../elements/socia-icons/socia-icons.component';\r\nimport { SanitizeHtmlPipe } from '../../services/sanitizeHtml';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { SpacingAroundDirective } from '../../directive/spacing-around.directive';\r\nimport { BackgroundDirective } from '../../directive/background-directive';\r\nimport { SpacingHorizontalDirective } from '../../directive/spacing-horizontal.directive';\r\nimport { ContentFitDirective } from '../../directive/content-fit-directive';\r\nimport { TextEditorComponent } from '../../elements/text-editor/text-editor.component';\r\n\r\n\r\n@Component({\r\n  selector: 'simpo-footer',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    ColorDirective,\r\n    SociaIconsComponent,\r\n    FormsModule,\r\n    SanitizeHtmlPipe,\r\n\r\n\r\n    //directives\r\n    SpacingHorizontalDirective,\r\n    BackgroundDirective,\r\n    ContentFitDirective,\r\n    TextEditorComponent\r\n  ],\r\n  templateUrl: './footer.component.html',\r\n  styleUrl: './footer.component.css'\r\n})\r\nexport class FooterComponent {\r\n  @Input() data?: FooterSectionModel;\r\n  @Input() index?: number;\r\n  @Input() edit?: boolean = true;\r\n  @Input() delete? = false;\r\n\r\n  content?: FooterContentModel;\r\n  style?: FooterStylesModel;\r\n\r\n  footerType: string = \"1\";\r\n  screenWidth: number = 475;\r\n\r\n  constructor() {\r\n    this.getScreenSize();\r\n  }\r\n\r\n  async ngOnInit() {\r\n    this.style = this.data?.styles;\r\n    this.content = this.data?.content;\r\n\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  getScreenSize(event?: number) {\r\n    if (typeof window !== 'undefined') {\r\n      this.screenWidth = window.innerWidth;\r\n    }\r\n  }\r\n\r\n   get stylesLayout() {\r\n      return { ...this.style?.layout } as LayOutModel;\r\n    }\r\n\r\n  pageLink : string = \"About Us\"\r\n  pages : string [] = [\"Mission\",\"Our Team\",\"Awards\",\"Testimonials\",\"Privacy Policy\"]\r\n\r\n}\r\n","<section class=\"total-container\">\r\n  <div [spacingHorizontal]=\"stylesLayout\" [simpoBackground]=\"style?.background\"   [simpoLayout]=\"style?.layout\">\r\n    <ng-container *ngTemplateOutlet=\"footer1\"></ng-container>\r\n  </div>\r\n</section>\r\n\r\n<ng-template #footer1>\r\n  <div class=\"row align-items-center\">\r\n    <div class=\"col-md-4\">\r\n      <div>\r\n        <ng-container *ngTemplateOutlet=\"logoSection\"></ng-container>\r\n      </div>\r\n      <div>\r\n        <ng-container *ngTemplateOutlet=\"descSection\"></ng-container>\r\n      </div>\r\n      <div *ngIf=\"content?.socialLinks?.display && screenWidth > 475\">\r\n        <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n      </div>\r\n    </div>\r\n    <div class=\"col-md-8\">\r\n      <div class=\"row\">\r\n        <ng-container *ngTemplateOutlet=\"pagesVertical\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"foldersVertical\"></ng-container>\r\n      </div>\r\n      <div *ngIf=\"content?.socialLinks?.display && screenWidth < 475\" class=\"d-flex justify-content-center\">\r\n        <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <hr *ngIf=\"content?.displayBranding\">\r\n  <div *ngIf=\"content?.displayBranding\">\r\n    <ng-container *ngTemplateOutlet=\"branding\"></ng-container>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #footer2>\r\n  <div class=\"row align-items-center\">\r\n    <div class=\"col-md-3\">\r\n      <div>\r\n        <ng-container *ngTemplateOutlet=\"logoSection\"></ng-container>\r\n      </div>\r\n      <div>\r\n        <ng-container *ngTemplateOutlet=\"descSection\"></ng-container>\r\n      </div>\r\n      <div *ngIf=\"content?.socialLinks?.display && screenWidth > 475\" >\r\n        <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n      </div>\r\n    </div>\r\n    <div class=\"col-md-9\">\r\n      <div class=\"row\">\r\n        <ng-container *ngTemplateOutlet=\"pagesHorizontal\"></ng-container>\r\n        <ng-container *ngTemplateOutlet=\"foldersHorizontal\"></ng-container>\r\n      </div>\r\n      <div *ngIf=\"content?.socialLinks?.display && screenWidth < 475\" class=\"d-flex justify-content-center\">\r\n        <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <hr *ngIf=\"content?.displayBranding\">\r\n  <div *ngIf=\"content?.displayBranding\">\r\n    <ng-container *ngTemplateOutlet=\"branding\"></ng-container>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #footer3>\r\n  <div class=\"row\" [class.align-items-start]=\"screenWidth < 475\">\r\n    <ng-container *ngTemplateOutlet=\"pagesVertical\"></ng-container>\r\n    <ng-container *ngTemplateOutlet=\"foldersVertical\"></ng-container>\r\n  </div>\r\n  <hr>\r\n  <div class=\"row justify-content-between\">\r\n    <div class=\"col-md-4\" [class.w-30]=\"screenWidth < 475\">\r\n      <ng-container *ngTemplateOutlet=\"logoSection\"></ng-container>\r\n    </div>\r\n    <div class=\"col-md-4 d-flex justify-content-center align-items-start\" *ngIf=\"content?.socialLinks?.display\" [class.w-30]=\"screenWidth < 475\">\r\n      <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n    </div>\r\n    <div class=\"col-md-4 d-flex justify-content-end\" *ngIf=\"content?.displayBranding\" [class.w-30]=\"screenWidth < 475\">\r\n      <ng-container *ngTemplateOutlet=\"branding\"></ng-container>\r\n    </div>\r\n  </div>\r\n\r\n</ng-template>\r\n\r\n<ng-template #footer4>\r\n  <div class=\"row align-items-center\">\r\n    <ng-container *ngTemplateOutlet=\"pagesHorizontal\"></ng-container>\r\n    <ng-container *ngTemplateOutlet=\"foldersHorizontal\"></ng-container>\r\n  </div>\r\n  <hr>\r\n  <div class=\"row justify-content-between\">\r\n    <div class=\"col-md-4\">\r\n      <ng-container *ngTemplateOutlet=\"logoSection\"></ng-container>\r\n    </div>\r\n    <div class=\"col-md-4 d-flex justify-content-center align-items-start\" *ngIf=\"content?.socialLinks?.display\">\r\n      <ng-container *ngTemplateOutlet=\"socialIcons\"></ng-container>\r\n    </div>\r\n    <div class=\"col-md-4 d-flex justify-content-end\" *ngIf=\"content?.displayBranding\">\r\n      <ng-container *ngTemplateOutlet=\"branding\"></ng-container>\r\n    </div>\r\n  </div>\r\n\r\n</ng-template>\r\n\r\n<ng-template #logoSection>\r\n  <div class=\"d-flex\" [class.justify-content-center]=\"screenWidth < 475\">\r\n    <div class=\"d-flex gap-3 align-items-lg-center cursor-pointer mb-4\"\r\n      *ngIf=\"!content?.logo?.isImage || !content?.logo?.image?.url\">\r\n      <div *ngIf=\"content?.logo?.text?.isIcon && content?.logo?.text?.url\">\r\n        <img loading=\"lazy\" [src]=\"content?.logo?.text?.url\" alt=\"logo\" [width]=\"content?.logo?.size\" loading=\"lazy\">\r\n      </div>\r\n      <div class=\"heading-small\" *ngIf=\"content?.logo?.text?.isText\" [simpoColor]=\"style?.background?.color\">\r\n        <b [ngStyle]=\"{'font-family': content?.logo?.text?.fontFamily}\">{{content?.siteName?.value}}</b>\r\n      </div>\r\n    </div>\r\n    <div class=\"d-flex gap-3 align-items-lg-center cursor-pointer mb-4\"\r\n      *ngIf=\"content?.logo?.isImage && content?.logo?.image?.url\">\r\n      <img loading=\"lazy\" [src]=\"content?.logo?.image?.url\" alt=\"logo\"\r\n        [style.width.%]=\"screenWidth > 475 || (content?.logo?.size || 10) < 50 ? content?.logo?.size : ((content?.logo?.size || 10) - 10)\"\r\n        loading=\"lazy\">\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #descSection>\r\n  <simpo-text-editor [value]=\"content?.additionalDetails?.value || ''\" [editable]=\"edit || false\"></simpo-text-editor>\r\n  <!-- <div class=\"description\" [innerHTML]=\"content?.additionalDetails?.value ?? '' | sanitizeHtml\"></div> -->\r\n</ng-template>\r\n\r\n<ng-template #socialIcons>\r\n  <div class=\"d-flex align-items-start align-items-lg-center flex-column flex-lg-row gap-lg-0 gap-3\"\r\n    [ngClass]=\"content?.socialLinks?.display ? 'justify-content-between' : 'justify-content-end'\">\r\n    <div class=\"d-flex mt-0\" *ngIf=\"content?.socialLinks?.display\">\r\n      <ng-container *ngFor=\"let item of content?.socialLinks?.channels\">\r\n        <div class=\"icons\">\r\n          <simpo-socia-icons [iconColor]=\"data?.styles?.background?.accentColor\" [socialIconData]=\"item\"\r\n            [color]=\"style?.background?.color\" [sectionId]=\"data?.id\"></simpo-socia-icons>\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #branding>\r\n  <div class=\"heading-small text-center  branding-text\">Made with <a class=\"branding-text fw-600\"\r\n      href=\"https://simpo.ai\" target=\"_blank\">Simpo</a></div>\r\n</ng-template>\r\n\r\n<ng-template #pagesHorizontal>\r\n    <div class=\"col-md-3 mb-3 pageType\"  [class.w-50]=\"screenWidth < 475\" [class.text-center]=\"screenWidth < 475\">\r\n      {{pageLink}}\r\n    </div>\r\n</ng-template>\r\n\r\n<ng-template #foldersHorizontal>\r\n  <div class=\"pageType col-md-3 mb-3\" *ngFor=\"let folder of content?.folder\" [class.w-50]=\"screenWidth < 475\" [class.text-center]=\"screenWidth < 475\">\r\n    {{folder.label}}\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #pagesVertical>\r\n  <div class=\"page-container col-md-3 mb-3\" [class.w-50]=\"screenWidth < 475\">\r\n    <div class=\"pageType mb-3\">{{pageLink}}</div>\r\n    <ng-container *ngFor=\"let page of pages\">\r\n      <div class=\"pages mb-2\">{{page}}</div>\r\n    </ng-container>\r\n  </div>\r\n</ng-template>\r\n\r\n<ng-template #foldersVertical>\r\n  <div class=\"page-container col-md-3 mb-3\" *ngFor=\"let folder of content?.folder\" [class.w-50]=\"screenWidth < 475\">\r\n    <!-- <div class=\"pageType mb-3\">{{folder.label}}</div> -->\r\n    <simpo-text-editor [value]=\"folder.label\" [editable]=\"edit || false\"></simpo-text-editor>\r\n    <div class=\"mt-15\">\r\n      <ng-container *ngFor=\"let page of folder.links\">\r\n        <div class=\"pages mb-2\">{{page.label}}</div>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9vdGVyLm1vZGFsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2ltcG8tdWkvc3JjL2xpYi9zZWN0aW9ucy9mb290ZXIvZm9vdGVyLm1vZGFsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFubmVsVHlwZSwgRm9vdGVyVHlwZXMsIH0gZnJvbSBcIi4vLi4vLi4vc3R5bGVzL2luZGV4XCJcclxuaW1wb3J0IHsgQWN0aW9uTW9kZWwsIEJhY2tncm91bmRNb2RlbCwgRGV2aWRlck1vZGVsLCBJbnB1dFRleHRNb2RlbCwgTmF2YmFyQnV0dG9uLCBTcGFjaW5nTW9kZWwsTGlzdEl0ZW1Nb2RhbCwgTGF5T3V0TW9kZWwsIEJ1dHRvbiB9IGZyb20gXCIuLy4uLy4uL3N0eWxlcy9zdHlsZS5tb2RlbFwiXHJcbmltcG9ydCB7IEZPT1RFUl9JTUFHRV9TT1VSQ0UsIFNPQ0lBTF9JQ09OX1NIQVBFLCBTT0NJQUxfSUNPTl9TSVpFLCBTT0NJQUxfSUNPTl9UWVBFIH0gZnJvbSBcIi4vLi4vLi4vc3R5bGVzL3R5cGVzXCJcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRm9vdGVyU2VjdGlvbk1vZGVse1xyXG4gICAgaWQ6c3RyaW5nLFxyXG4gICAgc2VjdGlvblR5cGU6c3RyaW5nLFxyXG4gICAgc2VjdGlvbk5hbWU6c3RyaW5nLFxyXG4gICAgY29udGVudDpGb290ZXJDb250ZW50TW9kZWwsXHJcbiAgICBzdHlsZXM6Rm9vdGVyU3R5bGVzTW9kZWwsXHJcbiAgICBhY3Rpb246IEFjdGlvbk1vZGVsO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEZvb3RlclN0eWxlc01vZGVse1xyXG4gICAgbGF5b3V0IDogTGF5T3V0TW9kZWw7XHJcbiAgICBiYWNrZ3JvdW5kIDogQmFja2dyb3VuZE1vZGVsO1xyXG4gICAgZm9vdGVyVHlwZSA6IEZvb3RlclR5cGVzO1xyXG4gICAgc29jaWFsSWNvbiA6IEZvb3RlclNvY2lhbEljb25TaXplTW9kZWxcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBGb290ZXJTb2NpYWxJY29uU2l6ZU1vZGVse1xyXG4gICAgc2l6ZTpTT0NJQUxfSUNPTl9TSVpFLFxyXG4gICAgc2hhcGU6U09DSUFMX0lDT05fU0hBUEUsXHJcbiAgICB0eXBlOlNPQ0lBTF9JQ09OX1RZUEVcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBGb290ZXJDb250ZW50TW9kZWx7XHJcbiAgICBzaXRlTmFtZUFuZExvZ286c3RyaW5nLFxyXG4gICAgc2l0ZU5hbWU6SW5wdXRUZXh0TW9kZWwsXHJcbiAgICBhZGRpdGlvbmFsRGV0YWlsczpJbnB1dFRleHRNb2RlbCxcclxuICAgIGxvZ286Rm9vdGVyTG9nb01vZGVsLFxyXG4gICAgc29jaWFsTGlua3M6Rm9vdGVyU29jaWFsTGlua01vZGVsLFxyXG4gICAgZGlzcGxheUJyYW5kaW5nOmJvb2xlYW47XHJcbiAgICBmb2xkZXI6IEZvbGRlck1vZGVsW107XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRm9vdGVyTG9nb01vZGVse1xyXG4gICAgaXNJbWFnZSA6IGJvb2xlYW4sXHJcbiAgICB0ZXh0OkZvb3RlckxvZ29UZXh0TW9kZWwsXHJcbiAgICBpbWFnZTpmb290ZXJMb2dvYnJhbmRpbmdNb2RlbDtcclxuICAgIHNpemU6IG51bWJlcjtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBmb290ZXJMb2dvYnJhbmRpbmdNb2RlbHtcclxuICAgIHNvdXJjZTpGT09URVJfSU1BR0VfU09VUkNFLFxyXG4gICAgdXJsOnN0cmluZ1xyXG59XHJcbmV4cG9ydCBpbnRlcmZhY2UgRm9vdGVyTG9nb1RleHRNb2RlbHtcclxuICAgIGlzVGV4dCA6IGJvb2xlYW4sXHJcbiAgICBpc0ljb24gOiBib29sZWFuLFxyXG4gICAgdXJsOnN0cmluZyxcclxuICAgIGZvbnRGYW1pbHk6c3RyaW5nXHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRm9vdGVyU29jaWFsTGlua01vZGVse1xyXG4gICAgZGlzcGxheTpib29sZWFuLFxyXG4gICAgY2hhbm5lbHM6Rm9vdGVyU29jaWFsQ2hhbm5lbE1vZGVsW11cclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBGb290ZXJTb2NpYWxDaGFubmVsTW9kZWx7XHJcbiAgICB0eXBlOkNoYW5uZWxUeXBlLFxyXG4gICAgdXJsOnN0cmluZyxcclxuICAgIGxpbms6c3RyaW5nXHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgRm9sZGVyTW9kZWwge1xyXG4gIGxhYmVsOiBzdHJpbmc7XHJcbiAgbGlua3M6IEJ1dHRvbltdO1xyXG59XHJcbiJdfQ==
@@ -41,6 +41,7 @@ export * from './lib/sections/registration-form/registration-form.component';
41
41
  export * from './lib/sections/property-component/property-component.component';
42
42
  export * from './lib/sections/usp-video-section/usp-video-section.component';
43
43
  export * from './lib/sections/property-list/property-list.component';
44
+ export * from './lib/sections/footer/footer.component';
44
45
  // Ecommerce sections
45
46
  export * from './lib/ecommerce/sections/featured-products/featured-products.component';
46
47
  export * from './lib/ecommerce/sections/featured-category/featured-category.component';
@@ -93,4 +94,4 @@ export * from './lib/ecommerce/styles/cart.modal';
93
94
  export * from './lib/ecommerce/styles/category.modal';
94
95
  export * from './lib/ecommerce/styles/Collection.modal';
95
96
  export * from './lib/ecommerce/styles/product.modal';
96
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"public-api.js","sourceRoot":"","sources":["../../../projects/simpo-ui/src/public-api.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,0CAA0C;AAC1C,4CAA4C;AAE5C,cAAc,oDAAoD,CAAC;AACnE,cAAc,wDAAwD,CAAC;AACvE,cAAc,kDAAkD,CAAC;AACjE,cAAc,wDAAwD,CAAC;AACvE,cAAc,wEAAwE,CAAC;AACvF,cAAc,gEAAgE,CAAC;AAC/E,cAAc,sDAAsD,CAAC;AACrE,cAAc,0DAA0D,CAAC;AACzE,cAAc,kEAAkE,CAAC;AACjF,cAAc,kEAAkE,CAAC;AACjF,cAAc,gEAAgE,CAAC;AAC/E,cAAc,sDAAsD,CAAC;AACrE,cAAc,wDAAwD,CAAC;AACvE,cAAc,0DAA0D,CAAC;AACzE,cAAc,gDAAgD,CAAA;AAC9D,cAAc,0EAA0E,CAAC;AACzF,cAAc,kEAAkE,CAAC;AACjF,cAAc,8DAA8D,CAAC;AAC7E,cAAc,0DAA0D,CAAC;AACzE,cAAc,4DAA4D,CAAC;AAC3E,cAAc,kDAAkD,CAAA;AAChE,cAAc,4EAA4E,CAAA;AAC1F,cAAc,8CAA8C,CAAA;AAC5D,cAAc,8CAA8C,CAAA;AAC5D,cAAc,0DAA0D,CAAA;AACxE,cAAc,wDAAwD,CAAA;AACtE,cAAc,4DAA4D,CAAA;AAC1E,cAAc,sEAAsE,CAAA;AACpF,cAAc,sDAAsD,CAAA;AACpE,cAAc,0DAA0D,CAAA;AACxE,cAAc,0DAA0D,CAAC;AACzE,cAAc,4DAA4D,CAAC;AAC3E,cAAc,8DAA8D,CAAC;AAC7E,cAAc,oDAAoD,CAAC;AACnE,cAAc,8DAA8D,CAAA;AAC5E,cAAc,gEAAgE,CAAA;AAC9E,cAAc,8DAA8D,CAAA;AAC5E,cAAc,sDAAsD,CAAA;AAEpE,qBAAqB;AACrB,cAAc,wEAAwE,CAAC;AACvF,cAAc,wEAAwE,CAAC;AACvF,cAAc,8DAA8D,CAAC;AAC7E,cAAc,8DAA8D,CAAC;AAC7E,cAAc,8CAA8C,CAAC;AAC7D,cAAc,sDAAsD,CAAC;AACrE,cAAc,sDAAsD,CAAA;AACpE,cAAc,8DAA8D,CAAC;AAC7E,cAAc,wEAAwE,CAAC;AACvF,cAAc,kEAAkE,CAAC;AACjF,cAAc,kEAAkE,CAAC;AACjF,cAAc,gFAAgF,CAAC;AAC/F,cAAc,sEAAsE,CAAC;AACrF,cAAc,0EAA0E,CAAC;AACzF,cAAc,oEAAoE,CAAC;AACnF,cAAc,oFAAoF,CAAC;AAEnG,UAAU;AACV,cAAc,+BAA+B,CAAC;AAC9C,cAAc,gCAAgC,CAAC;AAC/C,cAAc,6BAA6B,CAAC;AAE5C,YAAY;AAEZ,cAAc,qCAAqC,CAAC;AACpD,cAAc,sCAAsC,CAAC;AACrD,cAAc,8CAA8C,CAAC;AAC7D,cAAc,kCAAkC,CAAC;AACjD,cAAc,4CAA4C,CAAC;AAC3D,cAAc,4CAA4C,CAAC;AAC3D,cAAc,yCAAyC,CAAC;AACxD,cAAc,6CAA6C,CAAC;AAC5D,cAAc,uCAAuC,CAAC;AACtD,cAAc,kCAAkC,CAAC;AACjD,cAAc,qDAAqD,CAAC;AACpE,cAAc,qDAAqD,CAAC;AACpE,cAAc,mCAAmC,CAAC;AAClD,cAAc,2CAA2C,CAAC;AAC1D,cAAc,yCAAyC,CAAC;AACxD,cAAc,yCAAyC,CAAC;AACxD,cAAc,iCAAiC,CAAA;AAC/C,cAAc,0CAA0C,CAAC;AACzD,cAAc,+CAA+C,CAAA;AAC7D,cAAc,kCAAkC,CAAC;AACjD,cAAc,0CAA0C,CAAC;AACzD,cAAc,0CAA0C,CAAC;AAEzD,SAAS;AAET,cAAc,oBAAoB,CAAC;AACnC,cAAc,0BAA0B,CAAC;AACzC,cAAc,oBAAoB,CAAC;AACnC,cAAc,mCAAmC,CAAC;AAClD,cAAc,uCAAuC,CAAC;AACtD,cAAc,yCAAyC,CAAC;AACxD,cAAc,sCAAsC,CAAC","sourcesContent":["/*\r\n * Public API Surface of simpo-ui\r\n */\r\n\r\n// export * from './lib/simpo-ui.service';\r\n// export * from './lib/simpo-ui.component';\r\n\r\nexport * from './lib/sections/text-section/text-section.component';\r\nexport * from './lib/sections/banner-section/banner-section.component';\r\nexport * from './lib/sections/faq-section/faq-section.component';\r\nexport * from './lib/sections/footer-section/footer-section.component';\r\nexport * from './lib/sections/image-carousel-section/image-carousel-section.component';\r\nexport * from './lib/sections/image-grid-section/image-grid-section.component';\r\nexport * from './lib/sections/image-section/image-section.component';\r\nexport * from './lib/sections/service-section/service-section.component';\r\nexport * from './lib/sections/team-member-section/team-member-section.component';\r\nexport * from './lib/sections/testimonial-section/testimonial-section.component';\r\nexport * from './lib/sections/text-image-section/text-image-section.component';\r\nexport * from './lib/sections/video-section/video-section.component';\r\nexport * from './lib/sections/navbar-section/navbar-section.component';\r\nexport * from './lib/sections/add-new-section/add-new-section.component';\r\nexport * from './lib/sections/contact-us/contact-us.component'\r\nexport * from './lib/sections/skeleton-loader-section/skeleton-loader-section.component';\r\nexport * from './lib/sections/banner-grid-section/banner-grid-section.component';\r\nexport * from './lib/sections/choose-us-section/choose-us-section.component';\r\nexport * from './lib/sections/pricing-section/pricing-section.component';\r\nexport * from './lib/sections/location-section/location-section.component';\r\nexport * from './lib/sections/header-text/header-text.component'\r\nexport * from './lib/sections/recent-blog-post-section/recent-blog-post-section.component'\r\nexport * from './lib/sections/blog-list/blog-list.component'\r\nexport * from './lib/sections/view-blog/view-blog.component'\r\nexport * from './lib/sections/process-section/process-section.component'\r\nexport * from './lib/sections/process-modern/process-modern.component'\r\nexport * from './lib/sections/features-section/features-section.component'\r\nexport * from './lib/sections/testimonial-fullwidth/testimonial-fullwidth.component'\r\nexport * from './lib/sections/logo-showcase/logo-showcase.component'\r\nexport * from './lib/sections/banner-carousel/banner-carousel.component'\r\nexport * from './lib/sections/carousel-banner/carousel-banner.component';\r\nexport * from './lib/sections/appointment-form/appointment-form.component';\r\nexport * from './lib/sections/testimonial-video/testimonial-video.component';\r\nexport * from './lib/sections/logo-gallery/logo-gallery.component';\r\nexport * from './lib/sections/registration-form/registration-form.component'\r\nexport * from './lib/sections/property-component/property-component.component'\r\nexport * from './lib/sections/usp-video-section/usp-video-section.component'\r\nexport * from './lib/sections/property-list/property-list.component'\r\n\r\n// Ecommerce sections\r\nexport * from './lib/ecommerce/sections/featured-products/featured-products.component';\r\nexport * from './lib/ecommerce/sections/featured-category/featured-category.component';\r\nexport * from './lib/ecommerce/sections/product-desc/product-desc.component';\r\nexport * from './lib/ecommerce/sections/product-list/product-list.component';\r\nexport * from './lib/ecommerce/sections/cart/cart.component';\r\nexport * from './lib/ecommerce/sections/checkout/checkout.component';\r\nexport * from './lib/ecommerce/sections/whislist/whislist.component'\r\nexport * from './lib/ecommerce/sections/user-profile/user-profile.component';\r\nexport * from './lib/ecommerce/sections/authenticate-user/authenticate-user.component';\r\nexport * from './lib/ecommerce/sections/verify-payment/verify-payment.component';\r\nexport * from './lib/ecommerce/sections/verify-payment/verify-payment.component';\r\nexport * from './lib/ecommerce/sections/product-category-list/product-category-list.component';\r\nexport * from './lib/ecommerce/sections/category-product/category-product.component';\r\nexport * from './lib/ecommerce/sections/featured-category/featured-collection.component';\r\nexport * from './lib/ecommerce/sections/customer-review/customer-review.component';\r\nexport * from './lib/ecommerce/sections/authentication-required/authentication-required.component';\r\n\r\n// service\r\nexport * from './lib/services/events.service';\r\nexport * from './lib/services/endUser.service';\r\nexport * from './lib/services/sanitizeHtml';\r\n\r\n//directives\r\n\r\nexport * from './lib/directive/animation-directive';\r\nexport * from './lib/directive/background-directive';\r\nexport * from './lib/directive/banner-content-fit-directive';\r\nexport * from './lib/directive/border-directive';\r\nexport * from './lib/directive/button-directive.directive';\r\nexport * from './lib/directive/column-directive.directive';\r\nexport * from './lib/directive/container-fir.directive';\r\nexport * from './lib/directive/content-alignment-directive';\r\nexport * from './lib/directive/content-fit-directive';\r\nexport * from './lib/directive/corner-directive';\r\nexport * from './lib/directive/text-background-directive.directive';\r\nexport * from './lib/directive/position-layout-directive.directive';\r\nexport * from './lib/directive/overlay-directive';\r\nexport * from './lib/directive/image-directive.directive';\r\nexport * from './lib/directive/hover-element-directive';\r\nexport * from './lib/directive/footer-layout-directive';\r\nexport * from './lib/directive/color.directive'\r\nexport * from './lib/directive/image-position.directive';\r\nexport * from './lib/directive/container-alignment.directive'\r\nexport * from './lib/directive/sticky-directive';\r\nexport * from './lib/directive/removeCarousel-directive';\r\nexport * from './lib/directive/spacing-around.directive';\r\n\r\n// styles\r\n\r\nexport * from './lib/styles/index';\r\nexport * from './lib/styles/style.model';\r\nexport * from './lib/styles/types';\r\nexport * from './lib/ecommerce/styles/cart.modal';\r\nexport * from './lib/ecommerce/styles/category.modal';\r\nexport * from './lib/ecommerce/styles/Collection.modal';\r\nexport * from './lib/ecommerce/styles/product.modal';\r\n"]}
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"public-api.js","sourceRoot":"","sources":["../../../projects/simpo-ui/src/public-api.ts"],"names":[],"mappings":"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","sourcesContent":["/*\r\n * Public API Surface of simpo-ui\r\n */\r\n\r\n// export * from './lib/simpo-ui.service';\r\n// export * from './lib/simpo-ui.component';\r\n\r\nexport * from './lib/sections/text-section/text-section.component';\r\nexport * from './lib/sections/banner-section/banner-section.component';\r\nexport * from './lib/sections/faq-section/faq-section.component';\r\nexport * from './lib/sections/footer-section/footer-section.component';\r\nexport * from './lib/sections/image-carousel-section/image-carousel-section.component';\r\nexport * from './lib/sections/image-grid-section/image-grid-section.component';\r\nexport * from './lib/sections/image-section/image-section.component';\r\nexport * from './lib/sections/service-section/service-section.component';\r\nexport * from './lib/sections/team-member-section/team-member-section.component';\r\nexport * from './lib/sections/testimonial-section/testimonial-section.component';\r\nexport * from './lib/sections/text-image-section/text-image-section.component';\r\nexport * from './lib/sections/video-section/video-section.component';\r\nexport * from './lib/sections/navbar-section/navbar-section.component';\r\nexport * from './lib/sections/add-new-section/add-new-section.component';\r\nexport * from './lib/sections/contact-us/contact-us.component'\r\nexport * from './lib/sections/skeleton-loader-section/skeleton-loader-section.component';\r\nexport * from './lib/sections/banner-grid-section/banner-grid-section.component';\r\nexport * from './lib/sections/choose-us-section/choose-us-section.component';\r\nexport * from './lib/sections/pricing-section/pricing-section.component';\r\nexport * from './lib/sections/location-section/location-section.component';\r\nexport * from './lib/sections/header-text/header-text.component'\r\nexport * from './lib/sections/recent-blog-post-section/recent-blog-post-section.component'\r\nexport * from './lib/sections/blog-list/blog-list.component'\r\nexport * from './lib/sections/view-blog/view-blog.component'\r\nexport * from './lib/sections/process-section/process-section.component'\r\nexport * from './lib/sections/process-modern/process-modern.component'\r\nexport * from './lib/sections/features-section/features-section.component'\r\nexport * from './lib/sections/testimonial-fullwidth/testimonial-fullwidth.component'\r\nexport * from './lib/sections/logo-showcase/logo-showcase.component'\r\nexport * from './lib/sections/banner-carousel/banner-carousel.component'\r\nexport * from './lib/sections/carousel-banner/carousel-banner.component';\r\nexport * from './lib/sections/appointment-form/appointment-form.component';\r\nexport * from './lib/sections/testimonial-video/testimonial-video.component';\r\nexport * from './lib/sections/logo-gallery/logo-gallery.component';\r\nexport * from './lib/sections/registration-form/registration-form.component'\r\nexport * from './lib/sections/property-component/property-component.component'\r\nexport * from './lib/sections/usp-video-section/usp-video-section.component'\r\nexport * from './lib/sections/property-list/property-list.component'\r\nexport * from './lib/sections/footer/footer.component'\r\n\r\n// Ecommerce sections\r\nexport * from './lib/ecommerce/sections/featured-products/featured-products.component';\r\nexport * from './lib/ecommerce/sections/featured-category/featured-category.component';\r\nexport * from './lib/ecommerce/sections/product-desc/product-desc.component';\r\nexport * from './lib/ecommerce/sections/product-list/product-list.component';\r\nexport * from './lib/ecommerce/sections/cart/cart.component';\r\nexport * from './lib/ecommerce/sections/checkout/checkout.component';\r\nexport * from './lib/ecommerce/sections/whislist/whislist.component'\r\nexport * from './lib/ecommerce/sections/user-profile/user-profile.component';\r\nexport * from './lib/ecommerce/sections/authenticate-user/authenticate-user.component';\r\nexport * from './lib/ecommerce/sections/verify-payment/verify-payment.component';\r\nexport * from './lib/ecommerce/sections/verify-payment/verify-payment.component';\r\nexport * from './lib/ecommerce/sections/product-category-list/product-category-list.component';\r\nexport * from './lib/ecommerce/sections/category-product/category-product.component';\r\nexport * from './lib/ecommerce/sections/featured-category/featured-collection.component';\r\nexport * from './lib/ecommerce/sections/customer-review/customer-review.component';\r\nexport * from './lib/ecommerce/sections/authentication-required/authentication-required.component';\r\n\r\n// service\r\nexport * from './lib/services/events.service';\r\nexport * from './lib/services/endUser.service';\r\nexport * from './lib/services/sanitizeHtml';\r\n\r\n//directives\r\n\r\nexport * from './lib/directive/animation-directive';\r\nexport * from './lib/directive/background-directive';\r\nexport * from './lib/directive/banner-content-fit-directive';\r\nexport * from './lib/directive/border-directive';\r\nexport * from './lib/directive/button-directive.directive';\r\nexport * from './lib/directive/column-directive.directive';\r\nexport * from './lib/directive/container-fir.directive';\r\nexport * from './lib/directive/content-alignment-directive';\r\nexport * from './lib/directive/content-fit-directive';\r\nexport * from './lib/directive/corner-directive';\r\nexport * from './lib/directive/text-background-directive.directive';\r\nexport * from './lib/directive/position-layout-directive.directive';\r\nexport * from './lib/directive/overlay-directive';\r\nexport * from './lib/directive/image-directive.directive';\r\nexport * from './lib/directive/hover-element-directive';\r\nexport * from './lib/directive/footer-layout-directive';\r\nexport * from './lib/directive/color.directive'\r\nexport * from './lib/directive/image-position.directive';\r\nexport * from './lib/directive/container-alignment.directive'\r\nexport * from './lib/directive/sticky-directive';\r\nexport * from './lib/directive/removeCarousel-directive';\r\nexport * from './lib/directive/spacing-around.directive';\r\n\r\n// styles\r\n\r\nexport * from './lib/styles/index';\r\nexport * from './lib/styles/style.model';\r\nexport * from './lib/styles/types';\r\nexport * from './lib/ecommerce/styles/cart.modal';\r\nexport * from './lib/ecommerce/styles/category.modal';\r\nexport * from './lib/ecommerce/styles/Collection.modal';\r\nexport * from './lib/ecommerce/styles/product.modal';\r\n"]}