-
Notifications
You must be signed in to change notification settings - Fork 1.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
test: Add Stories for new control components
- Loading branch information
Showing
5 changed files
with
303 additions
and
13 deletions.
There are no files selected for viewing
141 changes: 141 additions & 0 deletions
141
web/packages/shared/components/Controls/MultiselectMenu.story.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,141 @@ | ||
/** | ||
* Teleport | ||
* Copyright (C) 2024 Gravitational, Inc. | ||
* | ||
* This program is free software: you can redistribute it and/or modify | ||
* it under the terms of the GNU Affero General Public License as published by | ||
* the Free Software Foundation, either version 3 of the License, or | ||
* (at your option) any later version. | ||
* | ||
* This program is distributed in the hope that it will be useful, | ||
* but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
* GNU Affero General Public License for more details. | ||
* | ||
* You should have received a copy of the GNU Affero General Public License | ||
* along with this program. If not, see <http://www.gnu.org/licenses/>. | ||
*/ | ||
|
||
import React, { useState } from 'react'; | ||
import { Flex } from 'design'; | ||
|
||
import { MultiselectMenu } from './MultiselectMenu'; | ||
|
||
import type { Meta, StoryFn, StoryObj } from '@storybook/react'; | ||
|
||
type OptionValue = `option-${number}`; | ||
|
||
const options: { | ||
value: OptionValue; | ||
label: string | React.ReactNode; | ||
disabled?: boolean; | ||
disabledTooltip?: string; | ||
}[] = [ | ||
{ value: 'option-1', label: 'Option 1' }, | ||
{ value: 'option-2', label: 'Option 2' }, | ||
{ value: 'option-3', label: 'Option 3' }, | ||
{ value: 'option-4', label: 'Option 4' }, | ||
]; | ||
|
||
const optionsWithCustomLabels: typeof options = [ | ||
{ | ||
value: 'option-1', | ||
label: <strong>Bold Option 1</strong>, | ||
}, | ||
{ | ||
value: 'option-3', | ||
label: <em>Italic Option 3</em>, | ||
}, | ||
]; | ||
|
||
export default { | ||
title: 'Shared/Controls/MultiselectMenu', | ||
component: MultiselectMenu, | ||
argTypes: { | ||
buffered: { | ||
control: { type: 'boolean' }, | ||
description: 'Buffer selections until "Apply" is clicked', | ||
table: { defaultValue: { summary: 'false' } }, | ||
}, | ||
showIndicator: { | ||
control: { type: 'boolean' }, | ||
description: 'Show indicator when there are selected options', | ||
table: { defaultValue: { summary: 'true' } }, | ||
}, | ||
showSelectControls: { | ||
control: { type: 'boolean' }, | ||
description: 'Show select controls (Select All/Select None)', | ||
table: { defaultValue: { summary: 'true' } }, | ||
}, | ||
label: { | ||
control: { type: 'text' }, | ||
description: 'Label for the multiselect', | ||
}, | ||
tooltip: { | ||
control: { type: 'text' }, | ||
description: 'Tooltip for the label', | ||
}, | ||
selected: { | ||
control: false, | ||
description: 'Currently selected options', | ||
table: { type: { summary: 'T[]' } }, | ||
}, | ||
onChange: { | ||
control: false, | ||
description: 'Callback when selection changes', | ||
table: { type: { summary: 'selected: T[]' } }, | ||
}, | ||
options: { | ||
control: false, | ||
description: 'Options to select from', | ||
table: { | ||
type: { | ||
summary: | ||
'Array<{ value: T; label: string | ReactNode; disabled?: boolean; disabledTooltip?: string; }>', | ||
}, | ||
}, | ||
}, | ||
}, | ||
args: { | ||
label: 'Select Options', | ||
tooltip: 'Choose multiple options', | ||
buffered: false, | ||
showIndicator: true, | ||
showSelectControls: true, | ||
}, | ||
parameters: { controls: { expanded: true, exclude: ['userContext'] } }, | ||
render: (args => { | ||
const [selected, setSelected] = useState<string[]>([]); | ||
return ( | ||
<Flex alignItems="center" minHeight="100px"> | ||
<MultiselectMenu {...args} selected={selected} onChange={setSelected} /> | ||
</Flex> | ||
); | ||
}) satisfies StoryFn<typeof MultiselectMenu<OptionValue>>, | ||
} satisfies Meta<typeof MultiselectMenu<OptionValue>>; | ||
|
||
type Story = StoryObj<typeof MultiselectMenu<OptionValue>>; | ||
|
||
const Default = { | ||
args: { options }, | ||
} satisfies Story; | ||
|
||
const WithCustomLabels = { | ||
args: { options: optionsWithCustomLabels }, | ||
} satisfies Story; | ||
|
||
const WithDisabledOption = { | ||
args: { | ||
options: [ | ||
...options, | ||
{ | ||
value: 'option-5', | ||
label: 'Option 5', | ||
disabled: true, | ||
disabledTooltip: 'Option is disabled', | ||
}, | ||
], | ||
}, | ||
} satisfies Story; | ||
|
||
export { Default, WithCustomLabels, WithDisabledOption }; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
83 changes: 83 additions & 0 deletions
83
web/packages/shared/components/Controls/SortMenu.story.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,83 @@ | ||
/** | ||
* Teleport | ||
* Copyright (C) 2024 Gravitational, Inc. | ||
* | ||
* This program is free software: you can redistribute it and/or modify | ||
* it under the terms of the GNU Affero General Public License as published by | ||
* the Free Software Foundation, either version 3 of the License, or | ||
* (at your option) any later version. | ||
* | ||
* This program is distributed in the hope that it will be useful, | ||
* but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
* GNU Affero General Public License for more details. | ||
* | ||
* You should have received a copy of the GNU Affero General Public License | ||
* along with this program. If not, see <http://www.gnu.org/licenses/>. | ||
*/ | ||
|
||
import React, { useState } from 'react'; | ||
import { Flex } from 'design'; | ||
|
||
import { SortMenu } from './SortMenu'; | ||
|
||
import type { Meta, StoryFn, StoryObj } from '@storybook/react'; | ||
|
||
export default { | ||
title: 'Shared/Controls/SortMenu', | ||
component: SortMenu<any>, | ||
argTypes: { | ||
current: { | ||
control: false, | ||
description: 'Current sort', | ||
table: { | ||
type: { | ||
summary: | ||
"Array<{ fieldName: Exclude<keyof T, symbol | number>; dir: 'ASC' | 'DESC'>", | ||
}, | ||
}, | ||
}, | ||
fields: { | ||
control: false, | ||
description: 'Fields to sort by', | ||
table: { | ||
type: { | ||
summary: | ||
'{ value: Exclude<keyof T, symbol | number>; label: string }[]', | ||
}, | ||
}, | ||
}, | ||
onChange: { | ||
control: false, | ||
description: 'Callback when fieldName or dir is changed', | ||
table: { | ||
type: { | ||
summary: | ||
"(value: { fieldName: Exclude<keyof T, symbol | number>; dir: 'ASC' | 'DESC' }) => void", | ||
}, | ||
}, | ||
}, | ||
}, | ||
args: { | ||
current: { fieldName: 'name', dir: 'ASC' }, | ||
fields: [ | ||
{ value: 'name', label: 'Name' }, | ||
{ value: 'created', label: 'Created' }, | ||
{ value: 'updated', label: 'Updated' }, | ||
], | ||
}, | ||
parameters: { controls: { expanded: true, exclude: ['userContext'] } }, | ||
} satisfies Meta<typeof SortMenu<any>>; | ||
|
||
const Default = { | ||
render: (({ current, fields }) => { | ||
const [sort, setSort] = useState(current); | ||
return ( | ||
<Flex alignItems="center" minHeight="100px"> | ||
<SortMenu current={sort} fields={fields} onChange={setSort} /> | ||
</Flex> | ||
); | ||
}) satisfies StoryFn<typeof SortMenu>, | ||
} satisfies StoryObj<typeof SortMenu>; | ||
|
||
export { Default as SortMenu }; |
61 changes: 61 additions & 0 deletions
61
web/packages/shared/components/Controls/ViewModeSwitch.story.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
/** | ||
* Teleport | ||
* Copyright (C) 2024 Gravitational, Inc. | ||
* | ||
* This program is free software: you can redistribute it and/or modify | ||
* it under the terms of the GNU Affero General Public License as published by | ||
* the Free Software Foundation, either version 3 of the License, or | ||
* (at your option) any later version. | ||
* | ||
* This program is distributed in the hope that it will be useful, | ||
* but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
* GNU Affero General Public License for more details. | ||
* | ||
* You should have received a copy of the GNU Affero General Public License | ||
* along with this program. If not, see <http://www.gnu.org/licenses/>. | ||
*/ | ||
|
||
import React, { useState } from 'react'; | ||
import { Flex } from 'design'; | ||
|
||
import { ViewMode } from 'gen-proto-ts/teleport/userpreferences/v1/unified_resource_preferences_pb'; | ||
|
||
import { ViewModeSwitch } from './ViewModeSwitch'; | ||
|
||
import type { Meta, StoryFn, StoryObj } from '@storybook/react'; | ||
|
||
export default { | ||
title: 'Shared/Controls/ViewModeSwitch', | ||
component: ViewModeSwitch, | ||
argTypes: { | ||
currentViewMode: { | ||
control: { type: 'radio', options: [ViewMode.CARD, ViewMode.LIST] }, | ||
description: 'Current view mode', | ||
table: { defaultValue: { summary: ViewMode.CARD.toString() } }, | ||
}, | ||
setCurrentViewMode: { | ||
control: false, | ||
description: 'Callback to set current view mode', | ||
table: { type: { summary: '(newViewMode: ViewMode) => void' } }, | ||
}, | ||
}, | ||
args: { currentViewMode: ViewMode.CARD }, | ||
parameters: { controls: { expanded: true, exclude: ['userContext'] } }, | ||
} satisfies Meta<typeof ViewModeSwitch>; | ||
|
||
const Default = { | ||
render: (({ currentViewMode }) => { | ||
const [viewMode, setViewMode] = useState(currentViewMode); | ||
return ( | ||
<Flex alignItems="center" minHeight="100px"> | ||
<ViewModeSwitch | ||
currentViewMode={viewMode} | ||
setCurrentViewMode={setViewMode} | ||
/> | ||
</Flex> | ||
); | ||
}) satisfies StoryFn<typeof ViewModeSwitch>, | ||
} satisfies StoryObj<typeof ViewModeSwitch>; | ||
|
||
export { Default as ViewModeSwitch }; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters