From 582a52b95601e2d1dc0ce99e9bf264824b1e8c1f Mon Sep 17 00:00:00 2001 From: vanilla-wave Date: Wed, 25 Dec 2024 17:58:20 +0100 Subject: [PATCH] feat(onboarding): add customDefaultState option --- src/controller.ts | 6 ++++-- src/tests/controller.test.ts | 40 ++++++++++++++++++++++++++++++++++++ src/tests/utils.ts | 12 +++++++++-- src/types.ts | 1 + 4 files changed, 55 insertions(+), 4 deletions(-) diff --git a/src/controller.ts b/src/controller.ts index 8931fae..df2ef83 100644 --- a/src/controller.ts +++ b/src/controller.ts @@ -24,13 +24,14 @@ let instanceCounter = 0; const defaultLoggerOptions = { context: 'Onboarding', }; -const getDefaultBaseState = (): BaseState => ({ +const base = { availablePresets: [], activePresets: [], suggestedPresets: [], wizardState: 'hidden' as const, enabled: false, -}); +}; +const getDefaultBaseState = (): BaseState => base; const getDefaultProgressState = () => ({ presetPassedSteps: {}, @@ -93,6 +94,7 @@ export class Controller { + it('can use empty custom state', () => { + const options = getOptions(); + // @ts-ignore + options.baseState = {}; + options.customDefaultState = {}; + + const controller = new Controller(options); + expect(controller.state.base).toEqual({ + wizardState: 'hidden', + enabled: false, + activePresets: [], + availablePresets: [], + suggestedPresets: [], + }); + }); + + it('can apply custom state', () => { + const options = getOptions(); + options.customDefaultState = { + wizardState: 'visible', + enabled: true, + }; + + const controller = new Controller(options); + expect(controller.state.base.wizardState).toBe('visible'); + expect(controller.state.base.enabled).toBe(true); + }); + + it('has saved value -> dont apply custom default', () => { + const options = getOptions({wizardState: 'collapsed'}); + options.customDefaultState = { + wizardState: 'visible', + }; + + const controller = new Controller(options); + expect(controller.state.base.wizardState).toBe('collapsed'); + }); +}); diff --git a/src/tests/utils.ts b/src/tests/utils.ts index 8f18637..179d31a 100644 --- a/src/tests/utils.ts +++ b/src/tests/utils.ts @@ -1,4 +1,11 @@ -import {BaseState, CombinedPreset, OnboardingPlugin, PresetStep, ProgressState} from '../types'; +import { + BaseState, + CombinedPreset, + InitOptions, + OnboardingPlugin, + PresetStep, + ProgressState, +} from '../types'; import {PromoPresetsPlugin} from '../plugins/promo-presets'; export const getOptions = ( @@ -66,7 +73,8 @@ export const getOptions = ( }, }, plugins: [] as OnboardingPlugin[], - }; + customDefaultState: {} as Partial, + } satisfies InitOptions; }; export const getOptionsWithCombined = ( diff --git a/src/types.ts b/src/types.ts index 39d11a0..57d5aec 100644 --- a/src/types.ts +++ b/src/types.ts @@ -142,6 +142,7 @@ export type InitOptions; plugins?: OnboardingPlugin[]; hooks?: { [K in keyof EventsMap]?: (