From 6c2df0e94a59c97ee31edcf10984ab643cd3c421 Mon Sep 17 00:00:00 2001
From: Li Yi Yu
Date: Wed, 8 Nov 2023 15:52:30 -0500
Subject: [PATCH] fix(surveys): whitelabel, input radio grouping, and auto text
color bugs (#881)
* whitelabel for multiple questions
* fix multiple radio input grouping bug
* add test and fix auto text color for thank you box
---
src/__tests__/extensions/surveys.js | 35 +++++++++++++++++++++++++++++
src/extensions/surveys.ts | 23 ++++++++++---------
2 files changed, 47 insertions(+), 11 deletions(-)
diff --git a/src/__tests__/extensions/surveys.js b/src/__tests__/extensions/surveys.js
index 414f0060b..1052fb58b 100644
--- a/src/__tests__/extensions/surveys.js
+++ b/src/__tests__/extensions/surveys.js
@@ -191,4 +191,39 @@ describe('survey display logic', () => {
})
expect(uniqueIds.size).toBe(allSelectOptions.length)
})
+
+ test('single choice question type radio input elements are grouped correctly by question index', () => {
+ mockSurveys = [
+ {
+ id: 'testSurvey2',
+ name: 'Test survey 2',
+ appearance: null,
+ questions: [
+ {
+ question: 'Which types of content would you like to see more of?',
+ description: 'This is a question description',
+ type: 'single_choice',
+ choices: ['Tutorials', 'Product Updates', 'Events', 'Other'],
+ },
+ {
+ question: 'Which features do you use the most?',
+ description: 'This is a question description',
+ type: 'single_choice',
+ choices: ['Surveys', 'Feature flags', 'Analytics'],
+ },
+ ],
+ },
+ ]
+ const multipleQuestionSurveyForm = createMultipleQuestionSurvey(mockPostHog, mockSurveys[0])
+ const firstQuestionRadioInputs = multipleQuestionSurveyForm
+ .querySelectorAll('.tab.question-0')[0]
+ .querySelectorAll('input[type=radio]')
+ const mappedInputNames1 = [...firstQuestionRadioInputs].map((input) => input.name)
+ expect(mappedInputNames1.every((name) => name === 'question0')).toBe(true)
+ const secondQuestionRadioInputs = multipleQuestionSurveyForm
+ .querySelectorAll('.tab.question-1')[0]
+ .querySelectorAll('input[type=radio]')
+ const mappedInputNames2 = [...secondQuestionRadioInputs].map((input) => input.name)
+ expect(mappedInputNames2.every((name) => name === 'question1')).toBe(true)
+ })
})
diff --git a/src/extensions/surveys.ts b/src/extensions/surveys.ts
index 05957c6ef..3f6d32922 100644
--- a/src/extensions/surveys.ts
+++ b/src/extensions/surveys.ts
@@ -287,16 +287,14 @@ const style = (id: string, appearance: SurveyAppearance | null) => {
width: 100%;
${positions[appearance?.position || 'right'] || 'right: 30px;'}
}
- .thank-you-message {
- color: ${appearance?.textColor || 'black'};
- }
.thank-you-message-body {
margin-top: 6px;
font-size: 14px;
- color: ${appearance?.descriptionTextColor || '#4b4b52'};
+ background: ${appearance?.backgroundColor || '#eeeded'};
}
.thank-you-message-header {
margin: 10px 0px 0px;
+ background: ${appearance?.backgroundColor || '#eeeded'};
}
.thank-you-message-container .form-submit {
margin-top: 20px;
@@ -429,8 +427,10 @@ export const createThankYouMessage = (survey: Survey) => {
-
- ${survey.appearance?.thankYouMessageDescription || ''}
+
+ ${survey.appearance?.thankYouMessageDescription || ''}
${
survey.appearance?.whiteLabel
@@ -605,8 +605,8 @@ export const createMultipleChoicePopup = (
${surveyQuestionChoices
.map((option, idx) => {
const inputType = singleOrMultiSelect === 'single_choice' ? 'radio' : 'checkbox'
- const singleOrMultiSelectString = `
- ${checkSVG}
`
+ const singleOrMultiSelectString = `
+ ${checkSVG}
`
return singleOrMultiSelectString
})
.join(' ')}
@@ -704,9 +704,10 @@ export const callSurveys = (posthog: PostHog, forceReload: boolean = false) => {
if (surveyPopup) {
addCancelListeners(posthog, surveyPopup, survey.id, survey.name)
if (survey.appearance?.whiteLabel) {
- ;(
- surveyPopup.getElementsByClassName('footer-branding')[0] as HTMLAnchorElement
- ).style.display = 'none'
+ const allBrandingElements = surveyPopup.getElementsByClassName('footer-branding')
+ for (const brandingElement of allBrandingElements) {
+ ;(brandingElement as HTMLAnchorElement).style.display = 'none'
+ }
}
shadow.appendChild(surveyPopup)
}