From a32770b0d310125b4cb54df31625e4239ed942d8 Mon Sep 17 00:00:00 2001 From: Amir Hadzic Date: Tue, 1 Nov 2016 14:04:29 +0100 Subject: [PATCH] Add storybook so it's easier to test changes --- .storybook/config.js | 8 ++++++++ .storybook/webpack.config.js | 13 +++++++++++++ package.json | 15 ++++++++++----- stories/UsersTable.js | 16 ++++++++++++++++ stories/index.js | 33 +++++++++++++++++++++++++++++++++ 5 files changed, 80 insertions(+), 5 deletions(-) create mode 100644 .storybook/config.js create mode 100644 .storybook/webpack.config.js create mode 100644 stories/UsersTable.js create mode 100644 stories/index.js diff --git a/.storybook/config.js b/.storybook/config.js new file mode 100644 index 0000000..b089cdd --- /dev/null +++ b/.storybook/config.js @@ -0,0 +1,8 @@ +import { configure } from '@kadira/storybook'; +import '../node_modules/bootstrap/dist/css/bootstrap.min.css'; + +function loadStories() { + require('../stories'); +} + +configure(loadStories, module); diff --git a/.storybook/webpack.config.js b/.storybook/webpack.config.js new file mode 100644 index 0000000..379362c --- /dev/null +++ b/.storybook/webpack.config.js @@ -0,0 +1,13 @@ +const genDefaultConfig = require('@kadira/storybook/dist/server/config/defaults/webpack.config.js'); +const webpack = require('webpack'); + + +module.exports = function(config, env) { + const defaultConfig = genDefaultConfig(config, env); + const withOldPlugin = Object.assign({}, defaultConfig, { + plugins: defaultConfig.plugins.concat([ + new webpack.OldWatchingPlugin(), + ]) + }) + return withOldPlugin; +}; diff --git a/package.json b/package.json index b80b9cf..0ef5578 100644 --- a/package.json +++ b/package.json @@ -8,7 +8,9 @@ "compile": "babel --presets es2015 -d lib/ src/", "prepublish": "npm run compile", "eslint": "./node_modules/.bin/eslint src", - "lint": "npm run eslint" + "lint": "npm run eslint", + "storybook": "start-storybook -p 6006", + "build-storybook": "build-storybook" }, "repository": { "type": "git", @@ -62,22 +64,25 @@ "dependencies": { "lodash": "^4.15.0", "react": "^15.1.0", + "react-dom": "^15.3.2", "react-redux": "^4.4.5", "redux": "^3.4.0", "redux-actions": "^0.11.0", "reselect": "^2.5.3" }, "devDependencies": { + "@kadira/storybook": "^2.21.0", "babel-cli": "^6.14.0", - "babel-preset-es2015": "^6.6.0", + "babel-eslint": "^6.0.2", "babel-plugin-transform-object-rest-spread": "^6.6.5", + "babel-preset-es2015": "^6.6.0", "babel-preset-react": "^6.5.0", - "babel-eslint": "^6.0.2", + "bootstrap": "^4.0.0-alpha.2", "eslint": "^3.3.1", "eslint-config-airbnb": "^10.0.1", "eslint-loader": "^1.3.0", + "eslint-plugin-import": "^1.13.0", "eslint-plugin-jsx-a11y": "^2.1.0", - "eslint-plugin-react": "^6.0.0", - "eslint-plugin-import": "^1.13.0" + "eslint-plugin-react": "^6.0.0" } } diff --git a/stories/UsersTable.js b/stories/UsersTable.js new file mode 100644 index 0000000..84a804f --- /dev/null +++ b/stories/UsersTable.js @@ -0,0 +1,16 @@ +import React, { Component } from 'react'; +import sematable, { Table } from '../src'; + +const columns = [ + { key: 'id', primaryKey: true, header: 'ID' }, + { key: 'firstName', header: 'First name', filterable: true, sortable: true }, + { key: 'lastName', header: 'Last name', filterable: true, sortable: true }, + { key: 'status', header: 'Status', taggable: true }, +]; + +class UsersTable extends Component { + render() { + return ; + } +} +export default sematable('usersTable', UsersTable, columns); diff --git a/stories/index.js b/stories/index.js new file mode 100644 index 0000000..b56e144 --- /dev/null +++ b/stories/index.js @@ -0,0 +1,33 @@ +import React from 'react'; +import { storiesOf } from '@kadira/storybook'; +import { Provider } from 'react-redux'; +import { combineReducers, createStore } from 'redux'; +import { reducer as sematable } from '../src'; +import UsersTable from './UsersTable'; + +const reducer = combineReducers({ sematable }); +const store = createStore(reducer); + +const users = [ + { + id: 1, + firstName: 'John', + lastName: 'Doe', + status: 'UNKNOWN', + }, + { + id: 2, + firstName: 'Bob', + lastName: 'McBobber', + status: 'ACTIVE', + }, +]; + +storiesOf('Sematable', module) + .add('default', () => ( + +
+ +
+
+ ));