mirror of
https://github.com/storybookjs/storybook.git
synced 2025-04-07 21:41:46 +08:00
55 lines
1.5 KiB
JavaScript
55 lines
1.5 KiB
JavaScript
'use strict';
|
|
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.default = renderPreview;
|
|
exports.renderError = renderError;
|
|
exports.renderMain = renderMain;
|
|
|
|
var _react = require('react');
|
|
|
|
var _react2 = _interopRequireDefault(_react);
|
|
|
|
var _reactDom = require('react-dom');
|
|
|
|
var _reactDom2 = _interopRequireDefault(_reactDom);
|
|
|
|
var _redboxReact = require('redbox-react');
|
|
|
|
var _redboxReact2 = _interopRequireDefault(_redboxReact);
|
|
|
|
var _storybook = require('../storybook');
|
|
|
|
var _storybook2 = _interopRequireDefault(_storybook);
|
|
|
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
|
|
var rootEl = document.getElementById('root');
|
|
|
|
function renderPreview(data) {
|
|
if (data.error) {
|
|
return renderError(data, data.error);
|
|
}
|
|
|
|
return renderMain(data);
|
|
}
|
|
|
|
function renderError(data, error) {
|
|
// We always need to render redbox in the mainPage if we get an error.
|
|
// Since this is an error, this affects to the main page as well.
|
|
var realError = new Error(error.message);
|
|
realError.stack = error.stack;
|
|
var redBox = _react2.default.createElement(_redboxReact2.default, { error: realError });
|
|
_reactDom2.default.render(redBox, rootEl);
|
|
}
|
|
|
|
function renderMain(data) {
|
|
var selectedKind = data.selectedKind;
|
|
var selectedStory = data.selectedStory;
|
|
|
|
if (selectedKind && selectedStory) {
|
|
var main = _storybook2.default[selectedKind][selectedStory];
|
|
_reactDom2.default.render(main(), rootEl);
|
|
}
|
|
} |