Skip to content

Commit

Permalink
feat(onboarding): add customDefaultState option
Browse files Browse the repository at this point in the history
  • Loading branch information
vanilla-wave committed Jan 13, 2025
1 parent e2ea731 commit 582a52b
Show file tree
Hide file tree
Showing 4 changed files with 55 additions and 4 deletions.
6 changes: 4 additions & 2 deletions src/controller.ts
Original file line number Diff line number Diff line change
Expand Up @@ -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: {},
Expand Down Expand Up @@ -93,6 +94,7 @@ export class Controller<HintParams, Presets extends string, Steps extends string
this.state = {
base: {
...getDefaultBaseState(),
...options.customDefaultState,
...options.baseState,
},
};
Expand Down
40 changes: 40 additions & 0 deletions src/tests/controller.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -574,3 +574,43 @@ describe('goNextStep and goNextStep', function () {
});
});
});

describe('custom default state', () => {
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');
});
});
12 changes: 10 additions & 2 deletions src/tests/utils.ts
Original file line number Diff line number Diff line change
@@ -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 = (
Expand Down Expand Up @@ -66,7 +73,8 @@ export const getOptions = (
},
},
plugins: [] as OnboardingPlugin[],
};
customDefaultState: {} as Partial<BaseState>,
} satisfies InitOptions<any, any, any>;
};

export const getOptionsWithCombined = (
Expand Down
1 change: 1 addition & 0 deletions src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -142,6 +142,7 @@ export type InitOptions<HintParams, Presets extends string, Steps extends string
logger?: LoggerOptions;
ignoreUnknownPresets?: boolean;
debugMode?: boolean;
customDefaultState?: Partial<BaseState>;
plugins?: OnboardingPlugin[];
hooks?: {
[K in keyof EventsMap<HintParams, Presets, Steps>]?: (
Expand Down

0 comments on commit 582a52b

Please sign in to comment.