simpo-component-library 3.6.805 → 3.6.807
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/covering-image-card/covering-image-card.component.mjs +3 -3
- package/esm2022/lib/sections/brand-story-section/brand-story-section.component.mjs +105 -0
- package/esm2022/lib/sections/brand-story-section/brand-story-section.modal.mjs +2 -0
- package/esm2022/lib/sections/header-section/header-section.component.mjs +3 -3
- package/esm2022/lib/sections/testimonial-slider/testimonial-slider.component.mjs +162 -0
- package/esm2022/lib/sections/testimonial-slider/testimonial-slider.model.mjs +2 -0
- package/esm2022/lib/sections/video-carousel-section/video-carousel-section.component.mjs +3 -3
- package/esm2022/lib/sections/video-carousel-section/video-carousel.model.mjs +1 -1
- package/esm2022/lib/sections/video-grid-section/video-grid-section.component.mjs +12 -6
- package/esm2022/lib/sections/video-grid-section/video-grid-section.model.mjs +1 -1
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/simpo-component-library.mjs +294 -73
- package/fesm2022/simpo-component-library.mjs.map +1 -1
- package/lib/components/input-fields/input-fields.component.d.ts +1 -1
- package/lib/ecommerce/sections/authentication-required/authentication-required.component.d.ts +1 -1
- package/lib/ecommerce/sections/featured-category/featured-category.component.d.ts +1 -1
- package/lib/ecommerce/sections/featured-category/featured-collection.component.d.ts +1 -1
- package/lib/ecommerce/sections/new-collection/new-collection.component.d.ts +1 -1
- package/lib/ecommerce/sections/product-desc/product-desc.component.d.ts +1 -1
- package/lib/elements/link-editor/link-editor.component.d.ts +1 -1
- package/lib/elements/pricing-s1/pricing-s1.component.d.ts +1 -1
- package/lib/sections/banner-carousel/banner-carousel.component.d.ts +2 -2
- package/lib/sections/brand-story-section/brand-story-section.component.d.ts +29 -0
- package/lib/sections/brand-story-section/brand-story-section.modal.d.ts +24 -0
- package/lib/sections/carousel-banner/carousel-banner.component.d.ts +1 -1
- package/lib/sections/image-grid-hotspot/image-grid-hotspot.component.d.ts +1 -1
- package/lib/sections/image-grid-section/image-grid-section.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 +2 -2
- package/lib/sections/pricing-section/pricing-section.component.d.ts +1 -1
- package/lib/sections/testimonial-slider/testimonial-slider.component.d.ts +41 -0
- package/lib/sections/testimonial-slider/testimonial-slider.model.d.ts +20 -0
- package/lib/sections/video-carousel-section/video-carousel.model.d.ts +1 -1
- package/lib/sections/video-grid-section/video-grid-section.model.d.ts +8 -2
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
- package/simpo-component-library-3.6.807.tgz +0 -0
- package/simpo-component-library-3.6.805.tgz +0 -0
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
import { Component, HostListener, Input, ViewChild, ViewChildren } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
4
|
+
import { SimpoElementsModule } from '../../elements/index';
|
|
5
|
+
import { SimpoComponentModule } from '../../components/index';
|
|
6
|
+
import { AnimationDirective } from '../../directive/animation-directive';
|
|
7
|
+
import { BackgroundDirective } from '../../directive/background-directive';
|
|
8
|
+
import { ContentFitDirective } from '../../directive/content-fit-directive';
|
|
9
|
+
import { BorderDirective } from '../../directive/border-directive';
|
|
10
|
+
import { CornerDirective } from '../../directive/corner-directive';
|
|
11
|
+
import { HoverDirective } from '../../directive/hover-element-directive';
|
|
12
|
+
import { OverlayDirective } from '../../directive/overlay-directive';
|
|
13
|
+
import BaseSection from '../BaseSection';
|
|
14
|
+
import { ContentTitleDirective } from '../../directive/content-title-spacing.directive';
|
|
15
|
+
import { TextEditorComponent } from '../../elements/text-editor/text-editor.component';
|
|
16
|
+
import { ImageEditorDirective } from '../../directive/image-editor.directive';
|
|
17
|
+
import { SpacingHorizontalDirective } from '../../directive/spacing-horizontal.directive';
|
|
18
|
+
import * as i0 from "@angular/core";
|
|
19
|
+
import * as i1 from "./../../services/events.service";
|
|
20
|
+
import * as i2 from "@angular/common";
|
|
21
|
+
import * as i3 from "@angular/material/icon";
|
|
22
|
+
import * as i4 from "../../elements/svg-divider/svg-divider.component";
|
|
23
|
+
import * as i5 from "../../components/hover-elements/hover-elements.component";
|
|
24
|
+
import * as i6 from "../../components/delete-hover-element/delete-hover-element.component";
|
|
25
|
+
export class TestimonialSliderComponent extends BaseSection {
|
|
26
|
+
constructor(_eventService, renderer) {
|
|
27
|
+
super();
|
|
28
|
+
this._eventService = _eventService;
|
|
29
|
+
this.renderer = renderer;
|
|
30
|
+
this.activeDotIndex = 0;
|
|
31
|
+
this.showLeftArrow = true;
|
|
32
|
+
this.showRightArrow = true;
|
|
33
|
+
this.screenWidth = "";
|
|
34
|
+
this.getScreenSize();
|
|
35
|
+
}
|
|
36
|
+
ngOnInit() {
|
|
37
|
+
this.content = this.data?.content;
|
|
38
|
+
this.style = this.data?.styles;
|
|
39
|
+
this.deleteSelected = this.delete;
|
|
40
|
+
}
|
|
41
|
+
get headingSpace() {
|
|
42
|
+
return this.style?.layout?.headingSpacing;
|
|
43
|
+
}
|
|
44
|
+
get getLayout() {
|
|
45
|
+
return { ...this.style?.layout };
|
|
46
|
+
}
|
|
47
|
+
getScreenSize() {
|
|
48
|
+
this.screenWidth = window.innerWidth;
|
|
49
|
+
this.checkScrollLimits();
|
|
50
|
+
}
|
|
51
|
+
ngAfterViewInit() {
|
|
52
|
+
// Need a timeout to wait for rendering
|
|
53
|
+
setTimeout(() => {
|
|
54
|
+
this.checkScrollLimits();
|
|
55
|
+
}, 100);
|
|
56
|
+
}
|
|
57
|
+
checkScrollLimits() {
|
|
58
|
+
if (!this.sliderViewport)
|
|
59
|
+
return;
|
|
60
|
+
const viewport = this.sliderViewport.nativeElement;
|
|
61
|
+
const scrollLeft = viewport.scrollLeft;
|
|
62
|
+
const width = viewport.clientWidth;
|
|
63
|
+
const totalWidth = viewport.scrollWidth;
|
|
64
|
+
this.showLeftArrow = scrollLeft > 0;
|
|
65
|
+
// adding 5 extra pixels due to rounding edge cases
|
|
66
|
+
this.showRightArrow = Math.ceil(scrollLeft + width) < totalWidth - 5;
|
|
67
|
+
}
|
|
68
|
+
getLength() {
|
|
69
|
+
return this.content?.listItem?.data?.length ?? 0;
|
|
70
|
+
}
|
|
71
|
+
getDotsArray() {
|
|
72
|
+
return Array(this.getLength()).fill(0);
|
|
73
|
+
}
|
|
74
|
+
scrollPrev() {
|
|
75
|
+
const viewport = this.sliderViewport.nativeElement;
|
|
76
|
+
const scrollAmount = viewport.offsetWidth;
|
|
77
|
+
viewport.scrollBy({ left: -scrollAmount, behavior: 'smooth' });
|
|
78
|
+
}
|
|
79
|
+
scrollNext() {
|
|
80
|
+
const viewport = this.sliderViewport.nativeElement;
|
|
81
|
+
const scrollAmount = viewport.offsetWidth;
|
|
82
|
+
viewport.scrollBy({ left: scrollAmount, behavior: 'smooth' });
|
|
83
|
+
}
|
|
84
|
+
scrollToCard(index) {
|
|
85
|
+
const viewport = this.sliderViewport.nativeElement;
|
|
86
|
+
const cards = this.cardItems.toArray();
|
|
87
|
+
if (cards[index]) {
|
|
88
|
+
const cardElement = cards[index].nativeElement;
|
|
89
|
+
const scrollLeft = cardElement.offsetLeft - viewport.offsetLeft;
|
|
90
|
+
viewport.scrollTo({ left: scrollLeft, behavior: 'smooth' });
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
onScroll() {
|
|
94
|
+
const viewport = this.sliderViewport.nativeElement;
|
|
95
|
+
const scrollLeft = viewport.scrollLeft;
|
|
96
|
+
const width = viewport.clientWidth;
|
|
97
|
+
// Simple heuristic for active dot
|
|
98
|
+
const index = Math.round(scrollLeft / width);
|
|
99
|
+
if (this.activeDotIndex !== index) {
|
|
100
|
+
this.activeDotIndex = index;
|
|
101
|
+
}
|
|
102
|
+
this.checkScrollLimits();
|
|
103
|
+
}
|
|
104
|
+
editSection() {
|
|
105
|
+
if (window.innerWidth <= 475)
|
|
106
|
+
return;
|
|
107
|
+
this._eventService.toggleEditorEvent.emit(false);
|
|
108
|
+
setTimeout(() => {
|
|
109
|
+
this._eventService.editSection.emit({ data: this.data });
|
|
110
|
+
}, 100);
|
|
111
|
+
}
|
|
112
|
+
get stylesLayout() {
|
|
113
|
+
return { ...this.style?.layout };
|
|
114
|
+
}
|
|
115
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TestimonialSliderComponent, deps: [{ token: i1.EventsService }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
116
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: TestimonialSliderComponent, isStandalone: true, selector: "simpo-testimonial-slider", inputs: { data: "data", index: "index", edit: "edit", delete: "delete", customClass: "customClass", nextComponentColor: "nextComponentColor" }, host: { listeners: { "window: resize": "getScreenSize($event)" } }, viewQueries: [{ propertyName: "sliderViewport", first: true, predicate: ["sliderViewport"], descendants: true }, { propertyName: "cardItems", predicate: ["cardItem"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<section [id]=\"data?.id\" simpoHover (hovering)=\"showEditTabs($event)\" class=\"total-container\"\r\n [attr.style]=\"customClass\">\r\n\r\n <div #mainContainer [id]=\"data?.id\" [simpoOverlay]=\"style?.background\" [spacingHorizontal]=\"stylesLayout\"\r\n [class.px-1]=\"screenWidth < 475\" [simpoBackground]=\"style?.background\" [simpoBorder]=\"style?.border\">\r\n\r\n <div class=\"container-fluid\" [id]=\"data?.id\" [simpoLayout]=\"style?.layout\">\r\n <!-- Added row and content-side per convention -->\r\n <div class=\"row content-side w-100\" [id]=\"data?.id\" [simpoAnimation]=\"style?.animation\">\r\n\r\n <div class=\"header-container\">\r\n <div *ngFor=\"let text of data?.content?.inputText\">\r\n <div [simpoContentTitleSpace]=\"headingSpace\">\r\n <simpo-text-editor [(value)]=\"text.value\" [editable]=\"edit || false\"></simpo-text-editor>\r\n </div>\r\n </div>\r\n\r\n <div class=\"nav-arrows\" *ngIf=\"getLength() > 1 && (showLeftArrow || showRightArrow)\">\r\n <button class=\"nav-arrow\" (click)=\"scrollPrev()\" [style.visibility]=\"showLeftArrow ? 'visible' : 'hidden'\">\r\n <mat-icon>arrow_back</mat-icon>\r\n </button>\r\n <button class=\"nav-arrow\" (click)=\"scrollNext()\" [style.visibility]=\"showRightArrow ? 'visible' : 'hidden'\">\r\n <mat-icon>arrow_forward</mat-icon>\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div class=\"slider-viewport\" [id]=\"data?.id\" #sliderViewport (scroll)=\"onScroll()\">\r\n <div class=\"testimonial-card size-{{(style?.size || 'Large') | lowercase}}\"\r\n *ngFor=\"let testimonial of content?.listItem?.data; let i = index\" #cardItem [simpoCorner]=\"style?.corners\">\r\n <!-- [simpoContainerLayout]=\"style?.layout\" -->\r\n <div class=\"quote-container\">\r\n <div class=\"quote-text\">\r\n <simpo-text-editor [(value)]=\"testimonial.inputText[0].value\"\r\n [editable]=\"edit || false\"></simpo-text-editor>\r\n </div>\r\n </div>\r\n\r\n <div class=\"user-info\">\r\n <div class=\"avatar-circle\" [style.backgroundColor]=\"style?.background?.accentColor\">\r\n <ng-container *ngIf=\"testimonial?.image?.url; else initials\">\r\n <img [src]=\"testimonial.image.url\" alt=\"User Avatar\" [appImageEditor]=\"edit || false\"\r\n [imageData]=\"testimonial.image\" [sectionId]=\"data?.id\">\r\n <!-- [simpoContainerLayout]=\"getLayout\" -->\r\n </ng-container>\r\n <ng-template #initials>\r\n {{ testimonial.inputText[1].value.charAt(0) }}\r\n </ng-template>\r\n </div>\r\n\r\n <div class=\"user-details\">\r\n <div class=\"user-name\">\r\n <simpo-text-editor [(value)]=\"testimonial.inputText[1].value\"\r\n [editable]=\"edit || false\"></simpo-text-editor>\r\n </div>\r\n <div class=\"user-role\" *ngIf=\"testimonial.inputText[2]\">\r\n <simpo-text-editor [(value)]=\"testimonial.inputText[2].value\"\r\n [editable]=\"edit || false\"></simpo-text-editor>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <ng-container *ngIf=\"style?.devider?.display\">\r\n <simpo-svg-divider [dividerType]=\"style?.devider?.deviderType\"\r\n [color]=\"nextComponentColor?.color\"></simpo-svg-divider>\r\n </ng-container>\r\n\r\n <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n </div>\r\n <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n </div>\r\n</section>", styles: [".total-container{position:relative}.header-container{display:flex;justify-content:space-between;align-items:center}.heading-large{margin:0}.nav-arrows{display:flex;gap:12px}.nav-arrow{width:48px!important;height:48px!important;border-radius:50%;border:1px solid #ddd;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:#555}.nav-arrow:hover{background:#f0f0f0;border-color:#bbb}.nav-arrow mat-icon{font-size:20px;width:20px;height:20px}.slider-viewport{width:100%;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;display:flex;gap:24px;padding:20px 40px}.slider-viewport::-webkit-scrollbar{display:none}.testimonial-card{scroll-snap-align:start;background:#fff;border-radius:24px;padding:40px;box-shadow:0 10px 30px #0000000d;display:flex;flex-direction:column;justify-content:space-between;transition:transform .3s ease}.testimonial-card:hover{transform:translateY(-5px)}.quote-text{color:#333;margin-bottom:30px}.user-info{display:flex;align-items:center;gap:16px}.avatar-circle{width:56px;height:56px;border-radius:50%;background-color:#d4b483;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#111;overflow:hidden}.avatar-circle img{width:100%;height:100%;object-fit:cover}.user-details{display:flex;flex-direction:column}@media (min-width: 992px){.testimonial-card.size-large{flex:0 0 52%}.testimonial-card.size-medium{flex:0 0 33.33%}.testimonial-card.size-small{flex:0 0 25%}}@media (max-width: 991px){.testimonial-card{flex:0 0 calc(80% - 12px)}}@media (max-width: 767px){.heading-large{font-size:32px}.testimonial-card{flex:0 0 100%;padding:30px}.header-container{padding:0 20px}.slider-viewport{padding:20px 20px 40px}}.hover_effect{position:unset;width:100%;top:0;left:0;height:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.LowerCasePipe, name: "lowercase" }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: SimpoElementsModule }, { kind: "component", type: i4.SvgDividerComponent, selector: "simpo-svg-divider", inputs: ["dividerType", "color"] }, { kind: "ngmodule", type: SimpoComponentModule }, { kind: "component", type: i5.HoverElementsComponent, selector: "simpo-hover-elements", inputs: ["data", "index", "editOptions", "isMerged", "isEcommerce"], outputs: ["edit"] }, { kind: "component", type: i6.DeleteHoverElementComponent, selector: "simpo-delete-hover-element", inputs: ["index", "data"], outputs: ["edit"] }, { kind: "directive", type:
|
|
117
|
+
//directives
|
|
118
|
+
AnimationDirective, selector: "[simpoAnimation]", inputs: ["simpoAnimation"] }, { kind: "directive", type: BackgroundDirective, selector: "[simpoBackground]", inputs: ["simpoBackground", "scrollValue"] }, { kind: "directive", type: BorderDirective, selector: "[simpoBorder]", inputs: ["simpoBorder"] }, { kind: "directive", type: ContentFitDirective, selector: "[simpoLayout]", inputs: ["simpoLayout"] }, { kind: "directive", type: CornerDirective, selector: "[simpoCorner]", inputs: ["simpoCorner"] }, { kind: "directive", type: HoverDirective, selector: "[simpoHover]", outputs: ["hovering"] }, { kind: "directive", type: OverlayDirective, selector: "[simpoOverlay]", inputs: ["simpoOverlay"] }, { kind: "directive", type: ContentTitleDirective, selector: "[simpoContentTitleSpace]", inputs: ["simpoContentTitleSpace"] }, { kind: "component", type: TextEditorComponent, selector: "simpo-text-editor", inputs: ["value", "editable", "sectionId", "label", "type"], outputs: ["valueChange"] }, { kind: "directive", type: ImageEditorDirective, selector: "[appImageEditor]", inputs: ["appImageEditor", "imageData", "sectionId", "showIcon", "iconData"] }, { kind: "directive", type: SpacingHorizontalDirective, selector: "[spacingHorizontal]", inputs: ["spacingHorizontal", "isHeader"] }] }); }
|
|
119
|
+
}
|
|
120
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TestimonialSliderComponent, decorators: [{
|
|
121
|
+
type: Component,
|
|
122
|
+
args: [{ selector: 'simpo-testimonial-slider', standalone: true, imports: [
|
|
123
|
+
CommonModule,
|
|
124
|
+
MatIconModule,
|
|
125
|
+
SimpoElementsModule,
|
|
126
|
+
SimpoComponentModule,
|
|
127
|
+
//directives
|
|
128
|
+
AnimationDirective,
|
|
129
|
+
BackgroundDirective,
|
|
130
|
+
BorderDirective,
|
|
131
|
+
ContentFitDirective,
|
|
132
|
+
CornerDirective,
|
|
133
|
+
HoverDirective,
|
|
134
|
+
OverlayDirective,
|
|
135
|
+
ContentTitleDirective,
|
|
136
|
+
TextEditorComponent,
|
|
137
|
+
ImageEditorDirective,
|
|
138
|
+
SpacingHorizontalDirective,
|
|
139
|
+
], template: "<section [id]=\"data?.id\" simpoHover (hovering)=\"showEditTabs($event)\" class=\"total-container\"\r\n [attr.style]=\"customClass\">\r\n\r\n <div #mainContainer [id]=\"data?.id\" [simpoOverlay]=\"style?.background\" [spacingHorizontal]=\"stylesLayout\"\r\n [class.px-1]=\"screenWidth < 475\" [simpoBackground]=\"style?.background\" [simpoBorder]=\"style?.border\">\r\n\r\n <div class=\"container-fluid\" [id]=\"data?.id\" [simpoLayout]=\"style?.layout\">\r\n <!-- Added row and content-side per convention -->\r\n <div class=\"row content-side w-100\" [id]=\"data?.id\" [simpoAnimation]=\"style?.animation\">\r\n\r\n <div class=\"header-container\">\r\n <div *ngFor=\"let text of data?.content?.inputText\">\r\n <div [simpoContentTitleSpace]=\"headingSpace\">\r\n <simpo-text-editor [(value)]=\"text.value\" [editable]=\"edit || false\"></simpo-text-editor>\r\n </div>\r\n </div>\r\n\r\n <div class=\"nav-arrows\" *ngIf=\"getLength() > 1 && (showLeftArrow || showRightArrow)\">\r\n <button class=\"nav-arrow\" (click)=\"scrollPrev()\" [style.visibility]=\"showLeftArrow ? 'visible' : 'hidden'\">\r\n <mat-icon>arrow_back</mat-icon>\r\n </button>\r\n <button class=\"nav-arrow\" (click)=\"scrollNext()\" [style.visibility]=\"showRightArrow ? 'visible' : 'hidden'\">\r\n <mat-icon>arrow_forward</mat-icon>\r\n </button>\r\n </div>\r\n </div>\r\n\r\n <div class=\"slider-viewport\" [id]=\"data?.id\" #sliderViewport (scroll)=\"onScroll()\">\r\n <div class=\"testimonial-card size-{{(style?.size || 'Large') | lowercase}}\"\r\n *ngFor=\"let testimonial of content?.listItem?.data; let i = index\" #cardItem [simpoCorner]=\"style?.corners\">\r\n <!-- [simpoContainerLayout]=\"style?.layout\" -->\r\n <div class=\"quote-container\">\r\n <div class=\"quote-text\">\r\n <simpo-text-editor [(value)]=\"testimonial.inputText[0].value\"\r\n [editable]=\"edit || false\"></simpo-text-editor>\r\n </div>\r\n </div>\r\n\r\n <div class=\"user-info\">\r\n <div class=\"avatar-circle\" [style.backgroundColor]=\"style?.background?.accentColor\">\r\n <ng-container *ngIf=\"testimonial?.image?.url; else initials\">\r\n <img [src]=\"testimonial.image.url\" alt=\"User Avatar\" [appImageEditor]=\"edit || false\"\r\n [imageData]=\"testimonial.image\" [sectionId]=\"data?.id\">\r\n <!-- [simpoContainerLayout]=\"getLayout\" -->\r\n </ng-container>\r\n <ng-template #initials>\r\n {{ testimonial.inputText[1].value.charAt(0) }}\r\n </ng-template>\r\n </div>\r\n\r\n <div class=\"user-details\">\r\n <div class=\"user-name\">\r\n <simpo-text-editor [(value)]=\"testimonial.inputText[1].value\"\r\n [editable]=\"edit || false\"></simpo-text-editor>\r\n </div>\r\n <div class=\"user-role\" *ngIf=\"testimonial.inputText[2]\">\r\n <simpo-text-editor [(value)]=\"testimonial.inputText[2].value\"\r\n [editable]=\"edit || false\"></simpo-text-editor>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <ng-container *ngIf=\"style?.devider?.display\">\r\n <simpo-svg-divider [dividerType]=\"style?.devider?.deviderType\"\r\n [color]=\"nextComponentColor?.color\"></simpo-svg-divider>\r\n </ng-container>\r\n\r\n <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n </div>\r\n <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n </div>\r\n</section>", styles: [".total-container{position:relative}.header-container{display:flex;justify-content:space-between;align-items:center}.heading-large{margin:0}.nav-arrows{display:flex;gap:12px}.nav-arrow{width:48px!important;height:48px!important;border-radius:50%;border:1px solid #ddd;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;color:#555}.nav-arrow:hover{background:#f0f0f0;border-color:#bbb}.nav-arrow mat-icon{font-size:20px;width:20px;height:20px}.slider-viewport{width:100%;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;display:flex;gap:24px;padding:20px 40px}.slider-viewport::-webkit-scrollbar{display:none}.testimonial-card{scroll-snap-align:start;background:#fff;border-radius:24px;padding:40px;box-shadow:0 10px 30px #0000000d;display:flex;flex-direction:column;justify-content:space-between;transition:transform .3s ease}.testimonial-card:hover{transform:translateY(-5px)}.quote-text{color:#333;margin-bottom:30px}.user-info{display:flex;align-items:center;gap:16px}.avatar-circle{width:56px;height:56px;border-radius:50%;background-color:#d4b483;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#111;overflow:hidden}.avatar-circle img{width:100%;height:100%;object-fit:cover}.user-details{display:flex;flex-direction:column}@media (min-width: 992px){.testimonial-card.size-large{flex:0 0 52%}.testimonial-card.size-medium{flex:0 0 33.33%}.testimonial-card.size-small{flex:0 0 25%}}@media (max-width: 991px){.testimonial-card{flex:0 0 calc(80% - 12px)}}@media (max-width: 767px){.heading-large{font-size:32px}.testimonial-card{flex:0 0 100%;padding:30px}.header-container{padding:0 20px}.slider-viewport{padding:20px 20px 40px}}.hover_effect{position:unset;width:100%;top:0;left:0;height:100%}\n"] }]
|
|
140
|
+
}], ctorParameters: () => [{ type: i1.EventsService }, { type: i0.Renderer2 }], propDecorators: { data: [{
|
|
141
|
+
type: Input
|
|
142
|
+
}], index: [{
|
|
143
|
+
type: Input
|
|
144
|
+
}], edit: [{
|
|
145
|
+
type: Input
|
|
146
|
+
}], delete: [{
|
|
147
|
+
type: Input
|
|
148
|
+
}], customClass: [{
|
|
149
|
+
type: Input
|
|
150
|
+
}], nextComponentColor: [{
|
|
151
|
+
type: Input
|
|
152
|
+
}], sliderViewport: [{
|
|
153
|
+
type: ViewChild,
|
|
154
|
+
args: ['sliderViewport']
|
|
155
|
+
}], cardItems: [{
|
|
156
|
+
type: ViewChildren,
|
|
157
|
+
args: ['cardItem']
|
|
158
|
+
}], getScreenSize: [{
|
|
159
|
+
type: HostListener,
|
|
160
|
+
args: ["window: resize", ["$event"]]
|
|
161
|
+
}] } });
|
|
162
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"testimonial-slider.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/sections/testimonial-slider/testimonial-slider.component.ts","../../../../../../projects/simpo-ui/src/lib/sections/testimonial-slider/testimonial-slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, HostListener, Input, QueryList, Renderer2, ViewChild, ViewChildren, OnInit, AfterViewInit } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { SimpoElementsModule } from '../../elements/index';\r\nimport { SimpoComponentModule } from '../../components/index';\r\nimport { AnimationDirective } from '../../directive/animation-directive';\r\nimport { BackgroundDirective } from '../../directive/background-directive';\r\nimport { ContentFitDirective } from '../../directive/content-fit-directive';\r\nimport { BorderDirective } from '../../directive/border-directive';\r\nimport { CornerDirective } from '../../directive/corner-directive';\r\nimport { HoverDirective } from '../../directive/hover-element-directive';\r\nimport { OverlayDirective } from '../../directive/overlay-directive';\r\nimport { EventsService } from './../../services/events.service';\r\nimport BaseSection from '../BaseSection';\r\nimport { ContentTitleDirective } from '../../directive/content-title-spacing.directive';\r\nimport { BackgroundModel, LayOutModel } from '../../styles/style.model';\r\nimport { TextEditorComponent } from '../../elements/text-editor/text-editor.component';\r\nimport { ImageEditorDirective } from '../../directive/image-editor.directive';\r\nimport { SpacingHorizontalDirective } from '../../directive/spacing-horizontal.directive';\r\nimport { TestimonialSliderModel, TestimonialSliderContentModel, TestimonialSliderStylesModel } from './testimonial-slider.model';\r\n\r\n@Component({\r\n  selector: 'simpo-testimonial-slider',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    MatIconModule,\r\n    SimpoElementsModule,\r\n    SimpoComponentModule,\r\n    //directives\r\n    AnimationDirective,\r\n    BackgroundDirective,\r\n    BorderDirective,\r\n    ContentFitDirective,\r\n    CornerDirective,\r\n    HoverDirective,\r\n    OverlayDirective,\r\n    ContentTitleDirective,\r\n    TextEditorComponent,\r\n    ImageEditorDirective,\r\n    SpacingHorizontalDirective,\r\n  ],\r\n  templateUrl: './testimonial-slider.component.html',\r\n  styleUrl: './testimonial-slider.component.css'\r\n})\r\nexport class TestimonialSliderComponent extends BaseSection implements OnInit, AfterViewInit {\r\n  @Input() data?: TestimonialSliderModel;\r\n  @Input() index?: number;\r\n  @Input() edit?: boolean;\r\n  @Input() delete?: boolean;\r\n  @Input() customClass?: string;\r\n  @Input() nextComponentColor?: BackgroundModel;\r\n\r\n  @ViewChild('sliderViewport') sliderViewport!: ElementRef<HTMLDivElement>;\r\n  @ViewChildren('cardItem') cardItems!: QueryList<ElementRef<HTMLDivElement>>;\r\n\r\n  content?: TestimonialSliderContentModel;\r\n  style?: TestimonialSliderStylesModel;\r\n  activeDotIndex: number = 0;\r\n  \r\n  showLeftArrow: boolean = true;\r\n  showRightArrow: boolean = true;\r\n\r\n  constructor(\r\n    private _eventService: EventsService,\r\n    private renderer: Renderer2\r\n  ) {\r\n    super();\r\n    this.getScreenSize();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.content = this.data?.content;\r\n    this.style = this.data?.styles;\r\n    this.deleteSelected = this.delete;\r\n  }\r\n\r\n  get headingSpace() {\r\n    return this.style?.layout?.headingSpacing;\r\n  }\r\n\r\n  get getLayout(): LayOutModel {\r\n    return { ...this.style?.layout } as LayOutModel;\r\n  }\r\n\r\n  screenWidth: any = \"\"\r\n  @HostListener(\"window: resize\", [\"$event\"])\r\n  getScreenSize() {\r\n    this.screenWidth = window.innerWidth;\r\n    this.checkScrollLimits();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    // Need a timeout to wait for rendering\r\n    setTimeout(() => {\r\n      this.checkScrollLimits();\r\n    }, 100);\r\n  }\r\n\r\n  checkScrollLimits(): void {\r\n    if (!this.sliderViewport) return;\r\n    const viewport = this.sliderViewport.nativeElement;\r\n    const scrollLeft = viewport.scrollLeft;\r\n    const width = viewport.clientWidth;\r\n    const totalWidth = viewport.scrollWidth;\r\n\r\n    this.showLeftArrow = scrollLeft > 0;\r\n    // adding 5 extra pixels due to rounding edge cases\r\n    this.showRightArrow = Math.ceil(scrollLeft + width) < totalWidth - 5;\r\n  }\r\n\r\n  getLength(): number {\r\n    return this.content?.listItem?.data?.length ?? 0;\r\n  }\r\n\r\n  getDotsArray(): number[] {\r\n    return Array(this.getLength()).fill(0);\r\n  }\r\n\r\n  scrollPrev(): void {\r\n    const viewport = this.sliderViewport.nativeElement;\r\n    const scrollAmount = viewport.offsetWidth;\r\n    viewport.scrollBy({ left: -scrollAmount, behavior: 'smooth' });\r\n  }\r\n\r\n  scrollNext(): void {\r\n    const viewport = this.sliderViewport.nativeElement;\r\n    const scrollAmount = viewport.offsetWidth;\r\n    viewport.scrollBy({ left: scrollAmount, behavior: 'smooth' });\r\n  }\r\n\r\n  scrollToCard(index: number): void {\r\n    const viewport = this.sliderViewport.nativeElement;\r\n    const cards = this.cardItems.toArray();\r\n    if (cards[index]) {\r\n      const cardElement = cards[index].nativeElement;\r\n      const scrollLeft = cardElement.offsetLeft - viewport.offsetLeft;\r\n      viewport.scrollTo({ left: scrollLeft, behavior: 'smooth' });\r\n    }\r\n  }\r\n\r\n  onScroll(): void {\r\n    const viewport = this.sliderViewport.nativeElement;\r\n    const scrollLeft = viewport.scrollLeft;\r\n    const width = viewport.clientWidth;\r\n    \r\n    // Simple heuristic for active dot\r\n    const index = Math.round(scrollLeft / width);\r\n    if (this.activeDotIndex !== index) {\r\n      this.activeDotIndex = index;\r\n    }\r\n    this.checkScrollLimits();\r\n  }\r\n\r\n  editSection(): void {\r\n    if (window.innerWidth <= 475) return;\r\n    this._eventService.toggleEditorEvent.emit(false);\r\n    setTimeout(() => {\r\n      this._eventService.editSection.emit({ data: this.data });\r\n    }, 100);\r\n  }\r\n\r\n  get stylesLayout(): LayOutModel {\r\n    return { ...this.style?.layout } as LayOutModel;\r\n  }\r\n}\r\n","<section [id]=\"data?.id\" simpoHover (hovering)=\"showEditTabs($event)\" class=\"total-container\"\r\n  [attr.style]=\"customClass\">\r\n\r\n  <div #mainContainer [id]=\"data?.id\" [simpoOverlay]=\"style?.background\" [spacingHorizontal]=\"stylesLayout\"\r\n    [class.px-1]=\"screenWidth < 475\" [simpoBackground]=\"style?.background\" [simpoBorder]=\"style?.border\">\r\n\r\n    <div class=\"container-fluid\" [id]=\"data?.id\" [simpoLayout]=\"style?.layout\">\r\n      <!-- Added row and content-side per convention -->\r\n      <div class=\"row content-side w-100\" [id]=\"data?.id\" [simpoAnimation]=\"style?.animation\">\r\n\r\n        <div class=\"header-container\">\r\n          <div *ngFor=\"let text of data?.content?.inputText\">\r\n            <div [simpoContentTitleSpace]=\"headingSpace\">\r\n              <simpo-text-editor [(value)]=\"text.value\" [editable]=\"edit || false\"></simpo-text-editor>\r\n            </div>\r\n          </div>\r\n\r\n          <div class=\"nav-arrows\" *ngIf=\"getLength() > 1 && (showLeftArrow || showRightArrow)\">\r\n            <button class=\"nav-arrow\" (click)=\"scrollPrev()\" [style.visibility]=\"showLeftArrow ? 'visible' : 'hidden'\">\r\n              <mat-icon>arrow_back</mat-icon>\r\n            </button>\r\n            <button class=\"nav-arrow\" (click)=\"scrollNext()\" [style.visibility]=\"showRightArrow ? 'visible' : 'hidden'\">\r\n              <mat-icon>arrow_forward</mat-icon>\r\n            </button>\r\n          </div>\r\n        </div>\r\n\r\n        <div class=\"slider-viewport\" [id]=\"data?.id\" #sliderViewport (scroll)=\"onScroll()\">\r\n          <div class=\"testimonial-card size-{{(style?.size || 'Large') | lowercase}}\"\r\n            *ngFor=\"let testimonial of content?.listItem?.data; let i = index\" #cardItem [simpoCorner]=\"style?.corners\">\r\n            <!-- [simpoContainerLayout]=\"style?.layout\" -->\r\n            <div class=\"quote-container\">\r\n              <div class=\"quote-text\">\r\n                <simpo-text-editor [(value)]=\"testimonial.inputText[0].value\"\r\n                  [editable]=\"edit || false\"></simpo-text-editor>\r\n              </div>\r\n            </div>\r\n\r\n            <div class=\"user-info\">\r\n              <div class=\"avatar-circle\" [style.backgroundColor]=\"style?.background?.accentColor\">\r\n                <ng-container *ngIf=\"testimonial?.image?.url; else initials\">\r\n                  <img [src]=\"testimonial.image.url\" alt=\"User Avatar\" [appImageEditor]=\"edit || false\"\r\n                    [imageData]=\"testimonial.image\" [sectionId]=\"data?.id\">\r\n                  <!-- [simpoContainerLayout]=\"getLayout\" -->\r\n                </ng-container>\r\n                <ng-template #initials>\r\n                  {{ testimonial.inputText[1].value.charAt(0) }}\r\n                </ng-template>\r\n              </div>\r\n\r\n              <div class=\"user-details\">\r\n                <div class=\"user-name\">\r\n                  <simpo-text-editor [(value)]=\"testimonial.inputText[1].value\"\r\n                    [editable]=\"edit || false\"></simpo-text-editor>\r\n                </div>\r\n                <div class=\"user-role\" *ngIf=\"testimonial.inputText[2]\">\r\n                  <simpo-text-editor [(value)]=\"testimonial.inputText[2].value\"\r\n                    [editable]=\"edit || false\"></simpo-text-editor>\r\n                </div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <ng-container *ngIf=\"style?.devider?.display\">\r\n    <simpo-svg-divider [dividerType]=\"style?.devider?.deviderType\"\r\n      [color]=\"nextComponentColor?.color\"></simpo-svg-divider>\r\n  </ng-container>\r\n\r\n  <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n    <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n  </div>\r\n  <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n    <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n  </div>\r\n</section>"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdGltb25pYWwtc2xpZGVyLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2ltcG8tdWkvc3JjL2xpYi9zZWN0aW9ucy90ZXN0aW1vbmlhbC1zbGlkZXIvdGVzdGltb25pYWwtc2xpZGVyLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb3JuZXJzIH0gZnJvbSBcIi4uLy4uL3N0eWxlc1wiO1xyXG5pbXBvcnQgeyBEaXNwbGF5U2VjdGlvbiwgSW1hZ2UsIElucHV0VGV4dE1vZGVsLCBMaXN0SXRlbU1vZGFsLCBTdHlsZXNNb2RlbCwgQ2FyZFN0eWxlcyB9IGZyb20gXCIuLy4uLy4uL3N0eWxlcy9zdHlsZS5tb2RlbFwiO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBUZXN0aW1vbmlhbFNsaWRlck1vZGVsIHtcclxuICAgIGlkOiBzdHJpbmc7XHJcbiAgICBzZWN0aW9uVHlwZTogc3RyaW5nO1xyXG4gICAgc2VjdGlvbk5hbWU6IHN0cmluZztcclxuICAgIGNvbnRlbnQ6IFRlc3RpbW9uaWFsU2xpZGVyQ29udGVudE1vZGVsO1xyXG4gICAgc3R5bGVzOiBUZXN0aW1vbmlhbFNsaWRlclN0eWxlc01vZGVsO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFRlc3RpbW9uaWFsU2xpZGVyQ29udGVudE1vZGVsIHtcclxuICAgIGlucHV0VGV4dDogW0lucHV0VGV4dE1vZGVsXTtcclxuICAgIGRpc3BsYXk6IERpc3BsYXlTZWN0aW9uO1xyXG4gICAgbGlzdEl0ZW06IExpc3RJdGVtTW9kYWw8VGVzdGltb25pYWxJdGVtTW9kZWw+O1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFRlc3RpbW9uaWFsSXRlbU1vZGVsIHtcclxuICAgIHN0YXR1czogYm9vbGVhbjtcclxuICAgIGltYWdlOiBJbWFnZTtcclxuICAgIGlucHV0VGV4dDogSW5wdXRUZXh0TW9kZWxbXTtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBUZXN0aW1vbmlhbFNsaWRlclN0eWxlc01vZGVsIGV4dGVuZHMgU3R5bGVzTW9kZWwsIENhcmRTdHlsZXMge1xyXG59XHJcbiJdfQ==
|
|
@@ -80,7 +80,7 @@ export class VideoCarouselSectionComponent extends BaseSection {
|
|
|
80
80
|
}, 100);
|
|
81
81
|
}
|
|
82
82
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: VideoCarouselSectionComponent, deps: [{ token: i1.EventsService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
83
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: VideoCarouselSectionComponent, isStandalone: true, selector: "simpo-video-carousel-section", inputs: { data: "data", index: "index", customClass: "customClass", nextComponentColor: "nextComponentColor", edit: "edit", delete: "delete" }, host: { listeners: { "window:resize": "getScreenSize($event)" } }, usesInheritance: true, ngImport: i0, template: "<section class=\"container-fluid\" [id]=\"data?.id\" simpoHover (hovering)=\"showEditTabs($event)\" class=\"total-container\"\r\n [attr.style]=\"customClass\">\r\n <div [spacingAround]=\"stylesLayout\" [id]=\"data?.id\" [simpoBackground]=\"style?.background\">\r\n <div
|
|
83
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: VideoCarouselSectionComponent, isStandalone: true, selector: "simpo-video-carousel-section", inputs: { data: "data", index: "index", customClass: "customClass", nextComponentColor: "nextComponentColor", edit: "edit", delete: "delete" }, host: { listeners: { "window:resize": "getScreenSize($event)" } }, usesInheritance: true, ngImport: i0, template: "<section class=\"container-fluid\" [id]=\"data?.id\" simpoHover (hovering)=\"showEditTabs($event)\" class=\"total-container\"\r\n [attr.style]=\"customClass\">\r\n <div [spacingAround]=\"stylesLayout\" [id]=\"data?.id\" [simpoBackground]=\"style?.background\">\r\n <div [simpoCorner]=\"style?.corners\"\r\n [ngClass]=\"{ 'video-screen': style?.layout?.fit === 'screen' }\" [id]=\"data?.id\" [simpoBorder]=\"style?.border\">\r\n\r\n <div class=\"d-flex mlr-0 w-100 position-relative\" *ngIf=\"data?.content?.inputText?.length\" [id]=\"data?.id\"\r\n [simpoAnimation]=\"style?.animation\">\r\n\r\n <!-- Main Video Stage -->\r\n <div class=\"stage-container w-100 p-0\" [simpoCorner]=\"style?.corners\">\r\n <video *ngIf=\"primaryVideoUrl\" [src]=\"primaryVideoUrl\" autoplay muted loop playsinline class=\"stage-video\"\r\n [class.active]=\"isPrimaryActive\"\r\n [ngClass]=\"{'vh-80': style?.layout?.fit === 'screen', 'vh-50': style?.layout?.fit === 'content'}\">\r\n </video>\r\n <video *ngIf=\"secondaryVideoUrl\" [src]=\"secondaryVideoUrl\" autoplay muted loop playsinline class=\"stage-video\"\r\n [class.active]=\"!isPrimaryActive\"\r\n [ngClass]=\"{'vh-80': style?.layout?.fit === 'screen', 'vh-50': style?.layout?.fit === 'content'}\">\r\n </video>\r\n <div class=\"stage-overlay\"></div>\r\n\r\n <!-- Booth Selection Overlay -->\r\n <div class=\"booth-selector d-flex flex-column justify-content-center align-items-end\">\r\n <div class=\"booth-header d-flex align-items-center mb-2\">\r\n <span class=\"live-dot\" [style.--accent-color]=\"style?.background?.accentColor\"\r\n [style.backgroundColor]=\"'var(--accent-color)'\"></span>\r\n <span class=\"live-text\">\r\n <simpo-text-editor *ngIf=\"data?.content?.inputText?.[1] as liveText\" [(value)]=\"liveText.value\" [editable]=\"edit || false\"></simpo-text-editor>\r\n <ng-container *ngIf=\"!data?.content?.inputText?.[1]\">LIVE BOOTHS</ng-container>\r\n </span>\r\n </div>\r\n <div class=\"booth-thumbnails d-flex\">\r\n <div *ngFor=\"let item of content?.listItem?.data; let i = index\" class=\"booth-item\"\r\n [class.active]=\"i === activeIndex\" (click)=\"setVideo(i)\">\r\n <div class=\"booth-thumb-wrapper\"\r\n [style.borderColor]=\"i === activeIndex ? style?.background?.accentColor : 'transparent'\"\r\n [style.boxShadow]=\"i === activeIndex ? '0 0 15px ' + style?.background?.accentColor + '4d' : 'none'\">\r\n <video [src]=\"item.video.url\" muted loop playsinline class=\"thumb-video\"></video>\r\n <div class=\"active-indicator\" *ngIf=\"i === activeIndex\">\r\n <span class=\"dot\" [style.backgroundColor]=\"style?.background?.accentColor\"></span>\r\n </div>\r\n </div>\r\n <div class=\"booth-label\">{{item.video.description || 'BOOTH ' + (i + 1)}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Optional Text Overlay -->\r\n <div class=\"text-overlay\" *ngIf=\"edit || data?.content?.inputText?.[0]?.value\">\r\n <simpo-text-editor *ngIf=\"data?.content?.inputText?.[0] as mainText\" [(value)]=\"mainText.value\" [editable]=\"edit || false\"></simpo-text-editor>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Svg Divider -->\r\n <ng-container *ngIf=\"style?.devider?.display\">\r\n <simpo-svg-divider [dividerType]=\"style?.devider?.deviderType\"\r\n [color]=\"nextComponentColor?.color\"></simpo-svg-divider>\r\n </ng-container>\r\n\r\n <!-- Editor Hover Elements -->\r\n <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n </div>\r\n <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n </div>\r\n</section>", styles: [".total-container{position:relative}.stage-container{position:relative;width:100%;overflow:hidden}.stage-video{width:100%;object-fit:cover;display:block;position:absolute;top:0;left:0;opacity:0;transition:opacity .8s ease-in-out;pointer-events:none}.stage-video.active{opacity:1;position:relative;pointer-events:auto}.vh-80{height:80vh}.vh-50{height:50vh}.stage-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(0deg,rgba(0,0,0,.4) 0%,transparent 30%,transparent 100%);pointer-events:none}.booth-selector{position:absolute;bottom:1.5rem;right:1.5rem;z-index:10;max-width:90%}.booth-header{background:#121212d9;padding:6px 14px;border-radius:50px;width:fit-content;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);margin-bottom:.75rem!important;margin:0 10px}.live-dot{width:10px;height:10px;background-color:var(--accent-color, #ff3b30);border-radius:50%;display:inline-block;margin-right:10px;box-shadow:0 0 10px var(--accent-color, rgba(255, 59, 48, .6));animation:pulse-red 2s infinite}@keyframes pulse-red{0%{transform:scale(.95);box-shadow:0 0 0 0 var(--accent-color, rgba(255, 59, 48, .7))}70%{transform:scale(1);box-shadow:0 0 0 10px #0000}to{transform:scale(.95);box-shadow:0 0 #0000}}.live-text{color:#fff;font-size:.65rem;font-weight:800;letter-spacing:1.5px;text-transform:uppercase}.booth-thumbnails{gap:10px;overflow-x:auto;padding:5px 10px;scrollbar-width:none}.booth-thumbnails::-webkit-scrollbar{display:none}.booth-item{cursor:pointer;flex:0 0 auto;width:110px;transition:all .3s cubic-bezier(.23,1,.32,1)}.booth-item:hover{transform:scale(1.05)}.booth-thumb-wrapper{position:relative;width:100%;aspect-ratio:16/9;border-radius:10px;overflow:hidden;border:2px solid rgba(255,255,255,.1);background:#1a1a1a;transition:border-color .3s ease}.booth-item.active .booth-thumb-wrapper{border:2.5px solid #ff3b30;box-shadow:0 8px 24px #ff3b3066}.thumb-video{width:100%;height:100%;object-fit:cover}.active-indicator{position:absolute;top:8px;left:8px;background:#ff3b30e6;width:6px;height:6px;border-radius:50%;box-shadow:0 0 6px #ff3b30}.booth-label{color:#f0f0f0;font-size:.6rem;margin-top:8px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;text-align:left;opacity:.8}.booth-item.active .booth-label{opacity:1;color:#fff}.text-overlay{position:absolute;top:2rem;left:2rem;z-index:10;color:#fff;text-shadow:0 4px 12px rgba(0,0,0,.8)}@media (max-width: 768px){.booth-selector{bottom:1rem;right:1rem;left:1rem;max-width:none;overflow-y:scroll;align-items:start!important}.booth-thumbnails{width:100%!important}.booth-item{width:110px}.vh-80{height:45vh}.vh-50{height:35vh}}\n"], dependencies: [{ kind: "ngmodule", type: SimpoElementsModule }, { kind: "component", type: i2.SvgDividerComponent, selector: "simpo-svg-divider", inputs: ["dividerType", "color"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: SimpoComponentModule }, { kind: "component", type: i4.HoverElementsComponent, selector: "simpo-hover-elements", inputs: ["data", "index", "editOptions", "isMerged", "isEcommerce"], outputs: ["edit"] }, { kind: "component", type: i5.DeleteHoverElementComponent, selector: "simpo-delete-hover-element", inputs: ["index", "data"], outputs: ["edit"] }, { kind: "component", type: TextEditorComponent, selector: "simpo-text-editor", inputs: ["value", "editable", "sectionId", "label", "type"], outputs: ["valueChange"] }, { kind: "directive", type:
|
|
84
84
|
//directives
|
|
85
85
|
AnimationDirective, selector: "[simpoAnimation]", inputs: ["simpoAnimation"] }, { kind: "directive", type: BackgroundDirective, selector: "[simpoBackground]", inputs: ["simpoBackground", "scrollValue"] }, { kind: "directive", type: BorderDirective, selector: "[simpoBorder]", inputs: ["simpoBorder"] }, { kind: "directive", type: CornerDirective, selector: "[simpoCorner]", inputs: ["simpoCorner"] }, { kind: "directive", type: HoverDirective, selector: "[simpoHover]", outputs: ["hovering"] }, { kind: "directive", type: SpacingAroundDirective, selector: "[spacingAround]", inputs: ["spacingAround", "backgroundInfo"] }] }); }
|
|
86
86
|
}
|
|
@@ -103,7 +103,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
103
103
|
ContentTitleDirective,
|
|
104
104
|
SpacingAroundDirective,
|
|
105
105
|
SpacingDirective,
|
|
106
|
-
], template: "<section class=\"container-fluid\" [id]=\"data?.id\" simpoHover (hovering)=\"showEditTabs($event)\" class=\"total-container\"\r\n [attr.style]=\"customClass\">\r\n <div [spacingAround]=\"stylesLayout\" [id]=\"data?.id\" [simpoBackground]=\"style?.background\">\r\n <div
|
|
106
|
+
], template: "<section class=\"container-fluid\" [id]=\"data?.id\" simpoHover (hovering)=\"showEditTabs($event)\" class=\"total-container\"\r\n [attr.style]=\"customClass\">\r\n <div [spacingAround]=\"stylesLayout\" [id]=\"data?.id\" [simpoBackground]=\"style?.background\">\r\n <div [simpoCorner]=\"style?.corners\"\r\n [ngClass]=\"{ 'video-screen': style?.layout?.fit === 'screen' }\" [id]=\"data?.id\" [simpoBorder]=\"style?.border\">\r\n\r\n <div class=\"d-flex mlr-0 w-100 position-relative\" *ngIf=\"data?.content?.inputText?.length\" [id]=\"data?.id\"\r\n [simpoAnimation]=\"style?.animation\">\r\n\r\n <!-- Main Video Stage -->\r\n <div class=\"stage-container w-100 p-0\" [simpoCorner]=\"style?.corners\">\r\n <video *ngIf=\"primaryVideoUrl\" [src]=\"primaryVideoUrl\" autoplay muted loop playsinline class=\"stage-video\"\r\n [class.active]=\"isPrimaryActive\"\r\n [ngClass]=\"{'vh-80': style?.layout?.fit === 'screen', 'vh-50': style?.layout?.fit === 'content'}\">\r\n </video>\r\n <video *ngIf=\"secondaryVideoUrl\" [src]=\"secondaryVideoUrl\" autoplay muted loop playsinline class=\"stage-video\"\r\n [class.active]=\"!isPrimaryActive\"\r\n [ngClass]=\"{'vh-80': style?.layout?.fit === 'screen', 'vh-50': style?.layout?.fit === 'content'}\">\r\n </video>\r\n <div class=\"stage-overlay\"></div>\r\n\r\n <!-- Booth Selection Overlay -->\r\n <div class=\"booth-selector d-flex flex-column justify-content-center align-items-end\">\r\n <div class=\"booth-header d-flex align-items-center mb-2\">\r\n <span class=\"live-dot\" [style.--accent-color]=\"style?.background?.accentColor\"\r\n [style.backgroundColor]=\"'var(--accent-color)'\"></span>\r\n <span class=\"live-text\">\r\n <simpo-text-editor *ngIf=\"data?.content?.inputText?.[1] as liveText\" [(value)]=\"liveText.value\" [editable]=\"edit || false\"></simpo-text-editor>\r\n <ng-container *ngIf=\"!data?.content?.inputText?.[1]\">LIVE BOOTHS</ng-container>\r\n </span>\r\n </div>\r\n <div class=\"booth-thumbnails d-flex\">\r\n <div *ngFor=\"let item of content?.listItem?.data; let i = index\" class=\"booth-item\"\r\n [class.active]=\"i === activeIndex\" (click)=\"setVideo(i)\">\r\n <div class=\"booth-thumb-wrapper\"\r\n [style.borderColor]=\"i === activeIndex ? style?.background?.accentColor : 'transparent'\"\r\n [style.boxShadow]=\"i === activeIndex ? '0 0 15px ' + style?.background?.accentColor + '4d' : 'none'\">\r\n <video [src]=\"item.video.url\" muted loop playsinline class=\"thumb-video\"></video>\r\n <div class=\"active-indicator\" *ngIf=\"i === activeIndex\">\r\n <span class=\"dot\" [style.backgroundColor]=\"style?.background?.accentColor\"></span>\r\n </div>\r\n </div>\r\n <div class=\"booth-label\">{{item.video.description || 'BOOTH ' + (i + 1)}}</div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Optional Text Overlay -->\r\n <div class=\"text-overlay\" *ngIf=\"edit || data?.content?.inputText?.[0]?.value\">\r\n <simpo-text-editor *ngIf=\"data?.content?.inputText?.[0] as mainText\" [(value)]=\"mainText.value\" [editable]=\"edit || false\"></simpo-text-editor>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Svg Divider -->\r\n <ng-container *ngIf=\"style?.devider?.display\">\r\n <simpo-svg-divider [dividerType]=\"style?.devider?.deviderType\"\r\n [color]=\"nextComponentColor?.color\"></simpo-svg-divider>\r\n </ng-container>\r\n\r\n <!-- Editor Hover Elements -->\r\n <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n </div>\r\n <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n </div>\r\n</section>", styles: [".total-container{position:relative}.stage-container{position:relative;width:100%;overflow:hidden}.stage-video{width:100%;object-fit:cover;display:block;position:absolute;top:0;left:0;opacity:0;transition:opacity .8s ease-in-out;pointer-events:none}.stage-video.active{opacity:1;position:relative;pointer-events:auto}.vh-80{height:80vh}.vh-50{height:50vh}.stage-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(0deg,rgba(0,0,0,.4) 0%,transparent 30%,transparent 100%);pointer-events:none}.booth-selector{position:absolute;bottom:1.5rem;right:1.5rem;z-index:10;max-width:90%}.booth-header{background:#121212d9;padding:6px 14px;border-radius:50px;width:fit-content;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.1);margin-bottom:.75rem!important;margin:0 10px}.live-dot{width:10px;height:10px;background-color:var(--accent-color, #ff3b30);border-radius:50%;display:inline-block;margin-right:10px;box-shadow:0 0 10px var(--accent-color, rgba(255, 59, 48, .6));animation:pulse-red 2s infinite}@keyframes pulse-red{0%{transform:scale(.95);box-shadow:0 0 0 0 var(--accent-color, rgba(255, 59, 48, .7))}70%{transform:scale(1);box-shadow:0 0 0 10px #0000}to{transform:scale(.95);box-shadow:0 0 #0000}}.live-text{color:#fff;font-size:.65rem;font-weight:800;letter-spacing:1.5px;text-transform:uppercase}.booth-thumbnails{gap:10px;overflow-x:auto;padding:5px 10px;scrollbar-width:none}.booth-thumbnails::-webkit-scrollbar{display:none}.booth-item{cursor:pointer;flex:0 0 auto;width:110px;transition:all .3s cubic-bezier(.23,1,.32,1)}.booth-item:hover{transform:scale(1.05)}.booth-thumb-wrapper{position:relative;width:100%;aspect-ratio:16/9;border-radius:10px;overflow:hidden;border:2px solid rgba(255,255,255,.1);background:#1a1a1a;transition:border-color .3s ease}.booth-item.active .booth-thumb-wrapper{border:2.5px solid #ff3b30;box-shadow:0 8px 24px #ff3b3066}.thumb-video{width:100%;height:100%;object-fit:cover}.active-indicator{position:absolute;top:8px;left:8px;background:#ff3b30e6;width:6px;height:6px;border-radius:50%;box-shadow:0 0 6px #ff3b30}.booth-label{color:#f0f0f0;font-size:.6rem;margin-top:8px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;text-align:left;opacity:.8}.booth-item.active .booth-label{opacity:1;color:#fff}.text-overlay{position:absolute;top:2rem;left:2rem;z-index:10;color:#fff;text-shadow:0 4px 12px rgba(0,0,0,.8)}@media (max-width: 768px){.booth-selector{bottom:1rem;right:1rem;left:1rem;max-width:none;overflow-y:scroll;align-items:start!important}.booth-thumbnails{width:100%!important}.booth-item{width:110px}.vh-80{height:45vh}.vh-50{height:35vh}}\n"] }]
|
|
107
107
|
}], ctorParameters: () => [{ type: i1.EventsService }], propDecorators: { data: [{
|
|
108
108
|
type: Input
|
|
109
109
|
}], index: [{
|
|
@@ -120,4 +120,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
120
120
|
type: HostListener,
|
|
121
121
|
args: ['window:resize', ['$event']]
|
|
122
122
|
}] } });
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"video-carousel-section.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/sections/video-carousel-section/video-carousel-section.component.ts","../../../../../../projects/simpo-ui/src/lib/sections/video-carousel-section/video-carousel-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, Input, OnInit } from '@angular/core';\r\nimport {\r\n  VideoCarouselSection,\r\n  VideoCarouselSectionContentModel,\r\n  VideoCarouselSectionStylesModel,\r\n} from './video-carousel.model';\r\nimport { CommonModule } from '@angular/common';\r\nimport { SimpoElementsModule } from './../../elements/index';\r\n\r\nimport { AnimationDirective } from '../../directive/animation-directive';\r\nimport { BackgroundDirective } from '../../directive/background-directive';\r\nimport { ContentFitDirective } from '../../directive/content-fit-directive';\r\nimport { BorderDirective } from '../../directive/border-directive';\r\nimport { CornerDirective } from '../../directive/corner-directive';\r\nimport { HoverDirective } from '../../directive/hover-element-directive';\r\nimport { OverlayDirective } from '../../directive/overlay-directive';\r\nimport { EventsService } from './../../services/events.service';\r\nimport { SimpoComponentModule } from './../../components/index';\r\nimport BaseSection from '../BaseSection';\r\nimport { ContentTitleDirective } from '../../directive/content-title-spacing.directive';\r\nimport { SPACING } from '../../styles/index';\r\nimport { BackgroundModel, LayOutModel, SpacingModel } from '../../styles/style.model';\r\nimport { TextEditorComponent } from '../../elements/text-editor/text-editor.component';\r\nimport { SpacingAroundDirective } from '../../directive/spacing-around.directive';\r\nimport { MatIcon } from '@angular/material/icon';\r\nimport { SpacingDirective } from '../../directive/spacing.directive';\r\n\r\n@Component({\r\n  selector: 'simpo-video-carousel-section',\r\n  standalone: true,\r\n  imports: [\r\n    MatIcon,\r\n    SimpoElementsModule,\r\n    CommonModule,\r\n    SimpoComponentModule,\r\n    TextEditorComponent,\r\n\r\n    //directives\r\n    AnimationDirective,\r\n    BackgroundDirective,\r\n    BorderDirective,\r\n    ContentFitDirective,\r\n    CornerDirective,\r\n    HoverDirective,\r\n    OverlayDirective,\r\n    ContentTitleDirective,\r\n    SpacingAroundDirective,\r\n    SpacingDirective,\r\n  ],\r\n  templateUrl: './video-carousel-section.component.html',\r\n  styleUrl: './video-carousel-section.component.css',\r\n})\r\nexport class VideoCarouselSectionComponent extends BaseSection implements OnInit {\r\n  @Input() data?: VideoCarouselSection;\r\n  @Input() index?: number;\r\n  @Input() customClass?: string;\r\n\r\n  @Input() nextComponentColor?: BackgroundModel;\r\n  content?: VideoCarouselSectionContentModel;\r\n  style?: VideoCarouselSectionStylesModel;\r\n  @Input() edit?: boolean;\r\n  @Input() delete?: boolean;\r\n\r\n  constructor(\r\n    private _eventService: EventsService\r\n  ) {\r\n    super();\r\n    this.getScreenSize();\r\n  }\r\n\r\n  activeIndex: number = 0;\r\n  primaryVideoUrl: string = '';\r\n  secondaryVideoUrl: string = '';\r\n  isPrimaryActive: boolean = true;\r\n\r\n  ngOnInit() {\r\n    this.content = this.data?.content;\r\n    this.style = this.data?.styles;\r\n    this.deleteSelected = this.delete;\r\n\r\n    if (this.content?.listItem?.data?.length) {\r\n      this.primaryVideoUrl = this.content.listItem.data[0].video.url;\r\n    }\r\n  }\r\n\r\n  screenWidth: number = 475;\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  get spacingLayout() {\r\n    return { ...this.style?.layout?.spacing } as SpacingModel;\r\n  }\r\n\r\n  setVideo(index: number) {\r\n    if (this.activeIndex === index) return;\r\n\r\n    const newUrl = this.content?.listItem?.data[index]?.video?.url || '';\r\n\r\n    if (this.isPrimaryActive) {\r\n      this.secondaryVideoUrl = newUrl;\r\n      this.isPrimaryActive = false;\r\n    } else {\r\n      this.primaryVideoUrl = newUrl;\r\n      this.isPrimaryActive = true;\r\n    }\r\n\r\n    this.activeIndex = index;\r\n  }\r\n\r\n  get activeVideo() {\r\n    return this.content?.listItem?.data[this.activeIndex]?.video;\r\n  }\r\n\r\n  get headingSpace() {\r\n    return this.style?.layout.headingSpacing as SPACING;\r\n  }\r\n\r\n  editSection() {\r\n    if (window.innerWidth <= 475) return;\r\n\r\n    this._eventService.toggleEditorEvent.emit(false);\r\n    setTimeout(() => {\r\n      this._eventService.editSection.emit({ data: this.data });\r\n    }, 100);\r\n  }\r\n}\r\n","<section class=\"container-fluid\" [id]=\"data?.id\" simpoHover (hovering)=\"showEditTabs($event)\" class=\"total-container\"\r\n  [attr.style]=\"customClass\">\r\n  <div [spacingAround]=\"stylesLayout\" [id]=\"data?.id\" [simpoBackground]=\"style?.background\">\r\n    <div *ngFor=\"let text of data?.content?.inputText\" [simpoCorner]=\"style?.corners\"\r\n      [ngClass]=\"{ 'video-screen': style?.layout?.fit === 'screen' }\" [id]=\"data?.id\" [simpoBorder]=\"style?.border\">\r\n\r\n      <div class=\"d-flex mlr-0 w-100 position-relative\" *ngIf=\"data?.content?.inputText?.length\" [id]=\"data?.id\"\r\n        [simpoAnimation]=\"style?.animation\">\r\n\r\n        <!-- Main Video Stage -->\r\n        <div class=\"stage-container w-100 p-0\" [simpoCorner]=\"style?.corners\">\r\n          <video *ngIf=\"primaryVideoUrl\" [src]=\"primaryVideoUrl\" autoplay muted loop playsinline class=\"stage-video\"\r\n            [class.active]=\"isPrimaryActive\"\r\n            [ngClass]=\"{'vh-80': style?.layout?.fit === 'screen', 'vh-50': style?.layout?.fit === 'content'}\">\r\n          </video>\r\n          <video *ngIf=\"secondaryVideoUrl\" [src]=\"secondaryVideoUrl\" autoplay muted loop playsinline class=\"stage-video\"\r\n            [class.active]=\"!isPrimaryActive\"\r\n            [ngClass]=\"{'vh-80': style?.layout?.fit === 'screen', 'vh-50': style?.layout?.fit === 'content'}\">\r\n          </video>\r\n          <div class=\"stage-overlay\"></div>\r\n\r\n          <!-- Booth Selection Overlay -->\r\n          <div class=\"booth-selector d-flex flex-column justify-content-center align-items-end\">\r\n            <div class=\"booth-header d-flex align-items-center mb-2\">\r\n              <span class=\"live-dot\" [style.--accent-color]=\"style?.background?.accentColor\"\r\n                [style.backgroundColor]=\"'var(--accent-color)'\"></span>\r\n              <span class=\"live-text\">LIVE BOOTHS</span>\r\n            </div>\r\n            <div class=\"booth-thumbnails d-flex\">\r\n              <div *ngFor=\"let item of content?.listItem?.data; let i = index\" class=\"booth-item\"\r\n                [class.active]=\"i === activeIndex\" (click)=\"setVideo(i)\">\r\n                <div class=\"booth-thumb-wrapper\"\r\n                  [style.borderColor]=\"i === activeIndex ? style?.background?.accentColor : 'transparent'\"\r\n                  [style.boxShadow]=\"i === activeIndex ? '0 0 15px ' + style?.background?.accentColor + '4d' : 'none'\">\r\n                  <video [src]=\"item.video.url\" muted loop playsinline class=\"thumb-video\"></video>\r\n                  <div class=\"active-indicator\" *ngIf=\"i === activeIndex\">\r\n                    <span class=\"dot\" [style.backgroundColor]=\"style?.background?.accentColor\"></span>\r\n                  </div>\r\n                </div>\r\n                <div class=\"booth-label\">{{item.video.description || 'BOOTH ' + (i + 1)}}</div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n\r\n        <!-- Optional Text Overlay -->\r\n        <div class=\"text-overlay\" *ngIf=\"edit || text.value\">\r\n          <simpo-text-editor [(value)]=\"text.value\" [editable]=\"edit || false\"></simpo-text-editor>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- Svg Divider -->\r\n  <ng-container *ngIf=\"style?.devider?.display\">\r\n    <simpo-svg-divider [dividerType]=\"style?.devider?.deviderType\"\r\n      [color]=\"nextComponentColor?.color\"></simpo-svg-divider>\r\n  </ng-container>\r\n\r\n  <!-- Editor Hover Elements -->\r\n  <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n    <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n  </div>\r\n  <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n    <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n  </div>\r\n</section>"]}
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"video-carousel-section.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/sections/video-carousel-section/video-carousel-section.component.ts","../../../../../../projects/simpo-ui/src/lib/sections/video-carousel-section/video-carousel-section.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, Input, OnInit } from '@angular/core';\r\nimport {\r\n  VideoCarouselSection,\r\n  VideoCarouselSectionContentModel,\r\n  VideoCarouselSectionStylesModel,\r\n} from './video-carousel.model';\r\nimport { CommonModule } from '@angular/common';\r\nimport { SimpoElementsModule } from './../../elements/index';\r\n\r\nimport { AnimationDirective } from '../../directive/animation-directive';\r\nimport { BackgroundDirective } from '../../directive/background-directive';\r\nimport { ContentFitDirective } from '../../directive/content-fit-directive';\r\nimport { BorderDirective } from '../../directive/border-directive';\r\nimport { CornerDirective } from '../../directive/corner-directive';\r\nimport { HoverDirective } from '../../directive/hover-element-directive';\r\nimport { OverlayDirective } from '../../directive/overlay-directive';\r\nimport { EventsService } from './../../services/events.service';\r\nimport { SimpoComponentModule } from './../../components/index';\r\nimport BaseSection from '../BaseSection';\r\nimport { ContentTitleDirective } from '../../directive/content-title-spacing.directive';\r\nimport { SPACING } from '../../styles/index';\r\nimport { BackgroundModel, LayOutModel, SpacingModel } from '../../styles/style.model';\r\nimport { TextEditorComponent } from '../../elements/text-editor/text-editor.component';\r\nimport { SpacingAroundDirective } from '../../directive/spacing-around.directive';\r\nimport { MatIcon } from '@angular/material/icon';\r\nimport { SpacingDirective } from '../../directive/spacing.directive';\r\n\r\n@Component({\r\n  selector: 'simpo-video-carousel-section',\r\n  standalone: true,\r\n  imports: [\r\n    MatIcon,\r\n    SimpoElementsModule,\r\n    CommonModule,\r\n    SimpoComponentModule,\r\n    TextEditorComponent,\r\n\r\n    //directives\r\n    AnimationDirective,\r\n    BackgroundDirective,\r\n    BorderDirective,\r\n    ContentFitDirective,\r\n    CornerDirective,\r\n    HoverDirective,\r\n    OverlayDirective,\r\n    ContentTitleDirective,\r\n    SpacingAroundDirective,\r\n    SpacingDirective,\r\n  ],\r\n  templateUrl: './video-carousel-section.component.html',\r\n  styleUrl: './video-carousel-section.component.css',\r\n})\r\nexport class VideoCarouselSectionComponent extends BaseSection implements OnInit {\r\n  @Input() data?: VideoCarouselSection;\r\n  @Input() index?: number;\r\n  @Input() customClass?: string;\r\n\r\n  @Input() nextComponentColor?: BackgroundModel;\r\n  content?: VideoCarouselSectionContentModel;\r\n  style?: VideoCarouselSectionStylesModel;\r\n  @Input() edit?: boolean;\r\n  @Input() delete?: boolean;\r\n\r\n  constructor(\r\n    private _eventService: EventsService\r\n  ) {\r\n    super();\r\n    this.getScreenSize();\r\n  }\r\n\r\n  activeIndex: number = 0;\r\n  primaryVideoUrl: string = '';\r\n  secondaryVideoUrl: string = '';\r\n  isPrimaryActive: boolean = true;\r\n\r\n  ngOnInit() {\r\n    this.content = this.data?.content;\r\n    this.style = this.data?.styles;\r\n    this.deleteSelected = this.delete;\r\n\r\n    if (this.content?.listItem?.data?.length) {\r\n      this.primaryVideoUrl = this.content.listItem.data[0].video.url;\r\n    }\r\n  }\r\n\r\n  screenWidth: number = 475;\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  get spacingLayout() {\r\n    return { ...this.style?.layout?.spacing } as SpacingModel;\r\n  }\r\n\r\n  setVideo(index: number) {\r\n    if (this.activeIndex === index) return;\r\n\r\n    const newUrl = this.content?.listItem?.data[index]?.video?.url || '';\r\n\r\n    if (this.isPrimaryActive) {\r\n      this.secondaryVideoUrl = newUrl;\r\n      this.isPrimaryActive = false;\r\n    } else {\r\n      this.primaryVideoUrl = newUrl;\r\n      this.isPrimaryActive = true;\r\n    }\r\n\r\n    this.activeIndex = index;\r\n  }\r\n\r\n  get activeVideo() {\r\n    return this.content?.listItem?.data[this.activeIndex]?.video;\r\n  }\r\n\r\n  get headingSpace() {\r\n    return this.style?.layout.headingSpacing as SPACING;\r\n  }\r\n\r\n  editSection() {\r\n    if (window.innerWidth <= 475) return;\r\n\r\n    this._eventService.toggleEditorEvent.emit(false);\r\n    setTimeout(() => {\r\n      this._eventService.editSection.emit({ data: this.data });\r\n    }, 100);\r\n  }\r\n}\r\n","<section class=\"container-fluid\" [id]=\"data?.id\" simpoHover (hovering)=\"showEditTabs($event)\" class=\"total-container\"\r\n  [attr.style]=\"customClass\">\r\n  <div [spacingAround]=\"stylesLayout\" [id]=\"data?.id\" [simpoBackground]=\"style?.background\">\r\n    <div [simpoCorner]=\"style?.corners\"\r\n      [ngClass]=\"{ 'video-screen': style?.layout?.fit === 'screen' }\" [id]=\"data?.id\" [simpoBorder]=\"style?.border\">\r\n\r\n      <div class=\"d-flex mlr-0 w-100 position-relative\" *ngIf=\"data?.content?.inputText?.length\" [id]=\"data?.id\"\r\n        [simpoAnimation]=\"style?.animation\">\r\n\r\n        <!-- Main Video Stage -->\r\n        <div class=\"stage-container w-100 p-0\" [simpoCorner]=\"style?.corners\">\r\n          <video *ngIf=\"primaryVideoUrl\" [src]=\"primaryVideoUrl\" autoplay muted loop playsinline class=\"stage-video\"\r\n            [class.active]=\"isPrimaryActive\"\r\n            [ngClass]=\"{'vh-80': style?.layout?.fit === 'screen', 'vh-50': style?.layout?.fit === 'content'}\">\r\n          </video>\r\n          <video *ngIf=\"secondaryVideoUrl\" [src]=\"secondaryVideoUrl\" autoplay muted loop playsinline class=\"stage-video\"\r\n            [class.active]=\"!isPrimaryActive\"\r\n            [ngClass]=\"{'vh-80': style?.layout?.fit === 'screen', 'vh-50': style?.layout?.fit === 'content'}\">\r\n          </video>\r\n          <div class=\"stage-overlay\"></div>\r\n\r\n          <!-- Booth Selection Overlay -->\r\n          <div class=\"booth-selector d-flex flex-column justify-content-center align-items-end\">\r\n            <div class=\"booth-header d-flex align-items-center mb-2\">\r\n              <span class=\"live-dot\" [style.--accent-color]=\"style?.background?.accentColor\"\r\n                [style.backgroundColor]=\"'var(--accent-color)'\"></span>\r\n              <span class=\"live-text\">\r\n                <simpo-text-editor *ngIf=\"data?.content?.inputText?.[1] as liveText\" [(value)]=\"liveText.value\" [editable]=\"edit || false\"></simpo-text-editor>\r\n                <ng-container *ngIf=\"!data?.content?.inputText?.[1]\">LIVE BOOTHS</ng-container>\r\n              </span>\r\n            </div>\r\n            <div class=\"booth-thumbnails d-flex\">\r\n              <div *ngFor=\"let item of content?.listItem?.data; let i = index\" class=\"booth-item\"\r\n                [class.active]=\"i === activeIndex\" (click)=\"setVideo(i)\">\r\n                <div class=\"booth-thumb-wrapper\"\r\n                  [style.borderColor]=\"i === activeIndex ? style?.background?.accentColor : 'transparent'\"\r\n                  [style.boxShadow]=\"i === activeIndex ? '0 0 15px ' + style?.background?.accentColor + '4d' : 'none'\">\r\n                  <video [src]=\"item.video.url\" muted loop playsinline class=\"thumb-video\"></video>\r\n                  <div class=\"active-indicator\" *ngIf=\"i === activeIndex\">\r\n                    <span class=\"dot\" [style.backgroundColor]=\"style?.background?.accentColor\"></span>\r\n                  </div>\r\n                </div>\r\n                <div class=\"booth-label\">{{item.video.description || 'BOOTH ' + (i + 1)}}</div>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n\r\n        <!-- Optional Text Overlay -->\r\n        <div class=\"text-overlay\" *ngIf=\"edit || data?.content?.inputText?.[0]?.value\">\r\n          <simpo-text-editor *ngIf=\"data?.content?.inputText?.[0] as mainText\" [(value)]=\"mainText.value\" [editable]=\"edit || false\"></simpo-text-editor>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- Svg Divider -->\r\n  <ng-container *ngIf=\"style?.devider?.display\">\r\n    <simpo-svg-divider [dividerType]=\"style?.devider?.deviderType\"\r\n      [color]=\"nextComponentColor?.color\"></simpo-svg-divider>\r\n  </ng-container>\r\n\r\n  <!-- Editor Hover Elements -->\r\n  <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n    <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n  </div>\r\n  <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n    <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n  </div>\r\n</section>"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlkZW8tY2Fyb3VzZWwubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zaW1wby11aS9zcmMvbGliL3NlY3Rpb25zL3ZpZGVvLWNhcm91c2VsLXNlY3Rpb24vdmlkZW8tY2Fyb3VzZWwubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvcm5lcnMgfSBmcm9tICcuLy4uLy4uL3N0eWxlcy9pbmRleCc7XHJcbmltcG9ydCB7XHJcbiAgSW5wdXRUZXh0TW9kZWwsXHJcbiAgTGlzdEl0ZW1Nb2RhbCxcclxuICBTdHlsZXNNb2RlbCxcclxuICBWaWRlbyxcclxuICBWaWRlb1N0eWxlLFxyXG59IGZyb20gJy4vLi4vLi4vc3R5bGVzL3N0eWxlLm1vZGVsJztcclxuaW1wb3J0IHsgQ0FSRF9TSVpFIH0gZnJvbSAnLi8uLi8uLi9zdHlsZXMvdHlwZXMnO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBWaWRlb0Nhcm91c2VsU2VjdGlvbiB7XHJcbiAgaWQ6IHN0cmluZztcclxuICBzZWN0aW9uVHlwZTogc3RyaW5nO1xyXG4gIHNlY3Rpb25OYW1lOiBzdHJpbmc7XHJcbiAgY29udGVudDogVmlkZW9DYXJvdXNlbFNlY3Rpb25Db250ZW50TW9kZWw7XHJcbiAgc3R5bGVzOiBWaWRlb0Nhcm91c2VsU2VjdGlvblN0eWxlc01vZGVsO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFZpZGVvQ2Fyb3VzZWxTZWN0aW9uQ29udGVudE1vZGVsIHtcclxuICBpbnB1dFRleHQ6IElucHV0VGV4dE1vZGVsW107XHJcbiAgbGlzdEl0ZW06IExpc3RJdGVtTW9kYWw8VmlkZW9DYXJvdXNlbEl0ZW1Nb2RlbD47XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgVmlkZW9DYXJvdXNlbEl0ZW1Nb2RlbCB7XHJcbiAgdmlkZW86IFZpZGVvO1xyXG59IFxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBWaWRlb0Nhcm91c2VsU2VjdGlvblN0eWxlc01vZGVsIGV4dGVuZHMgU3R5bGVzTW9kZWwge1xyXG4gIGNvcm5lcnM6IENvcm5lcnM7XHJcbiAgdmlkZW86IFZpZGVvU3R5bGU7XHJcbiAgcmVtb3ZlR2FwczogYm9vbGVhbjtcclxuICBmdWxsV2lkdGg6IGJvb2xlYW47XHJcbiAgc2l6ZTogQ0FSRF9TSVpFO1xyXG59XHJcbiJdfQ==
|