mirror of
https://github.com/overleaf/overleaf.git
synced 2024-12-27 13:53:44 +00:00
4a8b79080b
* [storybook] Update Storybook to version 8.3.5 * [storybook] Run storybook with `--no-open`. Fixes xdg-utils issue * [storybook] Create decorator for BS3/BS5 * [storybook] Add `bsVersionDecorator` to stories * [storybook] Fix bugs in stories * [storybook] Fixup `useMeta` type. Use `DeepPartial` * [storybook] Fix types GitOrigin-RevId: 48c0f0fefb1ab2d4863ab59051b900b1908a613c
37 lines
1 KiB
TypeScript
37 lines
1 KiB
TypeScript
import type { Meta } from '@storybook/react'
|
|
import _ from 'lodash'
|
|
import { SplitTestContext } from '../../frontend/js/shared/context/split-test-context'
|
|
|
|
export const splitTestsArgTypes = {
|
|
'local-ccy-format-v2': {
|
|
description: 'Use local currency formatting',
|
|
control: { type: 'radio' as const },
|
|
options: ['default', 'enabled'],
|
|
},
|
|
}
|
|
|
|
export const withSplitTests = (
|
|
story: Meta,
|
|
splitTests: (keyof typeof splitTestsArgTypes)[] = []
|
|
): Meta => {
|
|
return {
|
|
...story,
|
|
argTypes: { ...story.argTypes, ..._.pick(splitTestsArgTypes, splitTests) },
|
|
decorators: [
|
|
(Story, { args }) => {
|
|
const splitTestVariants = _.pick(args, splitTests)
|
|
const value = { splitTestVariants, splitTestInfo: {} }
|
|
return (
|
|
<SplitTestContext.Provider value={value}>
|
|
<Story />
|
|
</SplitTestContext.Provider>
|
|
)
|
|
},
|
|
...(story.decorators
|
|
? Array.isArray(story.decorators)
|
|
? story.decorators
|
|
: [story.decorators]
|
|
: []),
|
|
],
|
|
}
|
|
}
|