import React, { MouseEvent } from 'react'; import { storiesOf } from '@storybook/react'; import { action } from '@storybook/addon-actions'; import { withInfo } from "@storybook/addon-info"; import { withKnobs, number, boolean, select } from "@storybook/addon-knobs"; import { addReadme } from 'storybook-readme'; import ConsumeListView from '@/components/Payment/ConsumeListView'; import ConsumeListViewDoc from '@components/Payment/Common/ConsumeListView/README.md'; import PayPlatFormOptions, { PAY_CHANNEL } from '@/components/Payment/PayPlatformOptions'; import PayPlatFormOptionsDoc from '@components/Payment/Common/PayPlatformOptions/README.md'; import PriceOptions from '@/components/Payment/PriceOptions'; import PriceOptionsDoc from '@components/Payment/Common/PriceOptions/README.md'; import WaitPayInfoView from '@/components/Payment/WaitPayInfoView'; import WaitPayInfoViewDoc from '@components/Payment/Common/WaitPayInfoView/README.md'; const stories = storiesOf('Payment', module); stories.addDecorator((storyFn) =>
{storyFn()}
) stories.addDecorator(withKnobs); stories.addDecorator(withInfo); stories.addDecorator(addReadme); const consumeData = [ { "id": 69, "consume_id": "20190919120838283305719", "goods_id": 0, "goods_type": 4, "num": 9, "user_id": 71082, "user_nickname": "lydia", "user_avatar": "https://links123-images.oss-cn-hangzhou.aliyuncs.com/avatar/2018/8/26/10adf03c70fb128d546e0d40fea77047.jpg", "to_user_id": 1, "to_user_nickname": "", "to_user_avatar": "", "bill_price": 900, "ref_id": 0, "business_type": 3, "created_at": 1568894918, "updated_at": 1568894918 }, { "id": 32, "consume_id": "20190802095658644217897", "goods_id": 2, "goods_type": 1, "num": 8, "user_id": 2, "user_nickname": "jim", "user_avatar": "https://links123-images.oss-cn-hangzhou.aliyuncs.com/avatar/2018/4/6/7d4948f6e9a66789f776b0c69c8d51d9.png", "to_user_id": 1, "to_user_nickname": "", "to_user_avatar": "", "bill_price": 800, "ref_id": 0, "business_type": 3, "created_at": 1564739818, "updated_at": 1564739818 }, { "id": 46, "consume_id": "20190819131433734083448", "goods_id": 2, "goods_type": 1, "num": 7, "user_id": 5, "user_nickname": "Chris", "user_avatar": "https://links123-images.oss-cn-hangzhou.aliyuncs.com/avatar/2019/6/12/a1aec180fbb727cc693c7a2f14812dac.jpg", "to_user_id": 1, "to_user_nickname": "", "to_user_avatar": "", "bill_price": 700, "ref_id": 0, "business_type": 3, "created_at": 1566220473, "updated_at": 1566220473 }, { "id": 20, "consume_id": "20190729154830503859957", "goods_id": 2, "goods_type": 1, "num": 5, "user_id": 217, "user_nickname": "Paul", "user_avatar": "https://links123-images.oss-cn-hangzhou.aliyuncs.com/avatar/2019/12/4/b9221e3176d92c349affc3633a0ec7bf.jpg", "to_user_id": 1, "to_user_nickname": "", "to_user_avatar": "", "bill_price": 500, "ref_id": 0, "business_type": 3, "created_at": 1564415310, "updated_at": 1564415310 }, { "id": 127, "consume_id": "20191204115927765695546", "goods_id": 2, "goods_type": 1, "num": 1, "user_id": 45, "user_nickname": "Adam", "user_avatar": "https://links123-images.oss-cn-hangzhou.aliyuncs.com/avatar/2019/6/12/cbc5208e3a8aba6fcfc2cef2a4d5151d.jpg", "to_user_id": 1, "to_user_nickname": "", "to_user_avatar": "", "bill_price": 100, "ref_id": 0, "business_type": 3, "created_at": 1575460767, "updated_at": 1575460767 }, { "id": 71, "consume_id": "20190922010906704921621", "goods_id": 0, "goods_type": 4, "num": 1, "user_id": 22428, "user_nickname": "简单生活", "user_avatar": "https://links123-images.oss-cn-hangzhou.aliyuncs.com/avatar/2019/9/22/27886bb4305ab56adc0b20018b975dc5.jpg", "to_user_id": 1, "to_user_nickname": "", "to_user_avatar": "", "bill_price": 100, "ref_id": 0, "business_type": 3, "created_at": 1569114546, "updated_at": 1569114546 }, { "id": 70, "consume_id": "20190920014118872836942", "goods_id": 0, "goods_type": 4, "num": 1, "user_id": 70406, "user_nickname": "vicky", "user_avatar": "https://links123-images.oss-cn-hangzhou.aliyuncs.com/avatar/2019/5/5/8a0db661919f926501192eccf13740f1jpg", "to_user_id": 1, "to_user_nickname": "", "to_user_avatar": "", "bill_price": 100, "ref_id": 0, "business_type": 3, "created_at": 1568943678, "updated_at": 1568943678 }, { "id": 68, "consume_id": "20190917224355248346157", "goods_id": 0, "goods_type": 4, "num": 1, "user_id": 71603, "user_nickname": "Slate", "user_avatar": "https://links123-images.oss-cn-hangzhou.aliyuncs.com/avatar/2019/10/19/1cb9f491e90258ba91a189027ef774b7.jpg", "to_user_id": 1, "to_user_nickname": "", "to_user_avatar": "", "bill_price": 100, "ref_id": 0, "business_type": 3, "created_at": 1568760235, "updated_at": 1568760235 } ]; stories.add( 'ConsumeListView', () => { const [toggle, setToggle] = React.useState(false); return setToggle(!toggle)} onConsumeItemClick={(e: MouseEvent, clickData: any) => { console.log(clickData); }} dataSource={consumeData} listLength={consumeData.length} showLength={number("showLength", 5)} /> }, { info: { inline: true, text: ` ~~~typescript setToggle(!toggle)} dataSource={consumeData} listLength={consumeData.length} showLength={number("showLength", 5)} /> ~~~ `, // TableComponent: (props: TableComponentOptionProps) => { // const { propDefinitions } = props; // return propDefinitions.map(i => { // return ( //
// {i.defaultValue} //
// ) // }) // }, source: false, maxPropStringLength: 500, }, notes: 'A very simple example of addon notes', readme: { sidebar: ConsumeListViewDoc, } } ); stories.add( 'PayPlatFormOptions', () => { const [payChannel, setPayChannel] = React.useState(PAY_CHANNEL.PAYPAL); return ( { action(`PayItemChange: ${value}`); setPayChannel(value); }} isMobile={boolean("isMobile", false)} size={select("size", { Small: "small", Normal: "normal", Large: "large"}, "normal")} withTitle={boolean("withTitle", false)} locale={select("locale", { ZH: 'zh', EN: 'en' }, "zh")} /> ) }, { info: { inline: true, text: ``, source: false, maxPropStringLength: 500, }, notes: 'A very simple example of addon notes', readme: { sidebar: PayPlatFormOptionsDoc, } } ); stories.add( 'PriceOptions', () => { const [price, setPrice] = React.useState(0); const refInput = React.useRef(null); return ( setPrice(v)} size={select("size", { Small: "small", Normal: "normal", Large: "large"}, "normal")} withTitle={boolean("withTitle", false)} focusScroll={boolean("focusScroll", false)} inputRef={refInput} /> ) }, { info: { inline: true, text: ``, source: false, maxPropStringLength: 500, }, notes: 'A very simple example of addon notes', readme: { sidebar: PriceOptionsDoc, } } ) stories.add( 'WaitPayInfoView', () => { return ( ) }, { info: { inline: true, text: ``, source: false, maxPropStringLength: 500 }, notes: 'A very simple example of addon notes', readme: { sidebar: WaitPayInfoViewDoc, } } )