diff --git a/src-docs/src/views/key_pad_menu/key_pad_menu_example.js b/src-docs/src/views/key_pad_menu/key_pad_menu_example.js index 4f479fff5a17..e2ee7f6b1501 100644 --- a/src-docs/src/views/key_pad_menu/key_pad_menu_example.js +++ b/src-docs/src/views/key_pad_menu/key_pad_menu_example.js @@ -10,6 +10,7 @@ import { EuiKeyPadMenuItem, EuiCallOut, } from '../../../../src/components'; +import { keyPadMenuItemConfig } from './playground'; import KeyPadMenu from './key_pad_menu'; const keyPadMenuSource = require('!!raw-loader!./key_pad_menu'); @@ -141,4 +142,5 @@ export const KeyPadMenuExample = { demo: , }, ], + playground: keyPadMenuItemConfig, }; diff --git a/src-docs/src/views/key_pad_menu/playground.js b/src-docs/src/views/key_pad_menu/playground.js new file mode 100644 index 000000000000..aa0e8e93c559 --- /dev/null +++ b/src-docs/src/views/key_pad_menu/playground.js @@ -0,0 +1,78 @@ +import { PropTypes } from 'react-view'; +import { + EuiKeyPadMenuItem, + EuiIcon, + EuiBetaBadge, +} from '../../../../src/components/'; +import { + propUtilityForPlayground, + iconValidator, +} from '../../services/playground'; +import * as t from '@babel/types'; + +export const keyPadMenuItemConfig = () => { + const docgenInfo = Array.isArray(EuiKeyPadMenuItem.__docgenInfo) + ? EuiKeyPadMenuItem.__docgenInfo[0] + : EuiKeyPadMenuItem.__docgenInfo; + const propsToUse = propUtilityForPlayground(docgenInfo.props); + + propsToUse.onClick = { + ...propsToUse.onClick, + type: PropTypes.Custom, + value: undefined, + custom: { + ...propsToUse.onClick.custom, + use: 'switch', + label: 'Simulate', + }, + }; + propsToUse.label = { + ...propsToUse.label, + type: PropTypes.String, + value: 'Label', + }; + + propsToUse.betaBadgeTooltipContent = { + ...propsToUse.betaBadgeTooltipContent, + type: PropTypes.String, + }; + + propsToUse.betaBadgeIconType = iconValidator(propsToUse.betaBadgeIconType); + + propsToUse.children = { + ...propsToUse.children, + type: PropTypes.ReactNode, + value: '', + hidden: false, + }; + + return { + config: { + componentName: 'EuiKeyPadMenuItem', + props: propsToUse, + scope: { + EuiKeyPadMenuItem, + EuiIcon, + EuiBetaBadge, + }, + imports: { + '@elastic/eui': { + named: ['EuiKeyPadMenuItem', 'EuiIcon', 'EuiBetaBadge'], + }, + }, + customProps: { + onClick: { + generate: val => { + if (!val) return null; + const obj = t.arrowFunctionExpression( + [], + t.blockStatement([]), + false + ); + return obj; + }, + }, + }, + }, + }; +};