lib/ui/src/components/preview/tools/copy.tsx
import global from 'global';
import React from 'react';
import copy from 'copy-to-clipboard';
import { getStoryHref, IconButton, Icons } from '@storybook/components';
import { Consumer, Combo } from '@storybook/api';
import { Addon } from '@storybook/addons';
const { PREVIEW_URL } = global;
const copyMapper = ({ state }: Combo) => {
const { storyId, refId, refs } = state;
const ref = refs[refId];
return {
refId,
baseUrl: ref ? `${ref.url}/iframe.html` : (PREVIEW_URL as string) || 'iframe.html',
storyId,
queryParams: state.customQueryParams,
};
};
export const copyTool: Addon = {
title: 'copy',
id: 'copy',
match: ({ viewMode }) => viewMode === 'story',
render: () => (
<Consumer filter={copyMapper}>
{({ baseUrl, storyId, queryParams }) =>
storyId ? (
<IconButton
key="copy"
onClick={() => copy(getStoryHref(baseUrl, storyId, queryParams))}
title="Copy canvas link"
>
<Icons icon="link" />
</IconButton>
) : null
}
</Consumer>
),
};