import {Fragment} from 'react';
import styled from '@emotion/styled';
import ExternalLink from 'sentry/components/links/externalLink';
import JSXNode from 'sentry/components/stories/jsxNode';
import SideBySide from 'sentry/components/stories/sideBySide';
import {t, tct} from 'sentry/locale';
import storyBook from 'sentry/stories/storyBook';
import {WidgetFrame} from 'sentry/views/dashboards/widgets/common/widgetFrame';
export default storyBook(WidgetFrame, story => {
story('Getting Started', () => {
return (
is a container element used for all widgets in
the Dashboards Widget Platform. It's mostly an under-the-hood component, but it
can be useful to emulate widget-like states, like widget cards with actions.
);
});
story('Layout', () => {
return (
supports a few basic props that control its
content. This includes a title, a description, and the children
.
The title is automatically wrapped in a tooltip if it does not fit.
The description can be a React element, but don't go overboard. Stick to
strings, or tct
output consisting of text and links.
{t('documentation')}
),
})}
/>
);
});
story('Warnings', () => {
return (
supports a warnings
prop. If
supplied, it shows a small warning icon next to the title. Hovering over the
icon shows the warnings.
);
});
story('Badge', () => {
return (
supports a badgeProps
prop. If
passed, aBadge
component with the relevant props appears in the
header. Note: Avoid using this! This is mostly used as an internal feature, for
diagnosing widget state at a glance. We might remove this feature very soon.{' '}
Especially avoid multiple badges.
);
});
story('Action Menu', () => {
return (
supports an action menu. If only one action is
passed, the single action is rendered as a small button. If multiple actions are
passed, they are grouped into a dropdown menu. Menu actions appear on hover or
keyboard focus. They can be disabled with the actionsDisabled
prop,
and supplemented with an optional actionsMessage
prop that adds a
tooltip.
{
// eslint-disable-next-line no-console
console.log('See more!');
},
},
]}
/>
{
// eslint-disable-next-line no-console
console.log('See more!');
},
},
]}
/>
{
// eslint-disable-next-line no-console
console.log('See more!');
},
},
{
key: 'see-less',
label: t('See Less'),
onAction: () => {
// eslint-disable-next-line no-console
console.log('See less!');
},
},
]}
/>
{
// eslint-disable-next-line no-console
console.log('See more!');
},
},
{
key: 'see-less',
label: t('See Less'),
onAction: () => {
// eslint-disable-next-line no-console
console.log('See less!');
},
},
]}
/>
);
});
story('Full Screen View Button', () => {
return (
supports a onOpenFullScreenView
{' '}
prop. This is a special action that always appears as an individual icon to the
right of the normal actions.
{}} />
);
});
});
const NormalWidget = styled('div')`
width: 250px;
height: 100px;
`;