Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

files knob #2860

Merged
merged 10 commits into from
Mar 27, 2018
15 changes: 15 additions & 0 deletions addons/knobs/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -247,6 +247,21 @@ const value = select(label, options, defaultValue);

> You can also provide options as an array like this: `['red', 'blue', 'yellow']`

### files

Allows you to get a value from a file input from the user.

```js
import { files } from '@storybook/addon-knobs/react';

const label = 'Images';
const defaultValue = [];

const value = files(label, defaultValue);
```

> Multiple files can be selected, and will be returned as an array of [Data URLs](https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs)

### date

Allow you to get date (and time) from the user.
Expand Down
5 changes: 4 additions & 1 deletion addons/knobs/example/stories/index.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import React from 'react';
import { storiesOf } from '@storybook/react';
import moment from 'moment';
import { withKnobs, number, object, boolean, text, select, date, array, color } from '../../src';
import { withKnobs, number, object, boolean, text, select, date, array, color, files } from '../../src';

const stories = storiesOf('Example of Knobs', module);

Expand All @@ -20,6 +20,8 @@ stories.add('with all knobs', () => {

const passions = array('Passions', ['Fishing', 'Skiing']);

const images = files('Happy Picture', ['']);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please add this example to examples/offisial-storybook instead. addons/*/examples are outdated and probably will be removed. Sorry for the confusion


const customStyle = object('Style', {
fontFamily: 'Arial',
padding: 20,
Expand All @@ -38,6 +40,7 @@ stories.add('with all knobs', () => {
I like: <ul>{passions.map((p, i) => <li key={i}>{p}</li>)}</ul>
<p>My favorite number is {favoriteNumber}.</p>
<p>My most comfortable room temperature is {comfortTemp} degrees Fahrenheit.</p>
<p>When I am happy I look like this: <img src={images[0]} /></p>
</div>
);
});
Expand Down
4 changes: 4 additions & 0 deletions addons/knobs/src/base.js
Original file line number Diff line number Diff line change
Expand Up @@ -61,3 +61,7 @@ export function date(name, value = new Date()) {
export function button(name, callback) {
return manager.knob(name, { type: 'button', callback, hideLabel: true });
}

export function files(name, value = []) {
return manager.knob(name, { type: 'files', value });
}
37 changes: 37 additions & 0 deletions addons/knobs/src/components/types/Files.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
import { FileReader } from 'global';
import PropTypes from 'prop-types';
import React from 'react';

function fileReaderPromise(file) {
return new Promise(resolve => {
const fileReader = new FileReader();
fileReader.onload = e => resolve(e.currentTarget.result);
fileReader.readAsDataURL(file);
});
}

const FilesType = ({ knob, onChange }) => (
<input
id={knob.name}
type="file"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

multiple
onChange={e => Promise.all(Array.from(e.target.files).map(fileReaderPromise)).then(onChange)}
/>
);

FilesType.defaultProps = {
knob: {},
onChange: value => value,
};

FilesType.propTypes = {
knob: PropTypes.shape({
name: PropTypes.string,
}),
onChange: PropTypes.func,
};

FilesType.serialize = () => undefined;
FilesType.deserialize = () => undefined;

export default FilesType;
2 changes: 2 additions & 0 deletions addons/knobs/src/components/types/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import SelectType from './Select';
import ArrayType from './Array';
import DateType from './Date';
import ButtonType from './Button';
import FilesType from './Files';

export default {
text: TextType,
Expand All @@ -18,4 +19,5 @@ export default {
array: ArrayType,
date: DateType,
button: ButtonType,
files: FilesType,
};
3 changes: 2 additions & 1 deletion addons/knobs/src/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import {
array,
boolean,
button,
files,
color,
date,
knob,
Expand All @@ -19,7 +20,7 @@ import {
text,
} from './base';

export { knob, text, boolean, number, color, object, array, date, button, select };
export { knob, text, boolean, number, color, object, array, date, button, files, select };

deprecate(() => {},
'Using @storybook/addon-knobs directly is discouraged, please use @storybook/addon-knobs/{{framework}}');
Expand Down
3 changes: 2 additions & 1 deletion addons/knobs/src/react/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,11 @@ import {
date,
select,
button,
files,
manager,
} from '../base';

export { knob, text, boolean, number, color, object, array, date, select, button };
export { knob, text, boolean, number, color, object, array, date, select, button, files };

export const reactHandler = (channel, knobStore) => getStory => context => {
const initialContent = getStory(context);
Expand Down
3 changes: 2 additions & 1 deletion addons/knobs/src/vue/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,10 +11,11 @@ import {
date,
select,
button,
files,
manager,
} from '../base';

export { knob, text, boolean, number, color, object, array, date, select, button };
export { knob, text, boolean, number, color, object, array, date, select, button, files };
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can it be supported in angular and polymer as well?


export const vueHandler = (channel, knobStore) => getStory => context => ({
data() {
Expand Down