mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-06 15:31:16 +08:00
51 lines
1.1 KiB
TypeScript
51 lines
1.1 KiB
TypeScript
import { document, Node } from 'global';
|
|
import styles from './styles';
|
|
|
|
const INNER_ID = 'sb-addon-centered-inner';
|
|
const WRAPPER_ID = 'sb-addon-centered-wrapper';
|
|
|
|
function getOrCreate(id: string, style: Partial<CSSStyleDeclaration>): HTMLDivElement {
|
|
const elementOnDom = document.getElementById(id);
|
|
|
|
if (elementOnDom) {
|
|
return elementOnDom;
|
|
}
|
|
|
|
const element = document.createElement('div') as HTMLDivElement;
|
|
element.setAttribute('id', id);
|
|
Object.assign(element.style, style);
|
|
|
|
return element;
|
|
}
|
|
|
|
function getInnerDiv() {
|
|
return getOrCreate(INNER_ID, styles.innerStyle);
|
|
}
|
|
|
|
function getWrapperDiv() {
|
|
return getOrCreate(WRAPPER_ID, styles.style);
|
|
}
|
|
|
|
export default function(storyFn: () => any) {
|
|
const inner = getInnerDiv();
|
|
const wrapper = getWrapperDiv();
|
|
wrapper.appendChild(inner);
|
|
|
|
const element = storyFn();
|
|
|
|
if (typeof element === 'string') {
|
|
inner.innerHTML = element;
|
|
} else if (element instanceof Node) {
|
|
inner.innerHTML = '';
|
|
inner.appendChild(element);
|
|
} else {
|
|
return element;
|
|
}
|
|
|
|
return wrapper;
|
|
}
|
|
|
|
if (module && module.hot && module.hot.decline) {
|
|
module.hot.decline();
|
|
}
|