From 49a2822dbed85d514b4939db17f9adc5c2cc7de5 Mon Sep 17 00:00:00 2001 From: Abhijeet Khangarot Date: Tue, 18 Oct 2022 00:32:58 +0530 Subject: [PATCH] console: UI fixes for neon banner in connect db page PR-URL: https://github.com/hasura/graphql-engine-mono/pull/6376 Co-authored-by: Rishichandra Wawhal <27274869+wawhal@users.noreply.github.com> GitOrigin-RevId: 8f2ec961be370097b48b684211606d34dbaa002d --- .../Neon/components/HerokuBanner/Banner.tsx | 18 ++--- .../Neon/components/Neon/NeonBanner.tsx | 8 +- .../CreateDataSource/Neon/index.tsx | 4 +- .../components/NeonOnboarding.tsx | 2 +- .../features/OnboardingWizard/constants.ts | 4 +- .../components/HasuraFamiliaritySurvey.tsx | 9 ++- .../hooks/useFamiliaritySurveyData.ts | 17 ++-- .../HasuraFamiliaritySurvey/hooks/utils.ts | 77 +++++++++++++------ 8 files changed, 88 insertions(+), 51 deletions(-) diff --git a/console/src/components/Services/Data/DataSources/CreateDataSource/Neon/components/HerokuBanner/Banner.tsx b/console/src/components/Services/Data/DataSources/CreateDataSource/Neon/components/HerokuBanner/Banner.tsx index 55d346b5ed6..4c7578d909a 100644 --- a/console/src/components/Services/Data/DataSources/CreateDataSource/Neon/components/HerokuBanner/Banner.tsx +++ b/console/src/components/Services/Data/DataSources/CreateDataSource/Neon/components/HerokuBanner/Banner.tsx @@ -6,16 +6,16 @@ export function HerokuBanner() {
- Heroku free database integration support has been deprecated. + Heroku free database integration support has been deprecated.{' '} + + (Know More) +
- - (Know More) -
); } diff --git a/console/src/components/Services/Data/DataSources/CreateDataSource/Neon/components/Neon/NeonBanner.tsx b/console/src/components/Services/Data/DataSources/CreateDataSource/Neon/components/Neon/NeonBanner.tsx index e18c702b6a6..4d352c595ab 100644 --- a/console/src/components/Services/Data/DataSources/CreateDataSource/Neon/components/Neon/NeonBanner.tsx +++ b/console/src/components/Services/Data/DataSources/CreateDataSource/Neon/components/Neon/NeonBanner.tsx @@ -40,9 +40,6 @@ export function NeonBanner(props: Props) { Free - - Preview -
- Fully managed Postgres with separate storage and compute, that scales - to zero on inactivity and provides seamless scaling and branching. + Modern, developer-friendly Postgres built for the cloud. Neon + separates storage and compute to offer scale to zero and support + database branching.
-
+ {/* Remove skipping survey button, this change is experimental according to analytics data, so only commenting the code */} + {/*
Skip
-
+
*/} ); } diff --git a/console/src/features/Surveys/HasuraFamiliaritySurvey/hooks/useFamiliaritySurveyData.ts b/console/src/features/Surveys/HasuraFamiliaritySurvey/hooks/useFamiliaritySurveyData.ts index 325693464ee..967aab7d322 100644 --- a/console/src/features/Surveys/HasuraFamiliaritySurvey/hooks/useFamiliaritySurveyData.ts +++ b/console/src/features/Surveys/HasuraFamiliaritySurvey/hooks/useFamiliaritySurveyData.ts @@ -1,4 +1,4 @@ -import { useState } from 'react'; +import { useState, useMemo } from 'react'; import { useMutation, useQuery, useQueryClient } from 'react-query'; import { APIError } from '@/hooks/error'; import { IconCardGroupItem } from '@/new-components/IconCardGroup'; @@ -40,14 +40,19 @@ export function useFamiliaritySurveyData(): { }, }); - if (isLoading || isError) { - return emptySurveyResponseData; - } - const surveyQuestionData = data?.data?.survey?.find( surveyInfo => surveyInfo.survey_name === surveyName )?.survey_questions?.[0]; + const surveyOptions = useMemo( + () => mapOptionLabelToDetails(surveyQuestionData), + [surveyQuestionData] + ); + + if (isLoading || isError) { + return emptySurveyResponseData; + } + // skip showing the survey form if survey has no questions if (!surveyQuestionData) { return emptySurveyResponseData; @@ -92,7 +97,7 @@ export function useFamiliaritySurveyData(): { showFamiliaritySurvey, data: { question: surveyQuestionData.question, - options: mapOptionLabelToDetails(surveyQuestionData), + options: surveyOptions, }, onSkip, onOptionClick, diff --git a/console/src/features/Surveys/HasuraFamiliaritySurvey/hooks/utils.ts b/console/src/features/Surveys/HasuraFamiliaritySurvey/hooks/utils.ts index 9479abf1023..f25bd60c8de 100644 --- a/console/src/features/Surveys/HasuraFamiliaritySurvey/hooks/utils.ts +++ b/console/src/features/Surveys/HasuraFamiliaritySurvey/hooks/utils.ts @@ -6,14 +6,61 @@ import { getFamiliaritySurveyOptionDetails, } from './familiaritySurveyOptionDetails'; +type UnroderedOptionArray = { + option: FamiliaritySurveyOptionCode; + id: string; +}[]; + +/** + * Manually enforces the order of options as present in `familiaritySurveyOptionCode` + * array. + */ +// Not removing this function. Although it is not being used currenty due to dynamic product requirements, +// but can again be used in future. +// eslint-disable-next-line @typescript-eslint/no-unused-vars +const manuallyOrderOptions = (unroderedOptionArray: UnroderedOptionArray) => { + const surveyOptionDetails: IconCardGroupItem[] = []; + familiaritySurveyOptionCode.forEach(optionCode => { + const optionData = unroderedOptionArray.find( + optionObj => optionObj.option === optionCode + ); + if (optionData) { + const optionValues = getFamiliaritySurveyOptionDetails( + optionData.id, + optionCode + ); + surveyOptionDetails.push(optionValues); + } + }); + return surveyOptionDetails; +}; + +/** + * Randomly shuffles order of options of survey. + * The method comes from this algorithm: https://stackoverflow.com/a/46545530/7088648 + */ +const randomlyOrderOptions = (unroderedOptionArray: UnroderedOptionArray) => { + const shuffledOptionArray = unroderedOptionArray + .map(value => ({ value, sort: Math.random() })) + .sort((a, b) => a.sort - b.sort) + .map(({ value }) => value); + + const surveyOptionDetails: IconCardGroupItem[] = + shuffledOptionArray.map(option => + getFamiliaritySurveyOptionDetails(option.id, option.option) + ); + + return surveyOptionDetails; +}; + export const mapOptionLabelToDetails = ( - data: SurveysResponseData['data']['survey'][0]['survey_questions'][0] + data?: SurveysResponseData['data']['survey'][0]['survey_questions'][0] ): IconCardGroupItem[] => { - const unroderedOptionArray: { - option: FamiliaritySurveyOptionCode; - id: string; - }[] = []; - data.survey_question_options.forEach(optionData => { + if (!data) return []; + + // Array containing order of options as it comes from backend + const unroderedOptionArray: UnroderedOptionArray = []; + data?.survey_question_options?.forEach(optionData => { const optionLabel = optionData.option.toLowerCase(); if ( @@ -34,20 +81,6 @@ export const mapOptionLabelToDetails = ( }); }); - // enforce order of options to show in the UI - const surveyOptionDetails: IconCardGroupItem[] = []; - familiaritySurveyOptionCode.forEach(optionCode => { - const optionData = unroderedOptionArray.find( - optionObj => optionObj.option === optionCode - ); - if (optionData) { - const optionValues = getFamiliaritySurveyOptionDetails( - optionData.id, - optionCode - ); - surveyOptionDetails.push(optionValues); - } - }); - - return surveyOptionDetails; + // return manuallyOrderOptions(unroderedOptionArray); + return randomlyOrderOptions(unroderedOptionArray); };