112 lines
3.6 KiB
TypeScript
112 lines
3.6 KiB
TypeScript
import './src/styles/main.css';
|
|
import * as React from 'react';
|
|
import { MDXProvider } from '@mdx-js/react';
|
|
|
|
const SpoilerComponent = ({ children, title }) => {
|
|
const [show, setShow] = React.useState(false);
|
|
|
|
return (
|
|
<div className={`border border-gray-200 rounded-md`}>
|
|
<p
|
|
className="p-4 flex items-start"
|
|
onClick={e => setShow(!show)}
|
|
style={{ marginBottom: 0 }}
|
|
>
|
|
{show && (
|
|
<svg
|
|
className="h-6 w-6 text-gray-500 mr-4"
|
|
fill="currentColor"
|
|
viewBox="0 0 20 20"
|
|
>
|
|
<path
|
|
fillRule="evenodd"
|
|
d="M5.293 7.293a1 1 0 011.414 0L10 10.586l3.293-3.293a1 1 0 111.414 1.414l-4 4a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414z"
|
|
clipRule="evenodd"
|
|
/>
|
|
</svg>
|
|
)}
|
|
{!show && (
|
|
<svg
|
|
className="h-6 w-6 text-gray-500 mr-4"
|
|
fill="currentColor"
|
|
viewBox="0 0 20 20"
|
|
>
|
|
<path
|
|
fillRule="evenodd"
|
|
d="M7.293 14.707a1 1 0 010-1.414L10.586 10 7.293 6.707a1 1 0 011.414-1.414l4 4a1 1 0 010 1.414l-4 4a1 1 0 01-1.414 0z"
|
|
clipRule="evenodd"
|
|
/>
|
|
</svg>
|
|
)}
|
|
{title}
|
|
</p>
|
|
|
|
{show && <div className="p-4 pt-0 spoiler-body">{children}</div>}
|
|
</div>
|
|
);
|
|
};
|
|
|
|
const components = {
|
|
wrapper: ({ excerptOnly = false, children }) => {
|
|
if (excerptOnly) {
|
|
for (let child of children) {
|
|
if (child.props.originalType === 'module-excerpt') return child;
|
|
}
|
|
return null;
|
|
}
|
|
|
|
return children;
|
|
},
|
|
'module-excerpt': props => <div {...props} />,
|
|
spoiler: SpoilerComponent,
|
|
'info-block': ({
|
|
children,
|
|
title,
|
|
}: {
|
|
children: React.ReactNode;
|
|
title: string;
|
|
}) => (
|
|
<div className="rounded-md bg-blue-50 p-4 mb-12 info-block">
|
|
<div className="flex">
|
|
<div className="flex-shrink-0">
|
|
<svg
|
|
className="h-5 w-5 text-blue-400"
|
|
fill="currentColor"
|
|
viewBox="0 0 20 20"
|
|
>
|
|
<path
|
|
fillRule="evenodd"
|
|
d="M18 10a8 8 0 11-16 0 8 8 0 0116 0zm-7-4a1 1 0 11-2 0 1 1 0 012 0zM9 9a1 1 0 000 2v3a1 1 0 001 1h1a1 1 0 100-2v-3a1 1 0 00-1-1H9z"
|
|
clipRule="evenodd"
|
|
/>
|
|
</svg>
|
|
</div>
|
|
<div className="ml-3">
|
|
<h3 className="info-block__heading">{title}</h3>
|
|
<div className="info-block__body">{children}</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
),
|
|
'optional-content': ({
|
|
children,
|
|
title,
|
|
}: {
|
|
children: React.ReactNode;
|
|
title?: string;
|
|
}) => (
|
|
<div className="bg-white overflow-hidden shadow rounded-lg border border-purple-400 my-2">
|
|
<div className="p-4 flex items-center font-medium text-purple-800 bg-purple-50">
|
|
<svg className="h-6 w-6 mr-3" fill="currentColor" viewBox="0 0 20 20">
|
|
<path d="M11 3a1 1 0 10-2 0v1a1 1 0 102 0V3zM15.657 5.757a1 1 0 00-1.414-1.414l-.707.707a1 1 0 001.414 1.414l.707-.707zM18 10a1 1 0 01-1 1h-1a1 1 0 110-2h1a1 1 0 011 1zM5.05 6.464A1 1 0 106.464 5.05l-.707-.707a1 1 0 00-1.414 1.414l.707.707zM5 10a1 1 0 01-1 1H3a1 1 0 110-2h1a1 1 0 011 1zM8 16v-1h4v1a2 2 0 11-4 0zM12 14c.015-.34.208-.646.477-.859a4 4 0 10-4.954 0c.27.213.462.519.476.859h4.002z" />
|
|
</svg>
|
|
Optional{title ? `: ${title}` : ''}
|
|
</div>
|
|
<div className="px-4 pt-5 pb-2 sm:p-6 sm:pb-2">{children}</div>
|
|
</div>
|
|
),
|
|
};
|
|
|
|
export const wrapRootElement = ({ element }) => (
|
|
<MDXProvider components={components}>{element}</MDXProvider>
|
|
);
|