feat: manually mirror opencoze's code from bytedance
Change-Id: I09a73aadda978ad9511264a756b2ce51f5761adf
This commit is contained in:
@@ -0,0 +1,3 @@
|
||||
.readonly {
|
||||
pointer-events: none;
|
||||
}
|
||||
49
frontend/packages/workflow/setters/src/enum/enum.tsx
Normal file
49
frontend/packages/workflow/setters/src/enum/enum.tsx
Normal file
@@ -0,0 +1,49 @@
|
||||
/*
|
||||
* Copyright 2025 coze-dev Authors
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
import React from 'react';
|
||||
|
||||
import cx from 'classnames';
|
||||
import { Select } from '@coze-arch/coze-design';
|
||||
|
||||
import type { Setter } from '../types';
|
||||
import type { Options, EnumValue } from './types';
|
||||
|
||||
import styles from './enum.module.less';
|
||||
|
||||
export interface EnumOptions {
|
||||
width?: number | string;
|
||||
placeholder?: string;
|
||||
options: Options;
|
||||
}
|
||||
|
||||
export const Enum: Setter<EnumValue, EnumOptions> = ({
|
||||
value,
|
||||
onChange,
|
||||
readonly,
|
||||
options = [],
|
||||
placeholder,
|
||||
width = '100%',
|
||||
}) => (
|
||||
<Select
|
||||
placeholder={placeholder}
|
||||
className={cx({ [styles.readonly]: readonly })}
|
||||
optionList={options}
|
||||
style={{ width }}
|
||||
value={value}
|
||||
onChange={v => onChange?.(v as EnumValue)}
|
||||
/>
|
||||
);
|
||||
103
frontend/packages/workflow/setters/src/enum/index.stories.tsx
Normal file
103
frontend/packages/workflow/setters/src/enum/index.stories.tsx
Normal file
@@ -0,0 +1,103 @@
|
||||
/*
|
||||
* Copyright 2025 coze-dev Authors
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
import type { StoryObj, Meta } from '@storybook/react';
|
||||
import { useArgs } from '@storybook/preview-api';
|
||||
|
||||
import { Enum } from './enum';
|
||||
|
||||
const meta: Meta<typeof Enum> = {
|
||||
title: 'workflow setters/Enum',
|
||||
component: Enum,
|
||||
tags: ['autodocs'],
|
||||
args: {
|
||||
value: '1',
|
||||
options: [
|
||||
{
|
||||
value: '1',
|
||||
label: 'single',
|
||||
},
|
||||
{
|
||||
value: '2',
|
||||
label: 'batch',
|
||||
},
|
||||
],
|
||||
},
|
||||
render: args => {
|
||||
// eslint-disable-next-line react-hooks/rules-of-hooks -- linter-disable-autofix
|
||||
const [, updateArgs] = useArgs();
|
||||
|
||||
return (
|
||||
<Enum
|
||||
{...args}
|
||||
onChange={newValue => {
|
||||
updateArgs({ ...args, value: newValue });
|
||||
}}
|
||||
/>
|
||||
);
|
||||
},
|
||||
};
|
||||
|
||||
export default meta;
|
||||
|
||||
type Story = StoryObj<typeof Enum>;
|
||||
|
||||
export const Base: Story = {};
|
||||
|
||||
export const Readonly: Story = {
|
||||
args: {
|
||||
value: '1',
|
||||
options: [
|
||||
{
|
||||
value: '1',
|
||||
label: 'single',
|
||||
},
|
||||
{
|
||||
value: '2',
|
||||
label: 'batch',
|
||||
},
|
||||
],
|
||||
readonly: true,
|
||||
},
|
||||
render: args => {
|
||||
// eslint-disable-next-line react-hooks/rules-of-hooks -- linter-disable-autofix
|
||||
const [, updateArgs] = useArgs();
|
||||
const buttonArgs = JSON.parse(JSON.stringify(args));
|
||||
|
||||
buttonArgs.options.mode = 'button';
|
||||
|
||||
return (
|
||||
<>
|
||||
<div style={{ marginBottom: 10 }}>
|
||||
<Enum
|
||||
{...args}
|
||||
onChange={newValue => {
|
||||
updateArgs({ ...args, value: newValue });
|
||||
}}
|
||||
/>
|
||||
</div>
|
||||
<div>
|
||||
<Enum
|
||||
{...buttonArgs}
|
||||
onChange={newValue => {
|
||||
updateArgs({ ...args, value: newValue });
|
||||
}}
|
||||
/>
|
||||
</div>
|
||||
</>
|
||||
);
|
||||
},
|
||||
};
|
||||
37
frontend/packages/workflow/setters/src/enum/index.test.tsx
Normal file
37
frontend/packages/workflow/setters/src/enum/index.test.tsx
Normal file
@@ -0,0 +1,37 @@
|
||||
/*
|
||||
* Copyright 2025 coze-dev Authors
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
import '@testing-library/jest-dom';
|
||||
import { describe, it, expect, vi } from 'vitest';
|
||||
import { render } from '@testing-library/react';
|
||||
|
||||
import { Enum } from './enum';
|
||||
|
||||
const mockProps = {
|
||||
value: '',
|
||||
onChange: vi.fn(),
|
||||
options: [
|
||||
{ label: '选项一', value: 1 },
|
||||
{ label: '选项一', value: 2 },
|
||||
],
|
||||
};
|
||||
|
||||
describe('Enum Setter', () => {
|
||||
it('renders correctly with default props', () => {
|
||||
const { container } = render(<Enum {...mockProps} />);
|
||||
expect(container.firstChild).toBeInTheDocument();
|
||||
});
|
||||
});
|
||||
18
frontend/packages/workflow/setters/src/enum/index.ts
Normal file
18
frontend/packages/workflow/setters/src/enum/index.ts
Normal file
@@ -0,0 +1,18 @@
|
||||
/*
|
||||
* Copyright 2025 coze-dev Authors
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
export { Enum } from './enum';
|
||||
export type { EnumOptions } from './enum';
|
||||
23
frontend/packages/workflow/setters/src/enum/types.ts
Normal file
23
frontend/packages/workflow/setters/src/enum/types.ts
Normal file
@@ -0,0 +1,23 @@
|
||||
/*
|
||||
* Copyright 2025 coze-dev Authors
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
export type EnumValue = string | number;
|
||||
|
||||
export type Options = {
|
||||
label: string;
|
||||
value: EnumValue;
|
||||
disabled?: boolean;
|
||||
}[];
|
||||
Reference in New Issue
Block a user