storybook-addon-module-mock
Version:
[](https://www.npmjs.com/package/storybook-addon-module-mock) [](https://www.npmjs.com/package/storybook-addon-module-mock) [ • 3.74 kB
JavaScript
;
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
var ownKeys = function(o) {
ownKeys = Object.getOwnPropertyNames || function (o) {
var ar = [];
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
return ar;
};
return ownKeys(o);
};
return function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
__setModuleDefault(result, mod);
return result;
};
})();
Object.defineProperty(exports, "__esModule", { value: true });
const react_1 = __importStar(require("react"));
const react_json_tree_1 = require("react-json-tree");
const components_1 = require("storybook/internal/components");
const manager_api_1 = require("storybook/manager-api");
const types_js_1 = require("./types.js");
const theme = {
scheme: 'custom',
base00: '#ffffff',
base01: '#aeb8c4',
base02: '#9b9b9b',
base03: '#9b9a9a',
base04: '#909090',
base05: '#1e1e1e',
base06: '#efefef',
base07: '#9e9e9e',
base08: '#f44336',
base09: '#ff9800',
base0A: '#ffeb3b',
base0B: '#4caf50',
base0C: '#00bcd4',
base0D: '#2196f3',
base0E: '#9c27b0',
base0F: '#673ab7',
};
const Panel = () => {
const [mocks, setMocks] = (0, react_1.useState)(undefined);
(0, manager_api_1.useChannel)({
[types_js_1.ADDON_ID]: (mocks) => {
setMocks(mocks);
},
});
return (react_1.default.createElement("div", null, mocks &&
mocks.map(([name, mock], index) => (react_1.default.createElement("div", { key: name + index },
react_1.default.createElement("div", { style: { padding: '4px 4px 0', color: 'green' } }, name),
react_1.default.createElement("div", { style: { padding: '0 4px', color: 'blue', marginTop: '-4px' } },
react_1.default.createElement(react_json_tree_1.JSONTree, { data: mock, theme: theme })),
react_1.default.createElement("hr", null))))));
};
const render = ({ active }) => (react_1.default.createElement(components_1.TabWrapper, { active: !!active },
react_1.default.createElement(Panel, null)));
manager_api_1.addons.register(types_js_1.ADDON_ID, (api) => {
const property = { count: 0 };
const addPanel = () => manager_api_1.addons.add(types_js_1.TAB_ID, {
type: manager_api_1.types.PANEL,
title: () => {
const [count, setCount] = (0, react_1.useState)(property.count);
property.setCount = setCount;
return react_1.default.createElement(react_1.default.Fragment, null,
"Mocks",
count ? `(${count})` : '');
},
render,
});
api.on(types_js_1.ADDON_ID, (mocks) => {
property.count = mocks.length;
property.setCount?.(property.count);
});
addPanel();
});