@posiwise/resource-module 0.0.148 → 0.0.150
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/index.mjs +22 -3
- package/esm2022/lib/public/components/reslease-note-card/release-note-card.component.mjs +13 -9
- package/esm2022/lib/public/components/resource-blogs/resource-blog-top-banner/resource-blog-top-banner.component.mjs +6 -6
- package/esm2022/lib/public/components/resource-blogs/resource-blog.component.mjs +6 -6
- package/esm2022/lib/public/components/resource-case-studies/case-studies-cards/case-studies-cards.component.mjs +18 -12
- package/esm2022/lib/public/components/resource-case-studies/resource-case-studies.component.mjs +10 -10
- package/esm2022/lib/public/components/resource-company-card/resource-company-card.component.mjs +7 -8
- package/esm2022/lib/public/components/resource-contact-us/resource-contact-us.component.mjs +510 -0
- package/esm2022/lib/public/components/resource-contact-us/resource-contact-us.module.mjs +77 -0
- package/esm2022/lib/public/components/resource-edit-card/resource-edit-card.component.mjs +5 -5
- package/esm2022/lib/public/components/resource-edit-card-lazy/resource-edit-card-lazy.component.mjs +75 -0
- package/esm2022/lib/public/components/resource-integration/integration-top-banner/integration-top-banner.component.mjs +6 -6
- package/esm2022/lib/public/components/resource-integration/resource-integration.component.mjs +13 -13
- package/esm2022/lib/public/components/resource-post/related-resources/related-resources.component.mjs +8 -8
- package/esm2022/lib/public/components/resource-post/related-resources/resource-cards/resource-cards.component.mjs +8 -8
- package/esm2022/lib/public/components/resource-post/resource-post-details/resource-post-details.component.mjs +55 -24
- package/esm2022/lib/public/components/resource-post/resource-post.component.mjs +7 -8
- package/esm2022/lib/public/components/resource-release-notes/resource-release-notes-top-banner/resource-release-notes-top-banner.component.mjs +6 -6
- package/esm2022/lib/public/components/resource-release-notes/resource-release-notes.component.mjs +6 -6
- package/esm2022/lib/public/components/resource-top-banner-edit/resource-top-banner-edit.component.mjs +3 -3
- package/esm2022/lib/public/components/resource-vault/resource-vault.component.mjs +8 -8
- package/esm2022/lib/public/components/resource-videos/resource-video-cards/resource-video-cards.component.mjs +18 -12
- package/esm2022/lib/public/components/resource-videos/resource-videos-top-banner/resource-videos-top-banner.component.mjs +6 -6
- package/esm2022/lib/public/components/resource-videos/resource-videos.component.mjs +6 -6
- package/esm2022/lib/public/components/resource-webinars/replay-event-cards/replay-event-cards.component.mjs +8 -8
- package/esm2022/lib/public/components/resource-webinars/resource-webinars.component.mjs +9 -9
- package/esm2022/lib/public/components/resource-webinars/upcoming-event-cards/upcoming-event-cards.component.mjs +21 -14
- package/esm2022/lib/public/components/resources/resource-tags/resource-tags.component.mjs +3 -3
- package/esm2022/lib/public/components/resources/resources.component.mjs +21 -18
- package/esm2022/lib/public/components/resources/vault-section/vault-section.component.mjs +5 -5
- package/esm2022/lib/public/components/resources-hub/resources-hub.component.mjs +12 -11
- package/esm2022/lib/public/components/testimonial-card/testimonial-card.component.mjs +10 -9
- package/esm2022/lib/public/components/white-papers/white-papers-top-banner/white-papers-top-banner.component.mjs +6 -6
- package/esm2022/lib/public/components/white-papers/white-papers.component.mjs +6 -6
- package/esm2022/lib/public/modules/blogs/resource-blogs.module.mjs +30 -0
- package/esm2022/lib/public/modules/case-studies/resource-case-studies.module.mjs +35 -0
- package/esm2022/lib/public/modules/events/resource-events.module.mjs +30 -0
- package/esm2022/lib/public/modules/hub/resource-hub.module.mjs +29 -0
- package/esm2022/lib/public/modules/integrations/resource-integrations.module.mjs +30 -0
- package/esm2022/lib/public/modules/post/resource-post.module.mjs +32 -0
- package/esm2022/lib/public/modules/release-notes/resource-release-notes.module.mjs +30 -0
- package/esm2022/lib/public/modules/root/resource-root-shared.module.mjs +61 -0
- package/esm2022/lib/public/modules/root/resource-root.module.mjs +32 -0
- package/esm2022/lib/public/modules/videos/resource-videos.module.mjs +30 -0
- package/esm2022/lib/public/modules/white-papers/resource-white-papers.module.mjs +31 -0
- package/esm2022/lib/public/resource-public.module.mjs +5 -175
- package/esm2022/lib/public/resource-public.routing.module.mjs +13 -62
- package/esm2022/lib/public/shared/resource-cards.module.mjs +116 -0
- package/esm2022/lib/public/shared/resource-edit.module.mjs +64 -0
- package/esm2022/lib/public/shared/resource-shared.module.mjs +116 -0
- package/esm2022/lib/shared/resource-modal.interface.mjs +2 -0
- package/fesm2022/posiwise-resource-module-base-top-banner.component-DFT3ZpJE.mjs +111 -0
- package/fesm2022/posiwise-resource-module-base-top-banner.component-DFT3ZpJE.mjs.map +1 -0
- package/fesm2022/posiwise-resource-module-posiwise-resource-module-D953ymF3.mjs +2311 -0
- package/fesm2022/posiwise-resource-module-posiwise-resource-module-D953ymF3.mjs.map +1 -0
- package/fesm2022/posiwise-resource-module-resource-blogs.module-Dpg-VGXf.mjs +91 -0
- package/fesm2022/posiwise-resource-module-resource-blogs.module-Dpg-VGXf.mjs.map +1 -0
- package/fesm2022/posiwise-resource-module-resource-case-studies.module-Bxfa0c61.mjs +127 -0
- package/fesm2022/posiwise-resource-module-resource-case-studies.module-Bxfa0c61.mjs.map +1 -0
- package/fesm2022/posiwise-resource-module-resource-events.module-CNKoXu2J.mjs +245 -0
- package/fesm2022/posiwise-resource-module-resource-events.module-CNKoXu2J.mjs.map +1 -0
- package/fesm2022/posiwise-resource-module-resource-hub.module-ggk9jRt9.mjs +249 -0
- package/fesm2022/posiwise-resource-module-resource-hub.module-ggk9jRt9.mjs.map +1 -0
- package/fesm2022/posiwise-resource-module-resource-integrations.module-vGdvpS64.mjs +286 -0
- package/fesm2022/posiwise-resource-module-resource-integrations.module-vGdvpS64.mjs.map +1 -0
- package/fesm2022/posiwise-resource-module-resource-post.module-RkJpZSPU.mjs +318 -0
- package/fesm2022/posiwise-resource-module-resource-post.module-RkJpZSPU.mjs.map +1 -0
- package/fesm2022/posiwise-resource-module-resource-release-notes.module-DKu39Lgo.mjs +124 -0
- package/fesm2022/posiwise-resource-module-resource-release-notes.module-DKu39Lgo.mjs.map +1 -0
- package/fesm2022/posiwise-resource-module-resource-root.module-CItOAAUj.mjs +403 -0
- package/fesm2022/posiwise-resource-module-resource-root.module-CItOAAUj.mjs.map +1 -0
- package/fesm2022/posiwise-resource-module-resource-videos.module-CuXWTy8y.mjs +91 -0
- package/fesm2022/posiwise-resource-module-resource-videos.module-CuXWTy8y.mjs.map +1 -0
- package/fesm2022/posiwise-resource-module-resource-white-papers.module-BJe9cvpS.mjs +92 -0
- package/fesm2022/posiwise-resource-module-resource-white-papers.module-BJe9cvpS.mjs.map +1 -0
- package/fesm2022/posiwise-resource-module.mjs +32 -3119
- package/fesm2022/posiwise-resource-module.mjs.map +1 -1
- package/index.d.ts +17 -2
- package/lib/public/components/reslease-note-card/release-note-card.component.d.ts +2 -1
- package/lib/public/components/resource-case-studies/case-studies-cards/case-studies-cards.component.d.ts +4 -2
- package/lib/public/components/resource-contact-us/resource-contact-us.component.d.ts +126 -0
- package/lib/public/components/resource-contact-us/resource-contact-us.module.d.ts +23 -0
- package/lib/public/components/resource-edit-card-lazy/resource-edit-card-lazy.component.d.ts +19 -0
- package/lib/public/components/resource-post/resource-post-details/resource-post-details.component.d.ts +5 -4
- package/lib/public/components/resource-videos/resource-video-cards/resource-video-cards.component.d.ts +4 -2
- package/lib/public/components/resource-webinars/upcoming-event-cards/upcoming-event-cards.component.d.ts +4 -2
- package/lib/public/components/resources/resources.component.d.ts +3 -2
- package/lib/public/modules/blogs/resource-blogs.module.d.ts +10 -0
- package/lib/public/modules/case-studies/resource-case-studies.module.d.ts +10 -0
- package/lib/public/modules/events/resource-events.module.d.ts +10 -0
- package/lib/public/modules/hub/resource-hub.module.d.ts +9 -0
- package/lib/public/modules/integrations/resource-integrations.module.d.ts +10 -0
- package/lib/public/modules/post/resource-post.module.d.ts +11 -0
- package/lib/public/modules/release-notes/resource-release-notes.module.d.ts +10 -0
- package/lib/public/modules/root/resource-root-shared.module.d.ts +17 -0
- package/lib/public/modules/root/resource-root.module.d.ts +11 -0
- package/lib/public/modules/videos/resource-videos.module.d.ts +10 -0
- package/lib/public/modules/white-papers/resource-white-papers.module.d.ts +10 -0
- package/lib/public/resource-public.module.d.ts +2 -51
- package/lib/public/shared/resource-cards.module.d.ts +32 -0
- package/lib/public/shared/resource-edit.module.d.ts +22 -0
- package/lib/public/shared/resource-shared.module.d.ts +19 -0
- package/lib/shared/resource-modal.interface.d.ts +6 -0
- package/package.json +1 -1
- package/esm2022/lib/public/components/resource-card-list/resource-card-list.component.mjs +0 -22
- package/esm2022/lib/public/components/resources-read/resources-read.component.mjs +0 -125
- package/lib/public/components/resource-card-list/resource-card-list.component.d.ts +0 -8
- package/lib/public/components/resources-read/resources-read.component.d.ts +0 -43
|
@@ -0,0 +1,510 @@
|
|
|
1
|
+
import { moveItemInArray } from '@angular/cdk/drag-drop';
|
|
2
|
+
import { DOCUMENT } from '@angular/common';
|
|
3
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, Inject, Injector, Input, TemplateRef, ViewChild } from '@angular/core';
|
|
4
|
+
import { UntypedFormBuilder, Validators } from '@angular/forms';
|
|
5
|
+
import { DomSanitizer } from '@angular/platform-browser';
|
|
6
|
+
import { AdminService } from '@posiwise/admin-module-utils';
|
|
7
|
+
import { AppBaseComponent } from '@posiwise/app-base-component';
|
|
8
|
+
import { AbTestService, AuthService, ValidationService } from '@posiwise/common-services';
|
|
9
|
+
import { HelperService } from '@posiwise/helper-service';
|
|
10
|
+
import { CustomUploaderComponent } from '@posiwise/shared-components';
|
|
11
|
+
import { CrmService } from '@posiwise/smart-crm-shared';
|
|
12
|
+
import { StatusCodes } from 'http-status-codes';
|
|
13
|
+
import Swal from 'sweetalert2';
|
|
14
|
+
import { NgbModal } from '@ng-bootstrap/ng-bootstrap';
|
|
15
|
+
import * as i0 from "@angular/core";
|
|
16
|
+
import * as i1 from "@angular/forms";
|
|
17
|
+
import * as i2 from "@posiwise/common-services";
|
|
18
|
+
import * as i3 from "@posiwise/smart-crm-shared";
|
|
19
|
+
import * as i4 from "@angular/platform-browser";
|
|
20
|
+
import * as i5 from "@posiwise/admin-module-utils";
|
|
21
|
+
import * as i6 from "@ng-bootstrap/ng-bootstrap";
|
|
22
|
+
import * as i7 from "@angular/common";
|
|
23
|
+
import * as i8 from "@angular/router";
|
|
24
|
+
import * as i9 from "@angular/cdk/drag-drop";
|
|
25
|
+
import * as i10 from "@posiwise/directives";
|
|
26
|
+
import * as i11 from "ngx-captcha";
|
|
27
|
+
import * as i12 from "primeng/dropdown";
|
|
28
|
+
import * as i13 from "@posiwise/shared-components";
|
|
29
|
+
import * as i14 from "@jsverse/transloco";
|
|
30
|
+
export class Trial4ContactUsComponent extends AppBaseComponent {
|
|
31
|
+
openQuestionsEditModal() {
|
|
32
|
+
this.editingQuestions = JSON.parse(JSON.stringify(this.editingQuestions ?? []));
|
|
33
|
+
this.modalService.open(this.questionsEditModal, { centered: true, size: 'lg' });
|
|
34
|
+
}
|
|
35
|
+
constructor(fb, authService, crmService, sanitizer, adminService, injector, abTestService, modalService, cdr, document) {
|
|
36
|
+
super(injector);
|
|
37
|
+
this.fb = fb;
|
|
38
|
+
this.authService = authService;
|
|
39
|
+
this.crmService = crmService;
|
|
40
|
+
this.sanitizer = sanitizer;
|
|
41
|
+
this.adminService = adminService;
|
|
42
|
+
this.abTestService = abTestService;
|
|
43
|
+
this.modalService = modalService;
|
|
44
|
+
this.cdr = cdr;
|
|
45
|
+
this.document = document;
|
|
46
|
+
this.editingQuestions = [];
|
|
47
|
+
this.isFooterVisible = false;
|
|
48
|
+
this.recaptcha = null;
|
|
49
|
+
this.subscriptionId = this.appConfig.crm.subscription_id;
|
|
50
|
+
this.sourceId = this.appConfig.crm.source_id;
|
|
51
|
+
this.masterSubscriptionId = this.appConfig.master_subscription.subscription_id;
|
|
52
|
+
this.canEditResourcesValue = false;
|
|
53
|
+
this.logo = this.appConfig?.company?.logos?.main_contrast?.url;
|
|
54
|
+
this.trialBgImage2 = this.appConfig?.signup_config.trial?.image_bg2?.url;
|
|
55
|
+
this.tosId = this.appConfig?.main_tos_id;
|
|
56
|
+
this.description = this.appConfig.company.description;
|
|
57
|
+
this.email = this.appConfig.company.email;
|
|
58
|
+
this.companyName = this.appConfig.company.name;
|
|
59
|
+
this.street = this.appConfig.company.street;
|
|
60
|
+
this.questions = this.appConfig?.pages_config?.contact_us?.questions;
|
|
61
|
+
this.hubspot = this.appConfig?.pages_config?.contact_us?.hubspot;
|
|
62
|
+
this.footerLinks = this.appConfig?.pages_config?.footer_links?.items;
|
|
63
|
+
this.footerLinksData = this.appConfig?.pages_config?.footer_links;
|
|
64
|
+
this.youtubeUrl = this.appConfig.social?.youtube_url;
|
|
65
|
+
this.linkedInUrl = this.appConfig.social?.linkedin_url;
|
|
66
|
+
this.domainId = this.appConfig.domain_id;
|
|
67
|
+
this.editingEmail = this.email;
|
|
68
|
+
this.isEditingEmail = false;
|
|
69
|
+
this.submitted = false;
|
|
70
|
+
this.isCaptchaVerified = false;
|
|
71
|
+
this.isEmailValid = true;
|
|
72
|
+
this.isEditingStreet = false;
|
|
73
|
+
this.editingFooterLinks = {
|
|
74
|
+
items: []
|
|
75
|
+
};
|
|
76
|
+
this.captchaKeyV2 = this.appConfig.integrations.captcha_key_V2;
|
|
77
|
+
this.contactUsForm();
|
|
78
|
+
}
|
|
79
|
+
ngOnInit() {
|
|
80
|
+
setTimeout(() => (this.isHubspotReady = true), 2000);
|
|
81
|
+
if (this.userLoggedIn) {
|
|
82
|
+
this.localStorage.getItem$('product').subscribe(res => {
|
|
83
|
+
const data = res ? JSON.parse(res) : null;
|
|
84
|
+
this.id = data?.subscriptionId;
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
this.previewData = {
|
|
88
|
+
url: this.logo,
|
|
89
|
+
name: 'logo_main_contrast.png'
|
|
90
|
+
};
|
|
91
|
+
this.editingStreet = this.street;
|
|
92
|
+
if (Array.isArray(this.appConfig.pages_config?.ab_tests)) {
|
|
93
|
+
this.abTests = this.appConfig.pages_config.ab_tests.find(test => test.description === 'contact-us');
|
|
94
|
+
this.microserviceName = this.abTests?.microservice_name;
|
|
95
|
+
this.experimentName = this.abTests?.experiment_name;
|
|
96
|
+
this.shardName = this.abTests?.db_shard;
|
|
97
|
+
}
|
|
98
|
+
const footerItem = this.getFooterHubspotForm();
|
|
99
|
+
if (footerItem?.div) {
|
|
100
|
+
// NOSONAR: Trusted HTML content is handled safely here
|
|
101
|
+
this.hubspotHtml = this.sanitizer.bypassSecurityTrustHtml(footerItem.div); // NOSONAR
|
|
102
|
+
}
|
|
103
|
+
this.editingQuestions = this.questions;
|
|
104
|
+
this.question = this.questions?.[0]?.question;
|
|
105
|
+
this.psaOptions = [
|
|
106
|
+
{ label: 'Select PSA', value: '' },
|
|
107
|
+
...(this.questions?.[0]?.options ?? [])
|
|
108
|
+
.filter(q => q.option?.trim())
|
|
109
|
+
.map(q => ({
|
|
110
|
+
label: q.option,
|
|
111
|
+
value: q.option
|
|
112
|
+
}))
|
|
113
|
+
];
|
|
114
|
+
}
|
|
115
|
+
ngOnChanges(changes) {
|
|
116
|
+
if (changes['user'] || changes['userLoggedIn']) {
|
|
117
|
+
if (this.userLoggedIn && this.user) {
|
|
118
|
+
this.updateCanEditResourcesValue();
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
openLogoEditModal() {
|
|
123
|
+
this.modalService.open(this.logoModal, {
|
|
124
|
+
centered: true,
|
|
125
|
+
size: 'md'
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
onSaveFile(event) {
|
|
129
|
+
const formData = new FormData();
|
|
130
|
+
const data = { subscription_id: this.subscriptionId };
|
|
131
|
+
if (event.file instanceof File) {
|
|
132
|
+
data[event.name] = event.file;
|
|
133
|
+
}
|
|
134
|
+
else if (event.file === null) {
|
|
135
|
+
data[`remove_${event.name}`] = true;
|
|
136
|
+
}
|
|
137
|
+
for (const key in data) {
|
|
138
|
+
formData.append(key, data[key]);
|
|
139
|
+
}
|
|
140
|
+
this.adminService.updateDomainConfig(this.domainId, formData).subscribe(() => {
|
|
141
|
+
if (event.file) {
|
|
142
|
+
this.logo = URL.createObjectURL(event.file);
|
|
143
|
+
this.modalService.dismissAll();
|
|
144
|
+
}
|
|
145
|
+
this.toast.success(event.file ? 'Logo updated' : 'Logo removed');
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
saveQuestions(modal) {
|
|
149
|
+
const updateData = {
|
|
150
|
+
contact_us: {
|
|
151
|
+
...this.appConfig.pages_config?.contact_us,
|
|
152
|
+
questions: this.editingQuestions
|
|
153
|
+
},
|
|
154
|
+
subscription_id: this.id
|
|
155
|
+
};
|
|
156
|
+
this.adminService.updateDomainConfig(this.domainId, updateData).subscribe(() => {
|
|
157
|
+
this.questions = this.editingQuestions;
|
|
158
|
+
this.toast.success('Questions updated');
|
|
159
|
+
this.question = this.editingQuestions?.[0]?.question;
|
|
160
|
+
if (this.editingQuestions?.[0]?.options?.length > 0) {
|
|
161
|
+
this.psaOptions = [
|
|
162
|
+
{ label: 'Select PSA', value: '' },
|
|
163
|
+
...(this.questions?.[0]?.options ?? [])
|
|
164
|
+
.filter(q => q.option?.trim())
|
|
165
|
+
.map(q => ({
|
|
166
|
+
label: q.option,
|
|
167
|
+
value: q.option
|
|
168
|
+
}))
|
|
169
|
+
];
|
|
170
|
+
}
|
|
171
|
+
else {
|
|
172
|
+
this.psaOptions = [];
|
|
173
|
+
}
|
|
174
|
+
modal.close();
|
|
175
|
+
});
|
|
176
|
+
}
|
|
177
|
+
addNewQuestion() {
|
|
178
|
+
this.editingQuestions.push({ question: '', options: [] });
|
|
179
|
+
}
|
|
180
|
+
addQuestionOption(qIndex) {
|
|
181
|
+
this.editingQuestions[qIndex].options.push({ option: '' });
|
|
182
|
+
}
|
|
183
|
+
removeQuestionOption(qIndex, optIndex) {
|
|
184
|
+
this.editingQuestions[qIndex].options.splice(optIndex, 1);
|
|
185
|
+
}
|
|
186
|
+
dropQuestions(event) {
|
|
187
|
+
moveItemInArray(this.editingQuestions, event.previousIndex, event.currentIndex);
|
|
188
|
+
}
|
|
189
|
+
dropQuestionOptions(qIndex, event) {
|
|
190
|
+
moveItemInArray(this.editingQuestions[qIndex].options, event.previousIndex, event.currentIndex);
|
|
191
|
+
}
|
|
192
|
+
openSocialEditModal() {
|
|
193
|
+
this.editingYoutubeUrl = this.youtubeUrl;
|
|
194
|
+
this.editingLinkedInUrl = this.linkedInUrl;
|
|
195
|
+
this.editingCompanyName = this.companyName;
|
|
196
|
+
this.modalService.open(this.socialEditModal, { centered: true, size: 'lg' });
|
|
197
|
+
}
|
|
198
|
+
saveSocialLinks(modal) {
|
|
199
|
+
const updateData = {
|
|
200
|
+
youtube_url: this.editingYoutubeUrl,
|
|
201
|
+
linkedin_url: this.editingLinkedInUrl,
|
|
202
|
+
company_name: this.editingCompanyName,
|
|
203
|
+
subscription_id: this.id
|
|
204
|
+
};
|
|
205
|
+
this.adminService.updateDomainConfig(this.domainId, updateData).subscribe(() => {
|
|
206
|
+
this.youtubeUrl = this.editingYoutubeUrl;
|
|
207
|
+
this.linkedInUrl = this.editingLinkedInUrl;
|
|
208
|
+
this.companyName = this.editingCompanyName;
|
|
209
|
+
this.toast.success('Social links and company name updated');
|
|
210
|
+
modal.close();
|
|
211
|
+
});
|
|
212
|
+
}
|
|
213
|
+
hasValidOptions() {
|
|
214
|
+
return this.questions?.[0]?.options?.some(opt => opt.option?.trim());
|
|
215
|
+
}
|
|
216
|
+
ngAfterViewInit() {
|
|
217
|
+
this.watchIframeHeightChange();
|
|
218
|
+
this.observer = new IntersectionObserver(([entry]) => {
|
|
219
|
+
if (entry.isIntersecting) {
|
|
220
|
+
this.isFooterVisible = true;
|
|
221
|
+
this.cdr.detectChanges();
|
|
222
|
+
this.observer?.disconnect();
|
|
223
|
+
}
|
|
224
|
+
}, { threshold: 0.1 });
|
|
225
|
+
this.observer.observe(this.footerSection.nativeElement);
|
|
226
|
+
}
|
|
227
|
+
openEditFooterLinksModal(content) {
|
|
228
|
+
this.footerLinksData = this.footerLinksData ?? {};
|
|
229
|
+
this.footerLinksData.items = this.footerLinksData.items ?? [];
|
|
230
|
+
this.editingFooterLinks = JSON.parse(JSON.stringify(this.footerLinksData));
|
|
231
|
+
this.modalService.open(content, {
|
|
232
|
+
size: 'lg',
|
|
233
|
+
centered: true,
|
|
234
|
+
windowClass: 'modal-holder'
|
|
235
|
+
});
|
|
236
|
+
}
|
|
237
|
+
watchIframeHeightChange() {
|
|
238
|
+
const iframe = this.document.querySelector('.hubspot-container');
|
|
239
|
+
if (!iframe)
|
|
240
|
+
return;
|
|
241
|
+
const interval = setInterval(() => {
|
|
242
|
+
const newHeight = iframe['offsetHeight'];
|
|
243
|
+
if (newHeight === 250) {
|
|
244
|
+
clearInterval(interval);
|
|
245
|
+
this.callAbTestFinish();
|
|
246
|
+
}
|
|
247
|
+
}, 300);
|
|
248
|
+
}
|
|
249
|
+
// New method to handle Hubspot content loading
|
|
250
|
+
onHubspotLoad(event) {
|
|
251
|
+
const container = event.target;
|
|
252
|
+
container.classList.add('content-loaded');
|
|
253
|
+
// Optional: Trigger layout recalculation
|
|
254
|
+
setTimeout(() => {
|
|
255
|
+
window.dispatchEvent(new Event('resize'));
|
|
256
|
+
}, 100);
|
|
257
|
+
}
|
|
258
|
+
callAbTestFinish() {
|
|
259
|
+
if (this.experimentName && this.microserviceName) {
|
|
260
|
+
this.abTestService
|
|
261
|
+
.finishABExperiment(this.experimentName, this.microserviceName)
|
|
262
|
+
.subscribe(() => {
|
|
263
|
+
this.modalService.open(this.content, {
|
|
264
|
+
centered: true,
|
|
265
|
+
windowClass: 'modal-holder'
|
|
266
|
+
});
|
|
267
|
+
});
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
contactUsForm() {
|
|
271
|
+
this.form = this.fb.group({
|
|
272
|
+
first_name: ['', Validators.required],
|
|
273
|
+
last_name: [''],
|
|
274
|
+
company: [''],
|
|
275
|
+
psa: [''],
|
|
276
|
+
enquiry: ['', Validators.required],
|
|
277
|
+
email: ['', Validators.required]
|
|
278
|
+
});
|
|
279
|
+
}
|
|
280
|
+
onSubmit() {
|
|
281
|
+
this.submitted = true;
|
|
282
|
+
if (this.form.valid) {
|
|
283
|
+
this.isCaptchaVerified = true;
|
|
284
|
+
this.submitted = false;
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
handleSuccess(token) {
|
|
288
|
+
if (token) {
|
|
289
|
+
this.authService.validateReCaptcha(token).subscribe((isSuccess) => {
|
|
290
|
+
if (isSuccess && this.form.valid) {
|
|
291
|
+
const data = { ...this.form.getRawValue() };
|
|
292
|
+
const formattedEnquiry = `${data.enquiry}; Question: ${this.question}; Answer: ${data.psa}`;
|
|
293
|
+
const postData = {
|
|
294
|
+
first_name: `${data.first_name}`,
|
|
295
|
+
last_name: `${data.first_name}`,
|
|
296
|
+
company: `${data.first_name}`,
|
|
297
|
+
email: `${data.email}`,
|
|
298
|
+
enquiry: this.psaOptions.length ? formattedEnquiry : `${data.enquiry}`,
|
|
299
|
+
psa: data.psa,
|
|
300
|
+
subscription_id: this.subscriptionId,
|
|
301
|
+
crm_source_id: this.sourceId,
|
|
302
|
+
master_subscription_id: this.masterSubscriptionId,
|
|
303
|
+
notify_user: false,
|
|
304
|
+
is_manual: false
|
|
305
|
+
};
|
|
306
|
+
this.crmService.postCrmLead(this.subscriptionId, postData).subscribe(resp => {
|
|
307
|
+
// example of snippet to close the experiment and track in GA
|
|
308
|
+
if (resp?.status === StatusCodes.OK) {
|
|
309
|
+
this.googleAnalyticsService.sendEvent('new-lead-registration', // category, eg: videos
|
|
310
|
+
'subscribe-success', // action, eg: Play
|
|
311
|
+
'coming-soon-three', // label, eg: Chappy
|
|
312
|
+
1 // value, eg: 10
|
|
313
|
+
);
|
|
314
|
+
if (this.experimentName && this.microserviceName) {
|
|
315
|
+
this.abTestService
|
|
316
|
+
.finishABExperiment(this.experimentName, this.microserviceName)
|
|
317
|
+
.subscribe(() => {
|
|
318
|
+
this.modalService.open(this.content, {
|
|
319
|
+
centered: true,
|
|
320
|
+
windowClass: 'modal-holder'
|
|
321
|
+
});
|
|
322
|
+
});
|
|
323
|
+
}
|
|
324
|
+
else {
|
|
325
|
+
Swal.fire(resp.message);
|
|
326
|
+
}
|
|
327
|
+
}
|
|
328
|
+
this.form.reset();
|
|
329
|
+
this.isCaptchaVerified = false;
|
|
330
|
+
});
|
|
331
|
+
}
|
|
332
|
+
});
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
scrollToTop() {
|
|
336
|
+
this.document.documentElement.scrollTop = 0;
|
|
337
|
+
}
|
|
338
|
+
getFooterHubspotForm() {
|
|
339
|
+
if (!this.hubspot?.length) {
|
|
340
|
+
return null;
|
|
341
|
+
}
|
|
342
|
+
return this.hubspot.find(item => item.position === 'footer') ?? null;
|
|
343
|
+
}
|
|
344
|
+
navigateToBookMeeting() {
|
|
345
|
+
window.open('https://calendly.com/cloudolive', '_blank', 'noreferrer noopener');
|
|
346
|
+
}
|
|
347
|
+
validateEmail() {
|
|
348
|
+
const email = this.form.get('email').value;
|
|
349
|
+
if (email) {
|
|
350
|
+
this.isEmailValid = ValidationService.email(email);
|
|
351
|
+
}
|
|
352
|
+
else {
|
|
353
|
+
this.isEmailValid = true;
|
|
354
|
+
}
|
|
355
|
+
}
|
|
356
|
+
addFooterLink() {
|
|
357
|
+
this.editingFooterLinks.items.push({
|
|
358
|
+
title: '',
|
|
359
|
+
path: '',
|
|
360
|
+
subtitles: []
|
|
361
|
+
});
|
|
362
|
+
}
|
|
363
|
+
removeFooterLink(index) {
|
|
364
|
+
this.editingFooterLinks.items.splice(index, 1);
|
|
365
|
+
}
|
|
366
|
+
addSubtitle(footerIndex) {
|
|
367
|
+
this.editingFooterLinks.items[footerIndex].subtitles.push({
|
|
368
|
+
title: '',
|
|
369
|
+
path: ''
|
|
370
|
+
});
|
|
371
|
+
}
|
|
372
|
+
removeSubtitle(footerIndex, subtitleIndex) {
|
|
373
|
+
this.editingFooterLinks.items[footerIndex].subtitles.splice(subtitleIndex, 1);
|
|
374
|
+
}
|
|
375
|
+
dropFooterLinks(event) {
|
|
376
|
+
moveItemInArray(this.editingFooterLinks.items, event.previousIndex, event.currentIndex);
|
|
377
|
+
}
|
|
378
|
+
dropSubtitles(footerIndex, event) {
|
|
379
|
+
moveItemInArray(this.editingFooterLinks.items[footerIndex].subtitles, event.previousIndex, event.currentIndex);
|
|
380
|
+
}
|
|
381
|
+
saveFooterLinks(modal) {
|
|
382
|
+
const updatedConfig = {
|
|
383
|
+
footer_links: this.editingFooterLinks,
|
|
384
|
+
subscription_id: this.id
|
|
385
|
+
};
|
|
386
|
+
this.adminService
|
|
387
|
+
.updateDomainConfig(this.appConfig?.domain_id, updatedConfig)
|
|
388
|
+
.subscribe(() => {
|
|
389
|
+
this.toast.success('Footer links updated');
|
|
390
|
+
this.footerLinks = [...this.editingFooterLinks.items];
|
|
391
|
+
this.footerLinksData = { ...this.editingFooterLinks };
|
|
392
|
+
modal.close();
|
|
393
|
+
});
|
|
394
|
+
}
|
|
395
|
+
saveEmail() {
|
|
396
|
+
this.email = this.editingEmail;
|
|
397
|
+
this.adminService
|
|
398
|
+
.updateDomainConfig(this.appConfig?.domain_id, {
|
|
399
|
+
company_email: this.editingEmail,
|
|
400
|
+
subscription_id: this.id
|
|
401
|
+
})
|
|
402
|
+
.subscribe(() => {
|
|
403
|
+
this.toast.success('Email updated');
|
|
404
|
+
this.isEditingEmail = false;
|
|
405
|
+
});
|
|
406
|
+
}
|
|
407
|
+
saveStreet() {
|
|
408
|
+
this.adminService
|
|
409
|
+
.updateDomainConfig(this.appConfig?.domain_id, {
|
|
410
|
+
company_address: this.editingStreet,
|
|
411
|
+
subscription_id: this.id
|
|
412
|
+
})
|
|
413
|
+
.subscribe(() => {
|
|
414
|
+
this.toast.success('Street updated');
|
|
415
|
+
this.street = this.editingStreet;
|
|
416
|
+
this.isEditingStreet = false;
|
|
417
|
+
});
|
|
418
|
+
}
|
|
419
|
+
cancelStreet() {
|
|
420
|
+
this.editingStreet = this.street;
|
|
421
|
+
this.isEditingStreet = false;
|
|
422
|
+
}
|
|
423
|
+
openHubspotEditModal(footerItem) {
|
|
424
|
+
this.editingHubspotHtml = footerItem.div;
|
|
425
|
+
this.editingHubspotId = footerItem.id;
|
|
426
|
+
this.modalService.open(this.hubspotEditModal, { centered: true, size: 'lg' });
|
|
427
|
+
}
|
|
428
|
+
saveHubspotHtml(modal) {
|
|
429
|
+
const updatedConfig = {
|
|
430
|
+
contact_us: {
|
|
431
|
+
...this.appConfig?.pages_config?.contact_us,
|
|
432
|
+
hubspot: [
|
|
433
|
+
{
|
|
434
|
+
id: '7423639',
|
|
435
|
+
position: 'footer',
|
|
436
|
+
div: this.editingHubspotHtml
|
|
437
|
+
}
|
|
438
|
+
]
|
|
439
|
+
},
|
|
440
|
+
subscription_id: this.id
|
|
441
|
+
};
|
|
442
|
+
this.adminService
|
|
443
|
+
.updateDomainConfig(this.appConfig?.domain_id, updatedConfig)
|
|
444
|
+
.subscribe(() => {
|
|
445
|
+
// NOSONAR: Trusted HTML content is handled safely here
|
|
446
|
+
this.hubspotHtml = this.sanitizer.bypassSecurityTrustHtml(this.editingHubspotHtml); // NOSONAR
|
|
447
|
+
this.toast.success('Hubspot Embed updated');
|
|
448
|
+
modal.close();
|
|
449
|
+
});
|
|
450
|
+
}
|
|
451
|
+
updateCanEditResourcesValue() {
|
|
452
|
+
this.canEditResourcesValue = HelperService.canEditResources(this.user, this.userLoggedIn, this.permissionService);
|
|
453
|
+
}
|
|
454
|
+
canEditResources() {
|
|
455
|
+
return this.canEditResourcesValue;
|
|
456
|
+
}
|
|
457
|
+
ngOnDestroy() {
|
|
458
|
+
this.observer?.disconnect();
|
|
459
|
+
}
|
|
460
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: Trial4ContactUsComponent, deps: [{ token: i1.UntypedFormBuilder }, { token: i2.AuthService }, { token: i3.CrmService }, { token: i4.DomSanitizer }, { token: i5.AdminService }, { token: i0.Injector }, { token: i2.AbTestService }, { token: i6.NgbModal }, { token: i0.ChangeDetectorRef }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
461
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: Trial4ContactUsComponent, selector: "pw-trial-4-contact-us", inputs: { subscriptionId: "subscriptionId", sourceId: "sourceId", masterSubscriptionId: "masterSubscriptionId", experimentName: "experimentName", microserviceName: "microserviceName", shardName: "shardName", user: "user", userLoggedIn: "userLoggedIn" }, viewQueries: [{ propertyName: "footerSection", first: true, predicate: ["footerSection"], descendants: true, static: true }, { propertyName: "content", first: true, predicate: ["bookMeeting"], descendants: true, static: true }, { propertyName: "editFooterLinksModal", first: true, predicate: ["editFooterLinksModal"], descendants: true }, { propertyName: "logoModal", first: true, predicate: ["logoModal"], descendants: true }, { propertyName: "logoUploader", first: true, predicate: ["logoUploader"], descendants: true }, { propertyName: "hubspotEditModal", first: true, predicate: ["hubspotEditModal"], descendants: true }, { propertyName: "socialEditModal", first: true, predicate: ["socialEditModal"], descendants: true }, { propertyName: "questionsEditModal", first: true, predicate: ["questionsEditModal"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<section #footerSection class=\"bg-black text-white py-5 footer-section\">\n <div class=\"container\" *ngIf=\"isFooterVisible\">\n <div class=\"row\">\n\n <!-- LEFT COLUMN -->\n <div class=\"col-md-6 mb-4 d-flex flex-column justify-content-between\" [ngClass]=\"{ 'site-column': getFooterHubspotForm() }\">\n <div>\n <h3 class=\"mb-4 d-flex align-items-center\">\n <span class=\"me-2 text-white\">Site Map:</span>\n <i *ngIf=\"canEditResourcesValue\" class=\"fa fa-edit in-page-edit-icon cursor-pointer text-white ms-3\" (click)=\"openEditFooterLinksModal(editFooterLinksModal)\" (keydown.enter)=\"openEditFooterLinksModal(editFooterLinksModal)\" (keydown.space)=\"openEditFooterLinksModal(editFooterLinksModal)\" ngbTooltip=\"Edit Footer Links\"></i>\n </h3>\n <ul class=\"mt-4\">\n <li routerLink=\"/\"\n class=\"cursor-pointer user-info-label link-label\"> Home </li>\n <li *ngFor=\"let link of footerLinks\" [routerLink]=\"link?.path\"\n class=\"cursor-pointer user-info-label link-label mt-4\"><span *ngIf=\"link?.title\">{{link?.title}}</span> </li>\n <li routerLink=\"/login\"\n class=\"cursor-pointer user-info-label mt-4 link-label\"> Log in </li>\n <li [routerLink]=\"'/privacy-and-tos/' + tosId\"\n class=\"cursor-pointer user-info-label mt-4 link-label\"> Privacy statement </li>\n </ul>\n <p class=\"address-section email-section mb-4\">\n <span class=\"user-info-label\">Email: </span>\n <ng-container *ngIf=\"!isEditingEmail; else editEmail\">\n <span class=\"user-info\">{{ email }}</span>\n <i *ngIf=\"canEditResourcesValue\" class=\"fa fa-edit in-page-edit-icon text-white cursor-pointer ms-3\" (click)=\"isEditingEmail = true\" (keydown.enter)=\"isEditingEmail = true\" (keydown.space)=\"isEditingEmail = true\"></i>\n </ng-container>\n\n <ng-template #editEmail>\n <input\n class=\"form-control d-inline w-auto\"\n [(ngModel)]=\"editingEmail\"\n />\n <button class=\"btn btn-sm btn-primary ms-2\" (click)=\"saveEmail()\">Save</button>\n <button class=\"btn btn-sm btn-secondary ms-2\" (click)=\"isEditingEmail = false\">Cancel</button>\n </ng-template>\n </p>\n <span class=\"email-section mt-3 address-text\">\n <span class=\"user-info-label\">\n Address:\n <i *ngIf=\"canEditResourcesValue\"\n class=\"fa fa-edit in-page-edit-icon cursor-pointer ms-2 text-white\"\n title=\"Edit Address\"\n (click)=\"isEditingStreet = true\"\n (keydown.enter)=\"isEditingStreet = true\"\n (keydown.space)=\"isEditingStreet = true\"></i>\n </span><br/>\n\n <ng-container *ngIf=\"!isEditingStreet; else editStreetBlock\">\n <span class=\"address-text user-info\">{{ street }}</span>\n </ng-container>\n\n <ng-template #editStreetBlock>\n <div class=\"d-flex align-items-center mt-3\">\n <input class=\"form-control form-control-sm\" [(ngModel)]=\"editingStreet\" />\n <button class=\"btn btn-sm btn-primary ms-2\" (click)=\"saveStreet()\">Save</button>\n <button class=\"btn btn-sm btn-secondary ms-2\" (click)=\"cancelStreet()\">Cancel</button>\n </div>\n </ng-template>\n\n </span>\n\n </div>\n <div class=\"d-flex\">\n <img [src]=\"logo\"\n alt=\"Company logo\"\n class=\"img-fluid mt-4 logo-image cursor-pointer\"\n width=\"160\"\n height=\"35\"\n (click)=\"scrollToTop()\"\n (keydown.enter)=\"scrollToTop()\"\n (keydown.space)=\"scrollToTop()\"\n title=\"Click to go to top of page\" />\n <i *ngIf=\"canEditResourcesValue\"\n class=\"fa fa-edit in-page-edit-icon fa-sm ms-3 cursor-pointer text-white align-self-center mt-3\"\n (click)=\"openLogoEditModal()\"\n (keydown.enter)=\"openLogoEditModal()\"\n (keydown.space)=\"openLogoEditModal()\"\n title=\"Edit Logo\"></i>\n </div>\n </div>\n\n <!-- RIGHT COLUMN -->\n <div class=\"col-md-6\" *ngIf=\"isFooterVisible\">\n <ng-container *ngIf=\"getFooterHubspotForm() as footerItem; else defaultForm\">\n <div class=\"d-flex\">\n <div\n *ngIf=\"isHubspotReady\"\n class=\"hubspot-container w-100 content-loaded\"\n [innerHTML]=\"hubspotHtml\"\n (load)=\"onHubspotLoad($event)\">\n </div>\n <i *ngIf=\"canEditResourcesValue\"\n class=\"fa fa-edit in-page-edit-icon text-white cursor-pointer\"\n (click)=\"openHubspotEditModal(footerItem)\"\n (keydown.enter)=\"openHubspotEditModal(footerItem)\"\n (keydown.space)=\"openHubspotEditModal(footerItem)\"\n title=\"Edit Hubspot Embed\"></i>\n </div>\n </ng-container>\n\n <ng-template #defaultForm>\n <div class=\"d-flex\">\n <h3 class=\"text-white mb-4\"> <span class=\"text-white\">Get in touch:</span></h3>\n <i *ngIf=\"canEditResourcesValue\"\n class=\"fa fa-edit in-page-edit-icon text-white cursor-pointer ms-3 mt-2\"\n (click)=\"openQuestionsEditModal()\"\n (keydown.enter)=\"openQuestionsEditModal()\"\n (keydown.space)=\"openQuestionsEditModal()\"\n title=\"Edit Questions\"></i>\n </div>\n <div class=\"contact-form\">\n <form [formGroup]=\"form\">\n <div class=\"mb-3\">\n <div class=\"email\">\n <div class=\"form-field\">\n <label for=\"email\">Email:</label>\n <div class=\"w-100\">\n <input type=\"text\"\n class=\"mb-1\"\n id=\"email\"\n formControlName=\"email\" />\n <pw-field-error-display [displayError]=\"\n !form.get('email').valid && (form.get('email').touched || submitted)\n \"\n errorMsg=\"Email is required\">\n </pw-field-error-display>\n </div>\n </div>\n <div class=\"form-field\">\n <label for=\"first_name\">First name:</label>\n <div class=\"w-100\">\n <input input type=\"text\"\n id=\"first_name\"\n formControlName=\"first_name\" />\n <pw-field-error-display [displayError]=\"\n !form.get('first_name').valid && (form.get('first_name').touched || submitted)\n \"\n errorMsg=\"First name is required\">\n </pw-field-error-display>\n </div>\n </div>\n <div class=\"form-field\">\n <label for=\"last_name\">Last name:</label>\n <input type=\"text\"\n id=\"last_name\"\n formControlName=\"last_name\" />\n </div>\n <div class=\"form-field\">\n <label for=\"company\">Company:</label>\n <input type=\"text\"\n id=\"company\"\n formControlName=\"company\" />\n </div>\n <div class=\"form-field\" *ngIf=\"hasValidOptions()\">\n <label for=\"psa\" class=\"select-label\">{{question}}</label>\n <p-dropdown\n formControlName=\"psa\"\n [options]=\"psaOptions\"\n [placeholder]=\"'Select PSA'\"\n styleClass=\"input-select\">\n </p-dropdown>\n </div>\n <div class=\"form-field\">\n <label for=\"enquiry\" class=\"select-label\">How can we help you?</label>\n <div class=\"enquiry-field\">\n <textarea id=\"enquiry\" formControlName=\"enquiry\" class=\"\">\n </textarea>\n <pw-field-error-display [displayError]=\"\n !form.get('enquiry').valid && (form.get('enquiry').touched || submitted)\n \"\n errorMsg=\"Enquiry is required\">\n </pw-field-error-display>\n </div>\n </div>\n </div>\n </div>\n <div class=\"text-end\">\n <div class=\"captcha-wrapper-container\"\n *ngIf=\"isCaptchaVerified\">\n <ngx-recaptcha2 [ngModelOptions]=\"{ standalone: true }\"\n [siteKey]=\"captchaKeyV2\"\n size=\"normal\"\n [(ngModel)]=\"recaptcha\"\n (success)=\"handleSuccess($event)\">\n </ngx-recaptcha2>\n </div>\n <button type=\"submit\"\n (click)=\"onSubmit()\"\n *ngIf=\"!isCaptchaVerified\"\n class=\"sign-btn sign-header-btn mt-3\">\n {{ 'Button.Submit' | transloco }}\n </button>\n </div>\n\n <div class=\"d-flex align-items-center mt-4\">\n <div class=\"icons d-flex align-items-center\">\n <a [eventTracker]=\"{\n category: 'youtube',\n action: 'click',\n label: 'cloudolive-landing-page-b',\n value: 1\n }\"\n [href]=\"youtubeUrl\"\n target=\"_blank\"\n rel=\"noopener noreferrer\">\n <img src=\"/assets/img/icons/youtube.png\"\n class=\"img-fluid youtube-icon\"\n width=\"54\"\n height=\"54\"\n alt=\"\" />\n </a>\n <a [eventTracker]=\"{\n category: 'linkedin',\n action: 'click',\n label: 'cloudolive-landing-page-b',\n value: 1\n }\"\n [href]=\"linkedInUrl\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n class=\"ms-3\">\n <img src=\"/assets/img/icons/social/linkedin.svg\"\n class=\"img-fluid linkedin-icon\"\n width=\"48\"\n height=\"48\"\n alt=\"\" />\n </a>\n <i *ngIf=\"canEditResourcesValue\"\n class=\"fa fa-edit in-page-edit-icon text-white cursor-pointer ms-3\"\n (click)=\"openSocialEditModal()\"\n (keydown.enter)=\"openSocialEditModal()\"\n (keydown.space)=\"openSocialEditModal()\"\n title=\"Edit Social Links & Company Name\"></i>\n </div>\n <div class=\"copyright text-white\">\n 2025 {{companyName}}.\n </div>\n </div>\n </form>\n </div>\n </ng-template>\n </div>\n </div>\n </div>\n</section>\n\n\n\n<ng-template #bookMeeting\n let-modal>\n <div class=\"modal-header\">\n <button type=\"button\"\n class=\"btn-close float-end\"\n aria-label=\"Close\"\n (click)=\"modal.dismiss()\">\n </button>\n </div>\n <div class=\"modal-body\">\n <h3 class=\"text-center modal-basic-title\">\n Thanks for getting in touch! Our team will be in contact shortly, or we\n can compare calendars now & schedule a time\n </h3>\n <button type=\"button\"\n [eventTracker]=\"{\n category: 'request-demo',\n action: 'click',\n label: 'cloudolive-landing-page-b',\n value: 1\n }\"\n (click)=\"navigateToBookMeeting()\"\n class=\"sign-btn sign-header-btn mx-auto d-block mb-3\">\n Let's do it\n </button>\n </div>\n</ng-template>\n\n\n<ng-template #editFooterLinksModal let-modal>\n <div class=\"modal-header\">\n <h5 class=\"modal-title\">Edit Footer Links</h5>\n <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n </div>\n\n <div class=\"modal-body\">\n <h4 class=\"mb-3\">Footer Links Section</h4>\n <div cdkDropList (cdkDropListDropped)=\"dropFooterLinks($event)\">\n <div *ngFor=\"let footer of editingFooterLinks.items; let i = index\" class=\"border p-3 mb-3\" cdkDrag>\n <div class=\"row\">\n <div class=\"col-md-5 mb-2\">\n <label for=\"footerTitle{{i}}\" class=\"form-label\">Title</label>\n <input id=\"footerTitle{{i}}\" class=\"form-control\" [(ngModel)]=\"footer.title\" />\n </div>\n <div class=\"col-md-5 mb-2\">\n <label for=\"footerPath{{i}}\" class=\"form-label\">Path</label>\n <input id=\"footerPath{{i}}\" class=\"form-control\" [(ngModel)]=\"footer.path\" />\n </div>\n <div class=\"col-md-2 d-flex justify-content-between align-items-center mt-4\">\n <i class=\"fa fa-trash in-page-trash-icon text-danger cursor-pointer\" (click)=\"removeFooterLink(i)\" (keydown.enter)=\"removeFooterLink(i)\" (keydown.space)=\"removeFooterLink(i)\"></i>\n <i class=\"fa fa-bars in-page-bars-icon cursor-move\" cdkDragHandle></i>\n </div>\n </div>\n\n <!-- Subtitles -->\n <div cdkDropList (cdkDropListDropped)=\"dropSubtitles(i, $event)\">\n <div *ngFor=\"let sub of footer.subtitles; let j = index\" class=\"row border p-3 mb-2 align-items-center\" cdkDrag>\n <div class=\"col-md-5\">\n <label for=\"subtitleTitle{{i}}{{j}}\" class=\"form-label\">Subtitle Title</label>\n <input id=\"subtitleTitle{{i}}{{j}}\" class=\"form-control\" [(ngModel)]=\"sub.title\" />\n </div>\n <div class=\"col-md-5\">\n <label for=\"subtitlePath{{i}}{{j}}\" class=\"form-label\">Subtitle Path</label>\n <input id=\"subtitlePath{{i}}{{j}}\" class=\"form-control\" [(ngModel)]=\"sub.path\" />\n </div>\n <div class=\"col-md-2 d-flex justify-content-between align-items-center mt-4\">\n <i class=\"fa fa-trash in-page-trash-icon text-danger cursor-pointer\" (click)=\"removeSubtitle(i, j)\" (keydown.enter)=\"removeSubtitle(i, j)\" (keydown.space)=\"removeSubtitle(i, j)\"></i>\n <i class=\"fa fa-bars cursor-move in-page-bars-icon\" cdkDragHandle></i>\n </div>\n </div>\n </div>\n\n <button class=\"btn btn-outline-primary btn-sm mt-2\" (click)=\"addSubtitle(i)\">\n + Add Subtitle\n </button>\n </div>\n </div>\n\n <button class=\"btn btn-primary mt-3\" (click)=\"addFooterLink()\">\n + Add Footer Link\n </button>\n </div>\n\n <div class=\"modal-footer\">\n <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n <button class=\"btn btn-primary\" (click)=\"saveFooterLinks(modal)\">Save</button>\n </div>\n</ng-template>\n\n\n\n\n\n<ng-template #logoModal let-modal>\n <div class=\"modal-header\">\n <h5 class=\"modal-title\">Upload Logo</h5>\n <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n </div>\n <div class=\"modal-body\">\n <pw-custom-uploader\n [aspectRatio]=\"'fullLogo'\"\n [title]=\"'Main Contrast Logo'\"\n [controlName]=\"'logo_main_contrast'\"\n [previewData]=\"previewData\"\n (saveEvent)=\"onSaveFile($event)\">\n </pw-custom-uploader>\n </div>\n</ng-template>\n\n\n\n<ng-template #hubspotEditModal let-modal>\n <div class=\"modal-header\">\n <h5 class=\"modal-title\">Edit Hubspot Embed</h5>\n <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n </div>\n <div class=\"modal-body\">\n <div class=\"mb-3\">\n <label for=\"hubspotId\" class=\"form-label\">Hubspot ID</label>\n <input id=\"hubspotId\" [(ngModel)]=\"editingHubspotId\" class=\"form-control\" />\n </div>\n <div class=\"mb-3\">\n <label for=\"hubspotEmbedDiv\" class=\"form-label\">Embed DIV</label>\n <textarea id=\"hubspotEmbedDiv\" [(ngModel)]=\"editingHubspotHtml\" rows=\"8\" class=\"form-control\"></textarea>\n </div>\n </div>\n <div class=\"modal-footer\">\n <button class=\"btn btn-primary\" (click)=\"saveHubspotHtml(modal)\">Save</button>\n <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n </div>\n</ng-template>\n\n\n<ng-template #socialEditModal let-modal>\n <div class=\"modal-header\">\n <h5 class=\"modal-title\">Edit Social Links & Company Name</h5>\n <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n </div>\n <div class=\"modal-body\">\n <div class=\"mb-3\">\n <label for=\"youtubeUrl\" class=\"form-label\">YouTube URL</label>\n <input id=\"youtubeUrl\" [(ngModel)]=\"editingYoutubeUrl\" class=\"form-control\" />\n </div>\n <div class=\"mb-3\">\n <label for=\"linkedinUrl\" class=\"form-label\">LinkedIn URL</label>\n <input id=\"linkedinUrl\" [(ngModel)]=\"editingLinkedInUrl\" class=\"form-control\" />\n </div>\n <div class=\"mb-3\">\n <label for=\"companyName\" class=\"form-label\">Company Name</label>\n <input id=\"companyName\" [(ngModel)]=\"editingCompanyName\" class=\"form-control\" />\n </div>\n </div>\n <div class=\"modal-footer\">\n <button class=\"btn btn-primary\" (click)=\"saveSocialLinks(modal)\">Save</button>\n <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n </div>\n</ng-template>\n\n\n\n<ng-template #questionsEditModal let-modal>\n <div class=\"modal-header\">\n <h5 class=\"modal-title\">Edit Questions</h5>\n <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n </div>\n\n <div class=\"modal-body\">\n <h4 class=\"mb-3\">Questions Section</h4>\n <div cdkDropList (cdkDropListDropped)=\"dropQuestions($event)\">\n <div *ngFor=\"let q of editingQuestions; let i = index\" class=\"border p-3 mb-3\" cdkDrag>\n <div class=\"row\">\n <div class=\"col-md-11 mb-2\">\n <label for=\"questionText{{i}}\" class=\"form-label\">Question</label>\n <input id=\"questionText{{i}}\" class=\"form-control\" [(ngModel)]=\"q.question\" placeholder=\"Enter question\" />\n </div>\n <div class=\"col-md-1 d-flex justify-content-end align-items-start mt-4\">\n <i class=\"fa fa-bars in-page-bars-icon cursor-move\" cdkDragHandle></i>\n </div>\n </div>\n\n <!-- Options Section -->\n <div cdkDropList (cdkDropListDropped)=\"dropQuestionOptions(i, $event)\">\n <div *ngFor=\"let opt of q.options; let j = index\" class=\"row border p-3 mb-2 align-items-center\" cdkDrag>\n <div class=\"col-md-7 mb-2\">\n <label for=\"questionOption{{i}}{{j}}\" class=\"form-label\">Option</label>\n <input id=\"questionOption{{i}}{{j}}\" class=\"form-control\" [(ngModel)]=\"opt.option\" placeholder=\"Enter option\" />\n </div>\n <div class=\"col-md-2 d-flex justify-content-between align-items-center mt-4\">\n <i class=\"fa fa-trash in-page-trash-icon text-danger cursor-pointer\" (click)=\"removeQuestionOption(i, j)\" (keydown.enter)=\"removeQuestionOption(i, j)\" (keydown.enter)=\"removeQuestionOption(i, j)\"></i>\n <i class=\"fa fa-bars in-page-bars-icon cursor-move\" cdkDragHandle></i>\n </div>\n </div>\n </div>\n\n <button class=\"btn btn-outline-primary btn-sm mt-2\" (click)=\"addQuestionOption(i)\">+ Add Option</button>\n </div>\n </div>\n\n <button class=\"btn btn-primary mt-3\" (click)=\"addNewQuestion()\">+ Add Question</button>\n </div>\n\n <div class=\"modal-footer\">\n <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n <button class=\"btn btn-primary\" (click)=\"saveQuestions(modal)\">Save</button>\n </div>\n</ng-template>\n\n\n\n", styles: [".product-explainer-section{background-color:#000}.footer-section input.form-control,.footer-section select.form-control,.footer-section textarea.form-control{background-color:#fff;border:none;color:#000;font-size:14px}.btn-primary{background-color:#007bff;border:none}.site-column{margin-top:2.9rem}.email-section{color:#fff;font-size:2rem}.address-section{margin-top:5rem}.address-text{line-height:2.2rem}.user-info{font-size:1.5rem}.user-info-label{font-size:1.7rem;font-weight:700}.contact-form form .form-field{display:flex;align-items:center;margin-bottom:1.2rem}.contact-form form .form-field label{width:130px;min-width:130px;margin:0;font-size:14px;color:#fff;font-weight:600;text-transform:uppercase;letter-spacing:1px}.contact-form form .form-field p-dropdown{width:100%}.contact-form form .form-field input,.contact-form form .form-field select,.contact-form form .form-field textarea,.contact-form form .form-field ::ng-deep p-dropdown .p-inputwrapper{flex:1;border:none;border-radius:30px;padding:12px 20px;font-size:14px;width:100%!important;max-width:100%;color:#000}.contact-form form .form-field textarea{resize:vertical}.contact-form form .submit-button{background-color:#3b82f6;border:none;border-radius:30px;font-size:16px;font-weight:500;padding:10px 24px;margin-top:1.2rem}.input-select{height:43px}.select-label{width:210px!important}.copyright{margin-top:2rem;margin-left:4rem;font-size:19px;font-weight:700}.d-flex img{margin-right:0!important}.youtube-icon{height:38px}.enquiry-field{margin-left:.5rem;width:63%}::ng-deep .text-danger{margin-top:.25rem!important;margin-left:.5rem!important}@media (min-width: 768px){.hubspot-container{margin-top:-3rem}}@media (min-width: 768px) and (max-width: 1200px){.container{padding:0rem 6rem!important}}.link-label{cursor:pointer;transition:color .3s}.link-label:hover{color:var(--first)}.icons img{transition:transform .3s ease,filter .3s ease;cursor:pointer}.icons img:hover{transform:scale(1.1);filter:brightness(1.2)}.logo-image{max-width:160px;width:160px;height:35px;object-fit:contain;aspect-ratio:160/35}\n"], dependencies: [{ kind: "directive", type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.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: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i8.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i9.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i9.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i9.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "directive", type: i6.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "popperOptions", "triggers", "positionTarget", "container", "disableTooltip", "tooltipClass", "tooltipContext", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { kind: "directive", type: i10.EventTrackerDirective, selector: "[eventTracker]", inputs: ["eventTracker"] }, { kind: "directive", type: i10.LazyImgDirective, selector: "img" }, { kind: "component", type: i11.ReCaptcha2Component, selector: "ngx-recaptcha2", inputs: ["theme", "size"] }, { kind: "component", type: i12.Dropdown, selector: "p-dropdown", inputs: ["id", "scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "loadingIcon", "filterPlaceholder", "filterLocale", "variant", "inputId", "dataKey", "filterBy", "filterFields", "autofocus", "resetFilterOnHide", "checkmark", "dropdownIcon", "loading", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "focusOnHover", "selectOnFocus", "autoOptionFocus", "autofocusFilter", "disabled", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "filterValue", "options"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "component", type: i13.CustomUploaderComponent, selector: "pw-custom-uploader", inputs: ["controlName", "previewData", "aspectRatio", "title"], outputs: ["saveEvent"] }, { kind: "component", type: i13.FieldErrorDisplayComponent, selector: "pw-field-error-display", inputs: ["errorMsg", "displayError"] }, { kind: "pipe", type: i14.TranslocoPipe, name: "transloco" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
462
|
+
}
|
|
463
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: Trial4ContactUsComponent, decorators: [{
|
|
464
|
+
type: Component,
|
|
465
|
+
args: [{ selector: 'pw-trial-4-contact-us', changeDetection: ChangeDetectionStrategy.OnPush, template: "<section #footerSection class=\"bg-black text-white py-5 footer-section\">\n <div class=\"container\" *ngIf=\"isFooterVisible\">\n <div class=\"row\">\n\n <!-- LEFT COLUMN -->\n <div class=\"col-md-6 mb-4 d-flex flex-column justify-content-between\" [ngClass]=\"{ 'site-column': getFooterHubspotForm() }\">\n <div>\n <h3 class=\"mb-4 d-flex align-items-center\">\n <span class=\"me-2 text-white\">Site Map:</span>\n <i *ngIf=\"canEditResourcesValue\" class=\"fa fa-edit in-page-edit-icon cursor-pointer text-white ms-3\" (click)=\"openEditFooterLinksModal(editFooterLinksModal)\" (keydown.enter)=\"openEditFooterLinksModal(editFooterLinksModal)\" (keydown.space)=\"openEditFooterLinksModal(editFooterLinksModal)\" ngbTooltip=\"Edit Footer Links\"></i>\n </h3>\n <ul class=\"mt-4\">\n <li routerLink=\"/\"\n class=\"cursor-pointer user-info-label link-label\"> Home </li>\n <li *ngFor=\"let link of footerLinks\" [routerLink]=\"link?.path\"\n class=\"cursor-pointer user-info-label link-label mt-4\"><span *ngIf=\"link?.title\">{{link?.title}}</span> </li>\n <li routerLink=\"/login\"\n class=\"cursor-pointer user-info-label mt-4 link-label\"> Log in </li>\n <li [routerLink]=\"'/privacy-and-tos/' + tosId\"\n class=\"cursor-pointer user-info-label mt-4 link-label\"> Privacy statement </li>\n </ul>\n <p class=\"address-section email-section mb-4\">\n <span class=\"user-info-label\">Email: </span>\n <ng-container *ngIf=\"!isEditingEmail; else editEmail\">\n <span class=\"user-info\">{{ email }}</span>\n <i *ngIf=\"canEditResourcesValue\" class=\"fa fa-edit in-page-edit-icon text-white cursor-pointer ms-3\" (click)=\"isEditingEmail = true\" (keydown.enter)=\"isEditingEmail = true\" (keydown.space)=\"isEditingEmail = true\"></i>\n </ng-container>\n\n <ng-template #editEmail>\n <input\n class=\"form-control d-inline w-auto\"\n [(ngModel)]=\"editingEmail\"\n />\n <button class=\"btn btn-sm btn-primary ms-2\" (click)=\"saveEmail()\">Save</button>\n <button class=\"btn btn-sm btn-secondary ms-2\" (click)=\"isEditingEmail = false\">Cancel</button>\n </ng-template>\n </p>\n <span class=\"email-section mt-3 address-text\">\n <span class=\"user-info-label\">\n Address:\n <i *ngIf=\"canEditResourcesValue\"\n class=\"fa fa-edit in-page-edit-icon cursor-pointer ms-2 text-white\"\n title=\"Edit Address\"\n (click)=\"isEditingStreet = true\"\n (keydown.enter)=\"isEditingStreet = true\"\n (keydown.space)=\"isEditingStreet = true\"></i>\n </span><br/>\n\n <ng-container *ngIf=\"!isEditingStreet; else editStreetBlock\">\n <span class=\"address-text user-info\">{{ street }}</span>\n </ng-container>\n\n <ng-template #editStreetBlock>\n <div class=\"d-flex align-items-center mt-3\">\n <input class=\"form-control form-control-sm\" [(ngModel)]=\"editingStreet\" />\n <button class=\"btn btn-sm btn-primary ms-2\" (click)=\"saveStreet()\">Save</button>\n <button class=\"btn btn-sm btn-secondary ms-2\" (click)=\"cancelStreet()\">Cancel</button>\n </div>\n </ng-template>\n\n </span>\n\n </div>\n <div class=\"d-flex\">\n <img [src]=\"logo\"\n alt=\"Company logo\"\n class=\"img-fluid mt-4 logo-image cursor-pointer\"\n width=\"160\"\n height=\"35\"\n (click)=\"scrollToTop()\"\n (keydown.enter)=\"scrollToTop()\"\n (keydown.space)=\"scrollToTop()\"\n title=\"Click to go to top of page\" />\n <i *ngIf=\"canEditResourcesValue\"\n class=\"fa fa-edit in-page-edit-icon fa-sm ms-3 cursor-pointer text-white align-self-center mt-3\"\n (click)=\"openLogoEditModal()\"\n (keydown.enter)=\"openLogoEditModal()\"\n (keydown.space)=\"openLogoEditModal()\"\n title=\"Edit Logo\"></i>\n </div>\n </div>\n\n <!-- RIGHT COLUMN -->\n <div class=\"col-md-6\" *ngIf=\"isFooterVisible\">\n <ng-container *ngIf=\"getFooterHubspotForm() as footerItem; else defaultForm\">\n <div class=\"d-flex\">\n <div\n *ngIf=\"isHubspotReady\"\n class=\"hubspot-container w-100 content-loaded\"\n [innerHTML]=\"hubspotHtml\"\n (load)=\"onHubspotLoad($event)\">\n </div>\n <i *ngIf=\"canEditResourcesValue\"\n class=\"fa fa-edit in-page-edit-icon text-white cursor-pointer\"\n (click)=\"openHubspotEditModal(footerItem)\"\n (keydown.enter)=\"openHubspotEditModal(footerItem)\"\n (keydown.space)=\"openHubspotEditModal(footerItem)\"\n title=\"Edit Hubspot Embed\"></i>\n </div>\n </ng-container>\n\n <ng-template #defaultForm>\n <div class=\"d-flex\">\n <h3 class=\"text-white mb-4\"> <span class=\"text-white\">Get in touch:</span></h3>\n <i *ngIf=\"canEditResourcesValue\"\n class=\"fa fa-edit in-page-edit-icon text-white cursor-pointer ms-3 mt-2\"\n (click)=\"openQuestionsEditModal()\"\n (keydown.enter)=\"openQuestionsEditModal()\"\n (keydown.space)=\"openQuestionsEditModal()\"\n title=\"Edit Questions\"></i>\n </div>\n <div class=\"contact-form\">\n <form [formGroup]=\"form\">\n <div class=\"mb-3\">\n <div class=\"email\">\n <div class=\"form-field\">\n <label for=\"email\">Email:</label>\n <div class=\"w-100\">\n <input type=\"text\"\n class=\"mb-1\"\n id=\"email\"\n formControlName=\"email\" />\n <pw-field-error-display [displayError]=\"\n !form.get('email').valid && (form.get('email').touched || submitted)\n \"\n errorMsg=\"Email is required\">\n </pw-field-error-display>\n </div>\n </div>\n <div class=\"form-field\">\n <label for=\"first_name\">First name:</label>\n <div class=\"w-100\">\n <input input type=\"text\"\n id=\"first_name\"\n formControlName=\"first_name\" />\n <pw-field-error-display [displayError]=\"\n !form.get('first_name').valid && (form.get('first_name').touched || submitted)\n \"\n errorMsg=\"First name is required\">\n </pw-field-error-display>\n </div>\n </div>\n <div class=\"form-field\">\n <label for=\"last_name\">Last name:</label>\n <input type=\"text\"\n id=\"last_name\"\n formControlName=\"last_name\" />\n </div>\n <div class=\"form-field\">\n <label for=\"company\">Company:</label>\n <input type=\"text\"\n id=\"company\"\n formControlName=\"company\" />\n </div>\n <div class=\"form-field\" *ngIf=\"hasValidOptions()\">\n <label for=\"psa\" class=\"select-label\">{{question}}</label>\n <p-dropdown\n formControlName=\"psa\"\n [options]=\"psaOptions\"\n [placeholder]=\"'Select PSA'\"\n styleClass=\"input-select\">\n </p-dropdown>\n </div>\n <div class=\"form-field\">\n <label for=\"enquiry\" class=\"select-label\">How can we help you?</label>\n <div class=\"enquiry-field\">\n <textarea id=\"enquiry\" formControlName=\"enquiry\" class=\"\">\n </textarea>\n <pw-field-error-display [displayError]=\"\n !form.get('enquiry').valid && (form.get('enquiry').touched || submitted)\n \"\n errorMsg=\"Enquiry is required\">\n </pw-field-error-display>\n </div>\n </div>\n </div>\n </div>\n <div class=\"text-end\">\n <div class=\"captcha-wrapper-container\"\n *ngIf=\"isCaptchaVerified\">\n <ngx-recaptcha2 [ngModelOptions]=\"{ standalone: true }\"\n [siteKey]=\"captchaKeyV2\"\n size=\"normal\"\n [(ngModel)]=\"recaptcha\"\n (success)=\"handleSuccess($event)\">\n </ngx-recaptcha2>\n </div>\n <button type=\"submit\"\n (click)=\"onSubmit()\"\n *ngIf=\"!isCaptchaVerified\"\n class=\"sign-btn sign-header-btn mt-3\">\n {{ 'Button.Submit' | transloco }}\n </button>\n </div>\n\n <div class=\"d-flex align-items-center mt-4\">\n <div class=\"icons d-flex align-items-center\">\n <a [eventTracker]=\"{\n category: 'youtube',\n action: 'click',\n label: 'cloudolive-landing-page-b',\n value: 1\n }\"\n [href]=\"youtubeUrl\"\n target=\"_blank\"\n rel=\"noopener noreferrer\">\n <img src=\"/assets/img/icons/youtube.png\"\n class=\"img-fluid youtube-icon\"\n width=\"54\"\n height=\"54\"\n alt=\"\" />\n </a>\n <a [eventTracker]=\"{\n category: 'linkedin',\n action: 'click',\n label: 'cloudolive-landing-page-b',\n value: 1\n }\"\n [href]=\"linkedInUrl\"\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n class=\"ms-3\">\n <img src=\"/assets/img/icons/social/linkedin.svg\"\n class=\"img-fluid linkedin-icon\"\n width=\"48\"\n height=\"48\"\n alt=\"\" />\n </a>\n <i *ngIf=\"canEditResourcesValue\"\n class=\"fa fa-edit in-page-edit-icon text-white cursor-pointer ms-3\"\n (click)=\"openSocialEditModal()\"\n (keydown.enter)=\"openSocialEditModal()\"\n (keydown.space)=\"openSocialEditModal()\"\n title=\"Edit Social Links & Company Name\"></i>\n </div>\n <div class=\"copyright text-white\">\n 2025 {{companyName}}.\n </div>\n </div>\n </form>\n </div>\n </ng-template>\n </div>\n </div>\n </div>\n</section>\n\n\n\n<ng-template #bookMeeting\n let-modal>\n <div class=\"modal-header\">\n <button type=\"button\"\n class=\"btn-close float-end\"\n aria-label=\"Close\"\n (click)=\"modal.dismiss()\">\n </button>\n </div>\n <div class=\"modal-body\">\n <h3 class=\"text-center modal-basic-title\">\n Thanks for getting in touch! Our team will be in contact shortly, or we\n can compare calendars now & schedule a time\n </h3>\n <button type=\"button\"\n [eventTracker]=\"{\n category: 'request-demo',\n action: 'click',\n label: 'cloudolive-landing-page-b',\n value: 1\n }\"\n (click)=\"navigateToBookMeeting()\"\n class=\"sign-btn sign-header-btn mx-auto d-block mb-3\">\n Let's do it\n </button>\n </div>\n</ng-template>\n\n\n<ng-template #editFooterLinksModal let-modal>\n <div class=\"modal-header\">\n <h5 class=\"modal-title\">Edit Footer Links</h5>\n <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n </div>\n\n <div class=\"modal-body\">\n <h4 class=\"mb-3\">Footer Links Section</h4>\n <div cdkDropList (cdkDropListDropped)=\"dropFooterLinks($event)\">\n <div *ngFor=\"let footer of editingFooterLinks.items; let i = index\" class=\"border p-3 mb-3\" cdkDrag>\n <div class=\"row\">\n <div class=\"col-md-5 mb-2\">\n <label for=\"footerTitle{{i}}\" class=\"form-label\">Title</label>\n <input id=\"footerTitle{{i}}\" class=\"form-control\" [(ngModel)]=\"footer.title\" />\n </div>\n <div class=\"col-md-5 mb-2\">\n <label for=\"footerPath{{i}}\" class=\"form-label\">Path</label>\n <input id=\"footerPath{{i}}\" class=\"form-control\" [(ngModel)]=\"footer.path\" />\n </div>\n <div class=\"col-md-2 d-flex justify-content-between align-items-center mt-4\">\n <i class=\"fa fa-trash in-page-trash-icon text-danger cursor-pointer\" (click)=\"removeFooterLink(i)\" (keydown.enter)=\"removeFooterLink(i)\" (keydown.space)=\"removeFooterLink(i)\"></i>\n <i class=\"fa fa-bars in-page-bars-icon cursor-move\" cdkDragHandle></i>\n </div>\n </div>\n\n <!-- Subtitles -->\n <div cdkDropList (cdkDropListDropped)=\"dropSubtitles(i, $event)\">\n <div *ngFor=\"let sub of footer.subtitles; let j = index\" class=\"row border p-3 mb-2 align-items-center\" cdkDrag>\n <div class=\"col-md-5\">\n <label for=\"subtitleTitle{{i}}{{j}}\" class=\"form-label\">Subtitle Title</label>\n <input id=\"subtitleTitle{{i}}{{j}}\" class=\"form-control\" [(ngModel)]=\"sub.title\" />\n </div>\n <div class=\"col-md-5\">\n <label for=\"subtitlePath{{i}}{{j}}\" class=\"form-label\">Subtitle Path</label>\n <input id=\"subtitlePath{{i}}{{j}}\" class=\"form-control\" [(ngModel)]=\"sub.path\" />\n </div>\n <div class=\"col-md-2 d-flex justify-content-between align-items-center mt-4\">\n <i class=\"fa fa-trash in-page-trash-icon text-danger cursor-pointer\" (click)=\"removeSubtitle(i, j)\" (keydown.enter)=\"removeSubtitle(i, j)\" (keydown.space)=\"removeSubtitle(i, j)\"></i>\n <i class=\"fa fa-bars cursor-move in-page-bars-icon\" cdkDragHandle></i>\n </div>\n </div>\n </div>\n\n <button class=\"btn btn-outline-primary btn-sm mt-2\" (click)=\"addSubtitle(i)\">\n + Add Subtitle\n </button>\n </div>\n </div>\n\n <button class=\"btn btn-primary mt-3\" (click)=\"addFooterLink()\">\n + Add Footer Link\n </button>\n </div>\n\n <div class=\"modal-footer\">\n <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n <button class=\"btn btn-primary\" (click)=\"saveFooterLinks(modal)\">Save</button>\n </div>\n</ng-template>\n\n\n\n\n\n<ng-template #logoModal let-modal>\n <div class=\"modal-header\">\n <h5 class=\"modal-title\">Upload Logo</h5>\n <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n </div>\n <div class=\"modal-body\">\n <pw-custom-uploader\n [aspectRatio]=\"'fullLogo'\"\n [title]=\"'Main Contrast Logo'\"\n [controlName]=\"'logo_main_contrast'\"\n [previewData]=\"previewData\"\n (saveEvent)=\"onSaveFile($event)\">\n </pw-custom-uploader>\n </div>\n</ng-template>\n\n\n\n<ng-template #hubspotEditModal let-modal>\n <div class=\"modal-header\">\n <h5 class=\"modal-title\">Edit Hubspot Embed</h5>\n <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n </div>\n <div class=\"modal-body\">\n <div class=\"mb-3\">\n <label for=\"hubspotId\" class=\"form-label\">Hubspot ID</label>\n <input id=\"hubspotId\" [(ngModel)]=\"editingHubspotId\" class=\"form-control\" />\n </div>\n <div class=\"mb-3\">\n <label for=\"hubspotEmbedDiv\" class=\"form-label\">Embed DIV</label>\n <textarea id=\"hubspotEmbedDiv\" [(ngModel)]=\"editingHubspotHtml\" rows=\"8\" class=\"form-control\"></textarea>\n </div>\n </div>\n <div class=\"modal-footer\">\n <button class=\"btn btn-primary\" (click)=\"saveHubspotHtml(modal)\">Save</button>\n <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n </div>\n</ng-template>\n\n\n<ng-template #socialEditModal let-modal>\n <div class=\"modal-header\">\n <h5 class=\"modal-title\">Edit Social Links & Company Name</h5>\n <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n </div>\n <div class=\"modal-body\">\n <div class=\"mb-3\">\n <label for=\"youtubeUrl\" class=\"form-label\">YouTube URL</label>\n <input id=\"youtubeUrl\" [(ngModel)]=\"editingYoutubeUrl\" class=\"form-control\" />\n </div>\n <div class=\"mb-3\">\n <label for=\"linkedinUrl\" class=\"form-label\">LinkedIn URL</label>\n <input id=\"linkedinUrl\" [(ngModel)]=\"editingLinkedInUrl\" class=\"form-control\" />\n </div>\n <div class=\"mb-3\">\n <label for=\"companyName\" class=\"form-label\">Company Name</label>\n <input id=\"companyName\" [(ngModel)]=\"editingCompanyName\" class=\"form-control\" />\n </div>\n </div>\n <div class=\"modal-footer\">\n <button class=\"btn btn-primary\" (click)=\"saveSocialLinks(modal)\">Save</button>\n <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n </div>\n</ng-template>\n\n\n\n<ng-template #questionsEditModal let-modal>\n <div class=\"modal-header\">\n <h5 class=\"modal-title\">Edit Questions</h5>\n <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n </div>\n\n <div class=\"modal-body\">\n <h4 class=\"mb-3\">Questions Section</h4>\n <div cdkDropList (cdkDropListDropped)=\"dropQuestions($event)\">\n <div *ngFor=\"let q of editingQuestions; let i = index\" class=\"border p-3 mb-3\" cdkDrag>\n <div class=\"row\">\n <div class=\"col-md-11 mb-2\">\n <label for=\"questionText{{i}}\" class=\"form-label\">Question</label>\n <input id=\"questionText{{i}}\" class=\"form-control\" [(ngModel)]=\"q.question\" placeholder=\"Enter question\" />\n </div>\n <div class=\"col-md-1 d-flex justify-content-end align-items-start mt-4\">\n <i class=\"fa fa-bars in-page-bars-icon cursor-move\" cdkDragHandle></i>\n </div>\n </div>\n\n <!-- Options Section -->\n <div cdkDropList (cdkDropListDropped)=\"dropQuestionOptions(i, $event)\">\n <div *ngFor=\"let opt of q.options; let j = index\" class=\"row border p-3 mb-2 align-items-center\" cdkDrag>\n <div class=\"col-md-7 mb-2\">\n <label for=\"questionOption{{i}}{{j}}\" class=\"form-label\">Option</label>\n <input id=\"questionOption{{i}}{{j}}\" class=\"form-control\" [(ngModel)]=\"opt.option\" placeholder=\"Enter option\" />\n </div>\n <div class=\"col-md-2 d-flex justify-content-between align-items-center mt-4\">\n <i class=\"fa fa-trash in-page-trash-icon text-danger cursor-pointer\" (click)=\"removeQuestionOption(i, j)\" (keydown.enter)=\"removeQuestionOption(i, j)\" (keydown.enter)=\"removeQuestionOption(i, j)\"></i>\n <i class=\"fa fa-bars in-page-bars-icon cursor-move\" cdkDragHandle></i>\n </div>\n </div>\n </div>\n\n <button class=\"btn btn-outline-primary btn-sm mt-2\" (click)=\"addQuestionOption(i)\">+ Add Option</button>\n </div>\n </div>\n\n <button class=\"btn btn-primary mt-3\" (click)=\"addNewQuestion()\">+ Add Question</button>\n </div>\n\n <div class=\"modal-footer\">\n <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n <button class=\"btn btn-primary\" (click)=\"saveQuestions(modal)\">Save</button>\n </div>\n</ng-template>\n\n\n\n", styles: [".product-explainer-section{background-color:#000}.footer-section input.form-control,.footer-section select.form-control,.footer-section textarea.form-control{background-color:#fff;border:none;color:#000;font-size:14px}.btn-primary{background-color:#007bff;border:none}.site-column{margin-top:2.9rem}.email-section{color:#fff;font-size:2rem}.address-section{margin-top:5rem}.address-text{line-height:2.2rem}.user-info{font-size:1.5rem}.user-info-label{font-size:1.7rem;font-weight:700}.contact-form form .form-field{display:flex;align-items:center;margin-bottom:1.2rem}.contact-form form .form-field label{width:130px;min-width:130px;margin:0;font-size:14px;color:#fff;font-weight:600;text-transform:uppercase;letter-spacing:1px}.contact-form form .form-field p-dropdown{width:100%}.contact-form form .form-field input,.contact-form form .form-field select,.contact-form form .form-field textarea,.contact-form form .form-field ::ng-deep p-dropdown .p-inputwrapper{flex:1;border:none;border-radius:30px;padding:12px 20px;font-size:14px;width:100%!important;max-width:100%;color:#000}.contact-form form .form-field textarea{resize:vertical}.contact-form form .submit-button{background-color:#3b82f6;border:none;border-radius:30px;font-size:16px;font-weight:500;padding:10px 24px;margin-top:1.2rem}.input-select{height:43px}.select-label{width:210px!important}.copyright{margin-top:2rem;margin-left:4rem;font-size:19px;font-weight:700}.d-flex img{margin-right:0!important}.youtube-icon{height:38px}.enquiry-field{margin-left:.5rem;width:63%}::ng-deep .text-danger{margin-top:.25rem!important;margin-left:.5rem!important}@media (min-width: 768px){.hubspot-container{margin-top:-3rem}}@media (min-width: 768px) and (max-width: 1200px){.container{padding:0rem 6rem!important}}.link-label{cursor:pointer;transition:color .3s}.link-label:hover{color:var(--first)}.icons img{transition:transform .3s ease,filter .3s ease;cursor:pointer}.icons img:hover{transform:scale(1.1);filter:brightness(1.2)}.logo-image{max-width:160px;width:160px;height:35px;object-fit:contain;aspect-ratio:160/35}\n"] }]
|
|
466
|
+
}], ctorParameters: () => [{ type: i1.UntypedFormBuilder }, { type: i2.AuthService }, { type: i3.CrmService }, { type: i4.DomSanitizer }, { type: i5.AdminService }, { type: i0.Injector }, { type: i2.AbTestService }, { type: i6.NgbModal }, { type: i0.ChangeDetectorRef }, { type: Document, decorators: [{
|
|
467
|
+
type: Inject,
|
|
468
|
+
args: [DOCUMENT]
|
|
469
|
+
}] }], propDecorators: { footerSection: [{
|
|
470
|
+
type: ViewChild,
|
|
471
|
+
args: ['footerSection', { static: true }]
|
|
472
|
+
}], content: [{
|
|
473
|
+
type: ViewChild,
|
|
474
|
+
args: ['bookMeeting', { static: true }]
|
|
475
|
+
}], editFooterLinksModal: [{
|
|
476
|
+
type: ViewChild,
|
|
477
|
+
args: ['editFooterLinksModal']
|
|
478
|
+
}], logoModal: [{
|
|
479
|
+
type: ViewChild,
|
|
480
|
+
args: ['logoModal']
|
|
481
|
+
}], logoUploader: [{
|
|
482
|
+
type: ViewChild,
|
|
483
|
+
args: ['logoUploader']
|
|
484
|
+
}], hubspotEditModal: [{
|
|
485
|
+
type: ViewChild,
|
|
486
|
+
args: ['hubspotEditModal']
|
|
487
|
+
}], socialEditModal: [{
|
|
488
|
+
type: ViewChild,
|
|
489
|
+
args: ['socialEditModal']
|
|
490
|
+
}], questionsEditModal: [{
|
|
491
|
+
type: ViewChild,
|
|
492
|
+
args: ['questionsEditModal']
|
|
493
|
+
}], subscriptionId: [{
|
|
494
|
+
type: Input
|
|
495
|
+
}], sourceId: [{
|
|
496
|
+
type: Input
|
|
497
|
+
}], masterSubscriptionId: [{
|
|
498
|
+
type: Input
|
|
499
|
+
}], experimentName: [{
|
|
500
|
+
type: Input
|
|
501
|
+
}], microserviceName: [{
|
|
502
|
+
type: Input
|
|
503
|
+
}], shardName: [{
|
|
504
|
+
type: Input
|
|
505
|
+
}], user: [{
|
|
506
|
+
type: Input
|
|
507
|
+
}], userLoggedIn: [{
|
|
508
|
+
type: Input
|
|
509
|
+
}] } });
|
|
510
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-contact-us.component.js","sourceRoot":"","sources":["../../../../../../../../libs/resource-module/src/lib/public/components/resource-contact-us/resource-contact-us.component.ts","../../../../../../../../libs/resource-module/src/lib/public/components/resource-contact-us/resource-contact-us.component.html"],"names":[],"mappings":"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","sourcesContent":["import { moveItemInArray } from '@angular/cdk/drag-drop';\nimport { DOCUMENT } from '@angular/common';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    Inject,\n    Injector,\n    Input,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    SimpleChanges,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\nimport { UntypedFormBuilder, UntypedFormGroup, Validators } from '@angular/forms';\nimport { DomSanitizer } from '@angular/platform-browser';\n\nimport { AdminService } from '@posiwise/admin-module-utils';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { AbTestService, AuthService, ValidationService } from '@posiwise/common-services';\nimport { User } from '@posiwise/common-utilities';\nimport { HelperService } from '@posiwise/helper-service';\nimport { CustomUploaderComponent } from '@posiwise/shared-components';\nimport { CrmService } from '@posiwise/smart-crm-shared';\n\nimport { StatusCodes } from 'http-status-codes';\nimport Swal from 'sweetalert2';\n\nimport { NgbModal } from '@ng-bootstrap/ng-bootstrap';\n\nimport { ResourceModalContext } from '../../../shared/resource-modal.interface';\n\n@Component({\n    selector: 'pw-trial-4-contact-us',\n    templateUrl: './resource-contact-us.component.html',\n    styleUrls: ['./resource-contact-us.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class Trial4ContactUsComponent\n    extends AppBaseComponent\n    implements OnInit, AfterViewInit, OnChanges, OnDestroy\n{\n    @ViewChild('footerSection', { static: true }) footerSection!: ElementRef;\n    @ViewChild('bookMeeting', { static: true }) content: TemplateRef<ResourceModalContext>;\n    @ViewChild('editFooterLinksModal') editFooterLinksModal: TemplateRef<CustomUploaderComponent>;\n    @ViewChild('logoModal') logoModal: TemplateRef<CustomUploaderComponent>;\n    @ViewChild('logoUploader') logoUploader: CustomUploaderComponent;\n    @ViewChild('hubspotEditModal') hubspotEditModal: TemplateRef<ResourceModalContext>;\n    @ViewChild('socialEditModal') socialEditModal: TemplateRef<CustomUploaderComponent>;\n    @ViewChild('questionsEditModal') questionsEditModal: TemplateRef<CustomUploaderComponent>;\n\n    editingQuestions = [];\n    isHubspotReady: boolean;\n\n    isFooterVisible = false;\n    private observer?: IntersectionObserver;\n\n    openQuestionsEditModal(): void {\n        this.editingQuestions = JSON.parse(JSON.stringify(this.editingQuestions ?? []));\n        this.modalService.open(this.questionsEditModal, { centered: true, size: 'lg' });\n    }\n\n    editingYoutubeUrl: string;\n    editingLinkedInUrl: string;\n    editingCompanyName: string;\n\n    form: UntypedFormGroup;\n\n    recaptcha = null;\n\n    previewData;\n\n    @Input() subscriptionId = this.appConfig.crm.subscription_id;\n    @Input() sourceId = this.appConfig.crm.source_id;\n    @Input() masterSubscriptionId = this.appConfig.master_subscription.subscription_id;\n    @Input() experimentName;\n    @Input() microserviceName;\n    @Input() shardName;\n    @Input() user: User;\n\n    canEditResourcesValue = false;\n    @Input() userLoggedIn: boolean;\n\n    id;\n\n    logo = this.appConfig?.company?.logos?.main_contrast?.url;\n    trialBgImage2 = this.appConfig?.signup_config.trial?.image_bg2?.url;\n    tosId = this.appConfig?.main_tos_id;\n    description = this.appConfig.company.description;\n    email = this.appConfig.company.email;\n    companyName = this.appConfig.company.name;\n    street = this.appConfig.company.street;\n    questions = this.appConfig?.pages_config?.contact_us?.questions;\n    hubspot = this.appConfig?.pages_config?.contact_us?.hubspot;\n    footerLinks = this.appConfig?.pages_config?.footer_links?.items;\n\n    footerLinksData = this.appConfig?.pages_config?.footer_links;\n\n    youtubeUrl = this.appConfig.social?.youtube_url;\n    linkedInUrl = this.appConfig.social?.linkedin_url;\n    domainId = this.appConfig.domain_id;\n\n    editingEmail = this.email;\n    isEditingEmail = false;\n\n    editingHubspotHtml: string;\n    editingHubspotId: string;\n    captchaKeyV2: string;\n    hubspotHtml;\n\n    abTests;\n\n    submitted = false;\n    isCaptchaVerified = false;\n    isEmailValid = true;\n    isEditingStreet = false;\n\n    psaOptions;\n\n    question;\n\n    editingFooterLinks = {\n        items: []\n    };\n    editingStreet: string;\n\n    constructor(\n        private readonly fb: UntypedFormBuilder,\n        private readonly authService: AuthService,\n        private readonly crmService: CrmService,\n        private readonly sanitizer: DomSanitizer,\n        private readonly adminService: AdminService,\n        injector: Injector,\n        private readonly abTestService: AbTestService,\n        private readonly modalService: NgbModal,\n        private readonly cdr: ChangeDetectorRef,\n        @Inject(DOCUMENT) private readonly document: Document\n    ) {\n        super(injector);\n        this.captchaKeyV2 = this.appConfig.integrations.captcha_key_V2;\n        this.contactUsForm();\n    }\n\n    ngOnInit() {\n        setTimeout(() => (this.isHubspotReady = true), 2000);\n        if (this.userLoggedIn) {\n            this.localStorage.getItem$('product').subscribe(res => {\n                const data = res ? JSON.parse(res) : null;\n                this.id = data?.subscriptionId;\n            });\n        }\n        this.previewData = {\n            url: this.logo,\n            name: 'logo_main_contrast.png'\n        };\n        this.editingStreet = this.street;\n        if (Array.isArray(this.appConfig.pages_config?.ab_tests)) {\n            this.abTests = this.appConfig.pages_config.ab_tests.find(\n                test => test.description === 'contact-us'\n            );\n            this.microserviceName = this.abTests?.microservice_name;\n            this.experimentName = this.abTests?.experiment_name;\n            this.shardName = this.abTests?.db_shard;\n        }\n\n        const footerItem = this.getFooterHubspotForm();\n        if (footerItem?.div) {\n            // NOSONAR: Trusted HTML content is handled safely here\n            this.hubspotHtml = this.sanitizer.bypassSecurityTrustHtml(footerItem.div); // NOSONAR\n        }\n        this.editingQuestions = this.questions;\n        this.question = this.questions?.[0]?.question;\n        this.psaOptions = [\n            { label: 'Select PSA', value: '' },\n            ...(this.questions?.[0]?.options ?? [])\n                .filter(q => q.option?.trim())\n                .map(q => ({\n                    label: q.option,\n                    value: q.option\n                }))\n        ];\n    }\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes['user'] || changes['userLoggedIn']) {\n            if (this.userLoggedIn && this.user) {\n                this.updateCanEditResourcesValue();\n            }\n        }\n    }\n\n    openLogoEditModal(): void {\n        this.modalService.open(this.logoModal, {\n            centered: true,\n            size: 'md'\n        });\n    }\n\n    onSaveFile(event): void {\n        const formData = new FormData();\n        const data = { subscription_id: this.subscriptionId };\n\n        if (event.file instanceof File) {\n            data[event.name] = event.file;\n        } else if (event.file === null) {\n            data[`remove_${event.name}`] = true;\n        }\n\n        for (const key in data) {\n            formData.append(key, data[key]);\n        }\n\n        this.adminService.updateDomainConfig(this.domainId, formData).subscribe(() => {\n            if (event.file) {\n                this.logo = URL.createObjectURL(event.file);\n                this.modalService.dismissAll();\n            }\n            this.toast.success(event.file ? 'Logo updated' : 'Logo removed');\n        });\n    }\n\n    saveQuestions(modal): void {\n        const updateData = {\n            contact_us: {\n                ...this.appConfig.pages_config?.contact_us,\n                questions: this.editingQuestions\n            },\n            subscription_id: this.id\n        };\n\n        this.adminService.updateDomainConfig(this.domainId, updateData).subscribe(() => {\n            this.questions = this.editingQuestions;\n            this.toast.success('Questions updated');\n            this.question = this.editingQuestions?.[0]?.question;\n            if (this.editingQuestions?.[0]?.options?.length > 0) {\n                this.psaOptions = [\n                    { label: 'Select PSA', value: '' },\n                    ...(this.questions?.[0]?.options ?? [])\n                        .filter(q => q.option?.trim())\n                        .map(q => ({\n                            label: q.option,\n                            value: q.option\n                        }))\n                ];\n            } else {\n                this.psaOptions = [];\n            }\n\n            modal.close();\n        });\n    }\n\n    addNewQuestion(): void {\n        this.editingQuestions.push({ question: '', options: [] });\n    }\n\n    addQuestionOption(qIndex: number): void {\n        this.editingQuestions[qIndex].options.push({ option: '' });\n    }\n\n    removeQuestionOption(qIndex: number, optIndex: number): void {\n        this.editingQuestions[qIndex].options.splice(optIndex, 1);\n    }\n\n    dropQuestions(event): void {\n        moveItemInArray(this.editingQuestions, event.previousIndex, event.currentIndex);\n    }\n\n    dropQuestionOptions(qIndex: number, event): void {\n        moveItemInArray(\n            this.editingQuestions[qIndex].options,\n            event.previousIndex,\n            event.currentIndex\n        );\n    }\n\n    openSocialEditModal(): void {\n        this.editingYoutubeUrl = this.youtubeUrl;\n        this.editingLinkedInUrl = this.linkedInUrl;\n        this.editingCompanyName = this.companyName;\n\n        this.modalService.open(this.socialEditModal, { centered: true, size: 'lg' });\n    }\n\n    saveSocialLinks(modal): void {\n        const updateData = {\n            youtube_url: this.editingYoutubeUrl,\n            linkedin_url: this.editingLinkedInUrl,\n            company_name: this.editingCompanyName,\n            subscription_id: this.id\n        };\n\n        this.adminService.updateDomainConfig(this.domainId, updateData).subscribe(() => {\n            this.youtubeUrl = this.editingYoutubeUrl;\n            this.linkedInUrl = this.editingLinkedInUrl;\n            this.companyName = this.editingCompanyName;\n            this.toast.success('Social links and company name updated');\n            modal.close();\n        });\n    }\n\n    hasValidOptions(): boolean {\n        return this.questions?.[0]?.options?.some(opt => opt.option?.trim());\n    }\n\n    ngAfterViewInit() {\n        this.watchIframeHeightChange();\n        this.observer = new IntersectionObserver(\n            ([entry]) => {\n                if (entry.isIntersecting) {\n                    this.isFooterVisible = true;\n                    this.cdr.detectChanges();\n                    this.observer?.disconnect();\n                }\n            },\n            { threshold: 0.1 }\n        );\n\n        this.observer.observe(this.footerSection.nativeElement);\n    }\n\n    openEditFooterLinksModal(content): void {\n        this.footerLinksData = this.footerLinksData ?? {};\n        this.footerLinksData.items = this.footerLinksData.items ?? [];\n        this.editingFooterLinks = JSON.parse(JSON.stringify(this.footerLinksData));\n\n        this.modalService.open(content, {\n            size: 'lg',\n            centered: true,\n            windowClass: 'modal-holder'\n        });\n    }\n\n    private watchIframeHeightChange() {\n        const iframe = this.document.querySelector('.hubspot-container');\n        if (!iframe) return;\n        const interval = setInterval(() => {\n            const newHeight = iframe['offsetHeight'];\n            if (newHeight === 250) {\n                clearInterval(interval);\n                this.callAbTestFinish();\n            }\n        }, 300);\n    }\n\n    // New method to handle Hubspot content loading\n    onHubspotLoad(event: Event) {\n        const container = event.target as HTMLDivElement;\n        container.classList.add('content-loaded');\n\n        // Optional: Trigger layout recalculation\n        setTimeout(() => {\n            window.dispatchEvent(new Event('resize'));\n        }, 100);\n    }\n\n    private callAbTestFinish() {\n        if (this.experimentName && this.microserviceName) {\n            this.abTestService\n                .finishABExperiment(this.experimentName, this.microserviceName)\n                .subscribe(() => {\n                    this.modalService.open(this.content, {\n                        centered: true,\n                        windowClass: 'modal-holder'\n                    });\n                });\n        }\n    }\n\n    contactUsForm(): void {\n        this.form = this.fb.group({\n            first_name: ['', Validators.required],\n            last_name: [''],\n            company: [''],\n            psa: [''],\n            enquiry: ['', Validators.required],\n            email: ['', Validators.required]\n        });\n    }\n\n    onSubmit() {\n        this.submitted = true;\n        if (this.form.valid) {\n            this.isCaptchaVerified = true;\n            this.submitted = false;\n        }\n    }\n\n    handleSuccess(token: string) {\n        if (token) {\n            this.authService.validateReCaptcha(token).subscribe((isSuccess: boolean) => {\n                if (isSuccess && this.form.valid) {\n                    const data = { ...this.form.getRawValue() };\n                    const formattedEnquiry = `${data.enquiry}; Question: ${this.question}; Answer: ${data.psa}`;\n                    const postData = {\n                        first_name: `${data.first_name}`,\n                        last_name: `${data.first_name}`,\n                        company: `${data.first_name}`,\n                        email: `${data.email}`,\n                        enquiry: this.psaOptions.length ? formattedEnquiry : `${data.enquiry}`,\n                        psa: data.psa,\n                        subscription_id: this.subscriptionId,\n                        crm_source_id: this.sourceId,\n                        master_subscription_id: this.masterSubscriptionId,\n                        notify_user: false,\n                        is_manual: false\n                    };\n\n                    this.crmService.postCrmLead(this.subscriptionId, postData).subscribe(resp => {\n                        //  example of snippet to close the experiment and track in GA\n                        if (resp?.status === StatusCodes.OK) {\n                            this.googleAnalyticsService.sendEvent(\n                                'new-lead-registration', // category, eg: videos\n                                'subscribe-success', // action, eg: Play\n                                'coming-soon-three', // label, eg: Chappy\n                                1 // value, eg: 10\n                            );\n                            if (this.experimentName && this.microserviceName) {\n                                this.abTestService\n                                    .finishABExperiment(this.experimentName, this.microserviceName)\n                                    .subscribe(() => {\n                                        this.modalService.open(this.content, {\n                                            centered: true,\n                                            windowClass: 'modal-holder'\n                                        });\n                                    });\n                            } else {\n                                Swal.fire(resp.message);\n                            }\n                        }\n                        this.form.reset();\n                        this.isCaptchaVerified = false;\n                    });\n                }\n            });\n        }\n    }\n\n    scrollToTop() {\n        this.document.documentElement.scrollTop = 0;\n    }\n\n    getFooterHubspotForm() {\n        if (!this.hubspot?.length) {\n            return null;\n        }\n\n        return this.hubspot.find(item => item.position === 'footer') ?? null;\n    }\n\n    navigateToBookMeeting() {\n        window.open('https://calendly.com/cloudolive', '_blank', 'noreferrer noopener');\n    }\n\n    validateEmail() {\n        const email = this.form.get('email').value;\n        if (email) {\n            this.isEmailValid = ValidationService.email(email);\n        } else {\n            this.isEmailValid = true;\n        }\n    }\n\n    addFooterLink(): void {\n        this.editingFooterLinks.items.push({\n            title: '',\n            path: '',\n            subtitles: []\n        });\n    }\n\n    removeFooterLink(index: number): void {\n        this.editingFooterLinks.items.splice(index, 1);\n    }\n\n    addSubtitle(footerIndex: number): void {\n        this.editingFooterLinks.items[footerIndex].subtitles.push({\n            title: '',\n            path: ''\n        });\n    }\n\n    removeSubtitle(footerIndex: number, subtitleIndex: number): void {\n        this.editingFooterLinks.items[footerIndex].subtitles.splice(subtitleIndex, 1);\n    }\n\n    dropFooterLinks(event) {\n        moveItemInArray(this.editingFooterLinks.items, event.previousIndex, event.currentIndex);\n    }\n\n    dropSubtitles(footerIndex: number, event) {\n        moveItemInArray(\n            this.editingFooterLinks.items[footerIndex].subtitles,\n            event.previousIndex,\n            event.currentIndex\n        );\n    }\n\n    saveFooterLinks(modal): void {\n        const updatedConfig = {\n            footer_links: this.editingFooterLinks,\n            subscription_id: this.id\n        };\n\n        this.adminService\n            .updateDomainConfig(this.appConfig?.domain_id, updatedConfig)\n            .subscribe(() => {\n                this.toast.success('Footer links updated');\n                this.footerLinks = [...this.editingFooterLinks.items];\n                this.footerLinksData = { ...this.editingFooterLinks };\n                modal.close();\n            });\n    }\n\n    saveEmail(): void {\n        this.email = this.editingEmail;\n\n        this.adminService\n            .updateDomainConfig(this.appConfig?.domain_id, {\n                company_email: this.editingEmail,\n                subscription_id: this.id\n            })\n            .subscribe(() => {\n                this.toast.success('Email updated');\n                this.isEditingEmail = false;\n            });\n    }\n\n    saveStreet(): void {\n        this.adminService\n            .updateDomainConfig(this.appConfig?.domain_id, {\n                company_address: this.editingStreet,\n                subscription_id: this.id\n            })\n            .subscribe(() => {\n                this.toast.success('Street updated');\n                this.street = this.editingStreet;\n                this.isEditingStreet = false;\n            });\n    }\n\n    cancelStreet(): void {\n        this.editingStreet = this.street;\n        this.isEditingStreet = false;\n    }\n\n    openHubspotEditModal(footerItem): void {\n        this.editingHubspotHtml = footerItem.div;\n        this.editingHubspotId = footerItem.id;\n        this.modalService.open(this.hubspotEditModal, { centered: true, size: 'lg' });\n    }\n\n    saveHubspotHtml(modal): void {\n        const updatedConfig = {\n            contact_us: {\n                ...this.appConfig?.pages_config?.contact_us,\n                hubspot: [\n                    {\n                        id: '7423639',\n                        position: 'footer',\n                        div: this.editingHubspotHtml\n                    }\n                ]\n            },\n            subscription_id: this.id\n        };\n\n        this.adminService\n            .updateDomainConfig(this.appConfig?.domain_id, updatedConfig)\n            .subscribe(() => {\n                // NOSONAR: Trusted HTML content is handled safely here\n                this.hubspotHtml = this.sanitizer.bypassSecurityTrustHtml(this.editingHubspotHtml); // NOSONAR\n                this.toast.success('Hubspot Embed updated');\n                modal.close();\n            });\n    }\n    private updateCanEditResourcesValue(): void {\n        this.canEditResourcesValue = HelperService.canEditResources(\n            this.user,\n            this.userLoggedIn,\n            this.permissionService\n        );\n    }\n\n    canEditResources(): boolean {\n        return this.canEditResourcesValue;\n    }\n\n    override ngOnDestroy(): void {\n        this.observer?.disconnect();\n    }\n}\n","<section  #footerSection class=\"bg-black text-white py-5 footer-section\">\n  <div class=\"container\" *ngIf=\"isFooterVisible\">\n    <div class=\"row\">\n\n      <!-- LEFT COLUMN -->\n      <div class=\"col-md-6 mb-4 d-flex flex-column justify-content-between\" [ngClass]=\"{ 'site-column': getFooterHubspotForm() }\">\n        <div>\n          <h3 class=\"mb-4 d-flex align-items-center\">\n            <span class=\"me-2 text-white\">Site Map:</span>\n            <i *ngIf=\"canEditResourcesValue\" class=\"fa fa-edit in-page-edit-icon cursor-pointer text-white ms-3\" (click)=\"openEditFooterLinksModal(editFooterLinksModal)\" (keydown.enter)=\"openEditFooterLinksModal(editFooterLinksModal)\" (keydown.space)=\"openEditFooterLinksModal(editFooterLinksModal)\" ngbTooltip=\"Edit Footer Links\"></i>\n          </h3>\n          <ul class=\"mt-4\">\n            <li routerLink=\"/\"\n            class=\"cursor-pointer user-info-label link-label\"> Home </li>\n            <li *ngFor=\"let link of footerLinks\" [routerLink]=\"link?.path\"\n              class=\"cursor-pointer user-info-label link-label mt-4\"><span  *ngIf=\"link?.title\">{{link?.title}}</span> </li>\n            <li routerLink=\"/login\"\n              class=\"cursor-pointer user-info-label mt-4 link-label\"> Log in </li>\n            <li [routerLink]=\"'/privacy-and-tos/' + tosId\"\n              class=\"cursor-pointer user-info-label mt-4 link-label\"> Privacy statement </li>\n          </ul>\n          <p class=\"address-section email-section mb-4\">\n            <span class=\"user-info-label\">Email: </span>\n            <ng-container *ngIf=\"!isEditingEmail; else editEmail\">\n              <span class=\"user-info\">{{ email }}</span>\n              <i *ngIf=\"canEditResourcesValue\" class=\"fa fa-edit in-page-edit-icon text-white cursor-pointer ms-3\" (click)=\"isEditingEmail = true\" (keydown.enter)=\"isEditingEmail = true\" (keydown.space)=\"isEditingEmail = true\"></i>\n            </ng-container>\n\n            <ng-template #editEmail>\n              <input\n                class=\"form-control d-inline w-auto\"\n                [(ngModel)]=\"editingEmail\"\n              />\n              <button class=\"btn btn-sm btn-primary ms-2\" (click)=\"saveEmail()\">Save</button>\n              <button class=\"btn btn-sm btn-secondary ms-2\" (click)=\"isEditingEmail = false\">Cancel</button>\n            </ng-template>\n          </p>\n                    <span class=\"email-section mt-3 address-text\">\n            <span class=\"user-info-label\">\n              Address:\n              <i *ngIf=\"canEditResourcesValue\"\n                 class=\"fa fa-edit in-page-edit-icon cursor-pointer ms-2 text-white\"\n                 title=\"Edit Address\"\n                 (click)=\"isEditingStreet = true\"\n                 (keydown.enter)=\"isEditingStreet = true\"\n                 (keydown.space)=\"isEditingStreet = true\"></i>\n            </span><br/>\n\n            <ng-container *ngIf=\"!isEditingStreet; else editStreetBlock\">\n              <span class=\"address-text user-info\">{{ street }}</span>\n            </ng-container>\n\n            <ng-template #editStreetBlock>\n              <div class=\"d-flex align-items-center mt-3\">\n                <input class=\"form-control form-control-sm\" [(ngModel)]=\"editingStreet\" />\n                <button class=\"btn btn-sm btn-primary ms-2\" (click)=\"saveStreet()\">Save</button>\n                <button class=\"btn btn-sm btn-secondary ms-2\" (click)=\"cancelStreet()\">Cancel</button>\n              </div>\n            </ng-template>\n\n          </span>\n\n        </div>\n        <div class=\"d-flex\">\n          <img [src]=\"logo\"\n               alt=\"Company logo\"\n               class=\"img-fluid mt-4 logo-image cursor-pointer\"\n               width=\"160\"\n               height=\"35\"\n               (click)=\"scrollToTop()\"\n               (keydown.enter)=\"scrollToTop()\"\n               (keydown.space)=\"scrollToTop()\"\n               title=\"Click to go to top of page\" />\n          <i *ngIf=\"canEditResourcesValue\"\n             class=\"fa fa-edit in-page-edit-icon fa-sm ms-3 cursor-pointer text-white align-self-center mt-3\"\n             (click)=\"openLogoEditModal()\"\n             (keydown.enter)=\"openLogoEditModal()\"\n             (keydown.space)=\"openLogoEditModal()\"\n             title=\"Edit Logo\"></i>\n        </div>\n      </div>\n\n      <!-- RIGHT COLUMN -->\n      <div class=\"col-md-6\" *ngIf=\"isFooterVisible\">\n        <ng-container *ngIf=\"getFooterHubspotForm() as footerItem; else defaultForm\">\n            <div class=\"d-flex\">\n              <div\n                *ngIf=\"isHubspotReady\"\n                class=\"hubspot-container w-100 content-loaded\"\n                [innerHTML]=\"hubspotHtml\"\n                (load)=\"onHubspotLoad($event)\">\n              </div>\n              <i *ngIf=\"canEditResourcesValue\"\n              class=\"fa fa-edit in-page-edit-icon text-white cursor-pointer\"\n              (click)=\"openHubspotEditModal(footerItem)\"\n              (keydown.enter)=\"openHubspotEditModal(footerItem)\"\n              (keydown.space)=\"openHubspotEditModal(footerItem)\"\n              title=\"Edit Hubspot Embed\"></i>\n            </div>\n          </ng-container>\n\n          <ng-template #defaultForm>\n          <div class=\"d-flex\">\n                <h3 class=\"text-white mb-4\"> <span class=\"text-white\">Get in touch:</span></h3>\n                <i *ngIf=\"canEditResourcesValue\"\n                class=\"fa fa-edit in-page-edit-icon text-white cursor-pointer ms-3 mt-2\"\n                (click)=\"openQuestionsEditModal()\"\n                (keydown.enter)=\"openQuestionsEditModal()\"\n                (keydown.space)=\"openQuestionsEditModal()\"\n                title=\"Edit Questions\"></i>\n            </div>\n            <div class=\"contact-form\">\n              <form [formGroup]=\"form\">\n                <div class=\"mb-3\">\n                  <div class=\"email\">\n                    <div class=\"form-field\">\n                      <label for=\"email\">Email:</label>\n                      <div class=\"w-100\">\n                        <input type=\"text\"\n                          class=\"mb-1\"\n                          id=\"email\"\n                          formControlName=\"email\" />\n                          <pw-field-error-display [displayError]=\"\n                          !form.get('email').valid && (form.get('email').touched || submitted)\n                          \"\n                      errorMsg=\"Email is required\">\n                    </pw-field-error-display>\n                      </div>\n                    </div>\n                    <div class=\"form-field\">\n                      <label for=\"first_name\">First name:</label>\n                      <div class=\"w-100\">\n                        <input input type=\"text\"\n                        id=\"first_name\"\n                        formControlName=\"first_name\" />\n                          <pw-field-error-display [displayError]=\"\n                          !form.get('first_name').valid && (form.get('first_name').touched || submitted)\n                          \"\n                      errorMsg=\"First name is required\">\n                    </pw-field-error-display>\n                      </div>\n                    </div>\n                    <div class=\"form-field\">\n                      <label for=\"last_name\">Last name:</label>\n                      <input type=\"text\"\n                        id=\"last_name\"\n                        formControlName=\"last_name\" />\n                    </div>\n                    <div class=\"form-field\">\n                      <label for=\"company\">Company:</label>\n                      <input type=\"text\"\n                        id=\"company\"\n                        formControlName=\"company\" />\n                    </div>\n                    <div class=\"form-field\" *ngIf=\"hasValidOptions()\">\n                      <label for=\"psa\" class=\"select-label\">{{question}}</label>\n                      <p-dropdown\n                        formControlName=\"psa\"\n                        [options]=\"psaOptions\"\n                        [placeholder]=\"'Select PSA'\"\n                        styleClass=\"input-select\">\n                      </p-dropdown>\n                    </div>\n                    <div class=\"form-field\">\n                      <label for=\"enquiry\" class=\"select-label\">How can we help you?</label>\n                      <div class=\"enquiry-field\">\n                        <textarea  id=\"enquiry\" formControlName=\"enquiry\" class=\"\">\n                                      </textarea>\n                          <pw-field-error-display [displayError]=\"\n                          !form.get('enquiry').valid && (form.get('enquiry').touched || submitted)\n                          \"\n                      errorMsg=\"Enquiry is required\">\n                    </pw-field-error-display>\n                      </div>\n                    </div>\n                  </div>\n                </div>\n                <div class=\"text-end\">\n                  <div class=\"captcha-wrapper-container\"\n                  *ngIf=\"isCaptchaVerified\">\n                  <ngx-recaptcha2 [ngModelOptions]=\"{ standalone: true }\"\n                    [siteKey]=\"captchaKeyV2\"\n                    size=\"normal\"\n                    [(ngModel)]=\"recaptcha\"\n                    (success)=\"handleSuccess($event)\">\n                  </ngx-recaptcha2>\n                </div>\n                  <button type=\"submit\"\n                    (click)=\"onSubmit()\"\n                    *ngIf=\"!isCaptchaVerified\"\n                    class=\"sign-btn sign-header-btn mt-3\">\n                    {{ 'Button.Submit' | transloco }}\n                  </button>\n                </div>\n\n                <div class=\"d-flex align-items-center mt-4\">\n                  <div class=\"icons d-flex align-items-center\">\n                    <a [eventTracker]=\"{\n                        category: 'youtube',\n                        action: 'click',\n                        label: 'cloudolive-landing-page-b',\n                        value: 1\n                      }\"\n                      [href]=\"youtubeUrl\"\n                      target=\"_blank\"\n                      rel=\"noopener noreferrer\">\n                      <img src=\"/assets/img/icons/youtube.png\"\n                        class=\"img-fluid youtube-icon\"\n                        width=\"54\"\n                        height=\"54\"\n                        alt=\"\" />\n                    </a>\n                    <a [eventTracker]=\"{\n                        category: 'linkedin',\n                        action: 'click',\n                        label: 'cloudolive-landing-page-b',\n                        value: 1\n                      }\"\n                      [href]=\"linkedInUrl\"\n                      target=\"_blank\"\n                      rel=\"noopener noreferrer\"\n                      class=\"ms-3\">\n                      <img src=\"/assets/img/icons/social/linkedin.svg\"\n                        class=\"img-fluid linkedin-icon\"\n                        width=\"48\"\n                        height=\"48\"\n                        alt=\"\" />\n                    </a>\n                    <i *ngIf=\"canEditResourcesValue\"\n                    class=\"fa fa-edit in-page-edit-icon text-white cursor-pointer ms-3\"\n                    (click)=\"openSocialEditModal()\"\n                    (keydown.enter)=\"openSocialEditModal()\"\n                    (keydown.space)=\"openSocialEditModal()\"\n                    title=\"Edit Social Links & Company Name\"></i>\n                  </div>\n                  <div class=\"copyright text-white\">\n                    2025 {{companyName}}.\n                  </div>\n                </div>\n              </form>\n            </div>\n          </ng-template>\n        </div>\n    </div>\n  </div>\n</section>\n\n\n\n<ng-template #bookMeeting\n  let-modal>\n  <div class=\"modal-header\">\n    <button type=\"button\"\n      class=\"btn-close float-end\"\n      aria-label=\"Close\"\n      (click)=\"modal.dismiss()\">\n    </button>\n  </div>\n  <div class=\"modal-body\">\n    <h3 class=\"text-center modal-basic-title\">\n      Thanks for getting in touch! Our team will be in contact shortly, or we\n      can compare calendars now &amp; schedule a time\n    </h3>\n    <button type=\"button\"\n      [eventTracker]=\"{\n        category: 'request-demo',\n        action: 'click',\n        label: 'cloudolive-landing-page-b',\n        value: 1\n      }\"\n      (click)=\"navigateToBookMeeting()\"\n      class=\"sign-btn sign-header-btn mx-auto d-block mb-3\">\n      Let's do it\n    </button>\n  </div>\n</ng-template>\n\n\n<ng-template #editFooterLinksModal let-modal>\n  <div class=\"modal-header\">\n    <h5 class=\"modal-title\">Edit Footer Links</h5>\n    <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n  </div>\n\n  <div class=\"modal-body\">\n    <h4 class=\"mb-3\">Footer Links Section</h4>\n    <div cdkDropList (cdkDropListDropped)=\"dropFooterLinks($event)\">\n      <div *ngFor=\"let footer of editingFooterLinks.items; let i = index\" class=\"border p-3 mb-3\" cdkDrag>\n        <div class=\"row\">\n          <div class=\"col-md-5 mb-2\">\n            <label for=\"footerTitle{{i}}\" class=\"form-label\">Title</label>\n            <input id=\"footerTitle{{i}}\" class=\"form-control\" [(ngModel)]=\"footer.title\" />\n          </div>\n          <div class=\"col-md-5 mb-2\">\n            <label for=\"footerPath{{i}}\" class=\"form-label\">Path</label>\n            <input id=\"footerPath{{i}}\" class=\"form-control\" [(ngModel)]=\"footer.path\" />\n          </div>\n          <div class=\"col-md-2 d-flex justify-content-between align-items-center mt-4\">\n            <i class=\"fa fa-trash in-page-trash-icon text-danger cursor-pointer\" (click)=\"removeFooterLink(i)\" (keydown.enter)=\"removeFooterLink(i)\" (keydown.space)=\"removeFooterLink(i)\"></i>\n            <i class=\"fa fa-bars in-page-bars-icon cursor-move\" cdkDragHandle></i>\n          </div>\n        </div>\n\n        <!-- Subtitles -->\n        <div cdkDropList (cdkDropListDropped)=\"dropSubtitles(i, $event)\">\n          <div *ngFor=\"let sub of footer.subtitles; let j = index\" class=\"row border p-3 mb-2 align-items-center\" cdkDrag>\n            <div class=\"col-md-5\">\n              <label for=\"subtitleTitle{{i}}{{j}}\" class=\"form-label\">Subtitle Title</label>\n              <input id=\"subtitleTitle{{i}}{{j}}\" class=\"form-control\" [(ngModel)]=\"sub.title\" />\n            </div>\n            <div class=\"col-md-5\">\n              <label for=\"subtitlePath{{i}}{{j}}\" class=\"form-label\">Subtitle Path</label>\n              <input id=\"subtitlePath{{i}}{{j}}\" class=\"form-control\" [(ngModel)]=\"sub.path\" />\n            </div>\n            <div class=\"col-md-2 d-flex justify-content-between align-items-center mt-4\">\n              <i class=\"fa fa-trash in-page-trash-icon text-danger cursor-pointer\" (click)=\"removeSubtitle(i, j)\" (keydown.enter)=\"removeSubtitle(i, j)\" (keydown.space)=\"removeSubtitle(i, j)\"></i>\n              <i class=\"fa fa-bars cursor-move in-page-bars-icon\" cdkDragHandle></i>\n            </div>\n          </div>\n        </div>\n\n        <button class=\"btn btn-outline-primary btn-sm mt-2\" (click)=\"addSubtitle(i)\">\n          + Add Subtitle\n        </button>\n      </div>\n    </div>\n\n    <button class=\"btn btn-primary mt-3\" (click)=\"addFooterLink()\">\n      + Add Footer Link\n    </button>\n  </div>\n\n  <div class=\"modal-footer\">\n    <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n    <button class=\"btn btn-primary\" (click)=\"saveFooterLinks(modal)\">Save</button>\n  </div>\n</ng-template>\n\n\n\n\n\n<ng-template #logoModal let-modal>\n  <div class=\"modal-header\">\n    <h5 class=\"modal-title\">Upload Logo</h5>\n    <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n  </div>\n  <div class=\"modal-body\">\n    <pw-custom-uploader\n      [aspectRatio]=\"'fullLogo'\"\n      [title]=\"'Main Contrast Logo'\"\n      [controlName]=\"'logo_main_contrast'\"\n      [previewData]=\"previewData\"\n      (saveEvent)=\"onSaveFile($event)\">\n    </pw-custom-uploader>\n  </div>\n</ng-template>\n\n\n\n<ng-template #hubspotEditModal let-modal>\n  <div class=\"modal-header\">\n    <h5 class=\"modal-title\">Edit Hubspot Embed</h5>\n    <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n  </div>\n  <div class=\"modal-body\">\n    <div class=\"mb-3\">\n      <label for=\"hubspotId\" class=\"form-label\">Hubspot ID</label>\n      <input id=\"hubspotId\" [(ngModel)]=\"editingHubspotId\" class=\"form-control\" />\n    </div>\n    <div class=\"mb-3\">\n      <label for=\"hubspotEmbedDiv\" class=\"form-label\">Embed DIV</label>\n      <textarea id=\"hubspotEmbedDiv\" [(ngModel)]=\"editingHubspotHtml\" rows=\"8\" class=\"form-control\"></textarea>\n    </div>\n  </div>\n  <div class=\"modal-footer\">\n    <button class=\"btn btn-primary\" (click)=\"saveHubspotHtml(modal)\">Save</button>\n    <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n  </div>\n</ng-template>\n\n\n<ng-template #socialEditModal let-modal>\n  <div class=\"modal-header\">\n    <h5 class=\"modal-title\">Edit Social Links & Company Name</h5>\n    <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n  </div>\n  <div class=\"modal-body\">\n    <div class=\"mb-3\">\n      <label for=\"youtubeUrl\" class=\"form-label\">YouTube URL</label>\n      <input id=\"youtubeUrl\" [(ngModel)]=\"editingYoutubeUrl\" class=\"form-control\" />\n    </div>\n    <div class=\"mb-3\">\n      <label for=\"linkedinUrl\" class=\"form-label\">LinkedIn URL</label>\n      <input id=\"linkedinUrl\" [(ngModel)]=\"editingLinkedInUrl\" class=\"form-control\" />\n    </div>\n    <div class=\"mb-3\">\n      <label for=\"companyName\" class=\"form-label\">Company Name</label>\n      <input id=\"companyName\" [(ngModel)]=\"editingCompanyName\" class=\"form-control\" />\n    </div>\n  </div>\n  <div class=\"modal-footer\">\n    <button class=\"btn btn-primary\" (click)=\"saveSocialLinks(modal)\">Save</button>\n    <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n  </div>\n</ng-template>\n\n\n\n<ng-template #questionsEditModal let-modal>\n  <div class=\"modal-header\">\n    <h5 class=\"modal-title\">Edit Questions</h5>\n    <button type=\"button\" class=\"btn-close\" aria-label=\"Close\" (click)=\"modal.dismiss()\"></button>\n  </div>\n\n  <div class=\"modal-body\">\n    <h4 class=\"mb-3\">Questions Section</h4>\n    <div cdkDropList (cdkDropListDropped)=\"dropQuestions($event)\">\n      <div *ngFor=\"let q of editingQuestions; let i = index\" class=\"border p-3 mb-3\" cdkDrag>\n        <div class=\"row\">\n          <div class=\"col-md-11 mb-2\">\n            <label for=\"questionText{{i}}\" class=\"form-label\">Question</label>\n            <input id=\"questionText{{i}}\" class=\"form-control\" [(ngModel)]=\"q.question\" placeholder=\"Enter question\" />\n          </div>\n          <div class=\"col-md-1 d-flex justify-content-end align-items-start mt-4\">\n            <i class=\"fa fa-bars in-page-bars-icon cursor-move\" cdkDragHandle></i>\n          </div>\n        </div>\n\n        <!-- Options Section -->\n        <div cdkDropList (cdkDropListDropped)=\"dropQuestionOptions(i, $event)\">\n          <div *ngFor=\"let opt of q.options; let j = index\" class=\"row border p-3 mb-2 align-items-center\" cdkDrag>\n            <div class=\"col-md-7 mb-2\">\n              <label for=\"questionOption{{i}}{{j}}\" class=\"form-label\">Option</label>\n              <input id=\"questionOption{{i}}{{j}}\" class=\"form-control\" [(ngModel)]=\"opt.option\" placeholder=\"Enter option\" />\n            </div>\n            <div class=\"col-md-2 d-flex justify-content-between align-items-center mt-4\">\n              <i class=\"fa fa-trash in-page-trash-icon text-danger cursor-pointer\" (click)=\"removeQuestionOption(i, j)\" (keydown.enter)=\"removeQuestionOption(i, j)\" (keydown.enter)=\"removeQuestionOption(i, j)\"></i>\n              <i class=\"fa fa-bars in-page-bars-icon cursor-move\" cdkDragHandle></i>\n            </div>\n          </div>\n        </div>\n\n        <button class=\"btn btn-outline-primary btn-sm mt-2\" (click)=\"addQuestionOption(i)\">+ Add Option</button>\n      </div>\n    </div>\n\n    <button class=\"btn btn-primary mt-3\" (click)=\"addNewQuestion()\">+ Add Question</button>\n  </div>\n\n  <div class=\"modal-footer\">\n    <button class=\"btn btn-secondary\" (click)=\"modal.dismiss()\">Cancel</button>\n    <button class=\"btn btn-primary\" (click)=\"saveQuestions(modal)\">Save</button>\n  </div>\n</ng-template>\n\n\n\n"]}
|