added es-lint config to sandbox
parent
0b1f1dc3bd
commit
5d4aa1b519
@ -0,0 +1,8 @@
|
||||
{
|
||||
"root": true,
|
||||
"extends": "./node_modules/eslint-config-netconomy/react.js",
|
||||
"parser": "babel-eslint",
|
||||
"rules": {
|
||||
"comma-dangle": [2, "always-multiline"],
|
||||
}
|
||||
}
|
@ -0,0 +1,125 @@
|
||||
import React from 'react';
|
||||
import {List, ListItem} from 'material-ui/List';
|
||||
import Subheader from 'material-ui/Subheader';
|
||||
import Toggle from 'material-ui/Toggle';
|
||||
import SelectField from 'material-ui/SelectField';
|
||||
import MenuItem from 'material-ui/MenuItem';
|
||||
|
||||
function generateItems(keyValuePairs) {
|
||||
return keyValuePairs.map(([value, label]) => (
|
||||
<MenuItem key={value} value={value} primaryText={label} />
|
||||
));
|
||||
}
|
||||
|
||||
const availableReaders = [
|
||||
['ean_reader', "EAN-13", true],
|
||||
['ean_8_reader', "EAN-8"],
|
||||
["upc_e_reader", "UPC-E"],
|
||||
["code_39_reader", "CODE 39", true],
|
||||
["codabar_reader", "Codabar"],
|
||||
["code_128_reader", "CODE 128", true],
|
||||
["i2of5_reader", "ITF", true],
|
||||
];
|
||||
|
||||
let configOptions = {
|
||||
width: [[640, "640px"], [800, "800px"], [1280, "1280px"], [1920, "1920px"]],
|
||||
height: [[480, "480px"], [600, "600px"], [720, "720px"], [1080, "1080px"]],
|
||||
facingMode: [["user", "user"], ["environment", "environment"]],
|
||||
aspectRatio: [[1, '1/1'], [4 / 3, '4/3'], [16 / 9, '16/9'], [21 / 9, '21/9']],
|
||||
deviceId: [],
|
||||
};
|
||||
|
||||
let items = Object.keys(configOptions).reduce((result, option) => ({
|
||||
...result,
|
||||
[option]: generateItems(configOptions[option]),
|
||||
}), {});
|
||||
|
||||
const selectStyle = {
|
||||
};
|
||||
const selectedItemStyle = {
|
||||
whiteSpace: 'nowrap',
|
||||
textOverflow: 'ellipsis',
|
||||
overflow: 'hidden',
|
||||
};
|
||||
|
||||
export default class ConfigView extends React.Component {
|
||||
state = {
|
||||
devicesFetched: false,
|
||||
numOfWorkers: 2,
|
||||
...Object
|
||||
.keys(configOptions)
|
||||
.reduce((result, option) => ({...result, [option]: (configOptions[option][0] || [null])[0]}), {}),
|
||||
};
|
||||
|
||||
handleChange = (category, event, index, value) => {
|
||||
this.setState({[category]: value});
|
||||
}
|
||||
|
||||
componentWillMount() {
|
||||
navigator.mediaDevices
|
||||
.enumerateDevices()
|
||||
.then((devices) => {
|
||||
const videoDevices = devices
|
||||
.filter(info => info.kind === 'videoinput')
|
||||
.map(videoDevice => ([
|
||||
videoDevice.deviceId,
|
||||
videoDevice.label,
|
||||
]));
|
||||
configOptions = {
|
||||
...configOptions,
|
||||
deviceId: videoDevices,
|
||||
};
|
||||
items = {
|
||||
...items,
|
||||
deviceId: generateItems(configOptions.deviceId),
|
||||
};
|
||||
this.setState({devicesFetched: true});
|
||||
});
|
||||
}
|
||||
render() {
|
||||
return (
|
||||
<div>
|
||||
<Subheader>Constraints</Subheader>
|
||||
<div style={{paddingLeft: 16, paddingRight: 16}}>
|
||||
{Object.keys(items).map(option => (
|
||||
<SelectField fullWidth={true} key={option} style={selectStyle}
|
||||
labelStyle={selectedItemStyle}
|
||||
value={this.state[option]}
|
||||
onChange={this.handleChange.bind(this, option)}
|
||||
floatingLabelText={option}
|
||||
>
|
||||
{items[option]}
|
||||
</SelectField>
|
||||
))}
|
||||
</div>
|
||||
<List>
|
||||
<Subheader>General</Subheader>
|
||||
<ListItem primaryText="locate" secondaryText="Automatically detect position" rightToggle={<Toggle />} />
|
||||
<div style={{paddingLeft: 16, paddingRight: 16}}>
|
||||
<SelectField fullWidth={true} key={'numOfWorkers'}
|
||||
style={selectStyle}
|
||||
labelStyle={selectedItemStyle}
|
||||
value={this.state.numOfWorkers}
|
||||
onChange={this.handleChange.bind(this, 'numOfWorkers')}
|
||||
floatingLabelText='numOfWorkers'
|
||||
>
|
||||
{[0, 1, 2, 4, 8]
|
||||
.map(numOfWorkers => <MenuItem key={numOfWorkers} value={numOfWorkers} primaryText={numOfWorkers} />)
|
||||
}
|
||||
</SelectField>
|
||||
</div>
|
||||
</List>
|
||||
<List>
|
||||
<Subheader>Readers</Subheader>
|
||||
{availableReaders.map(([reader, label, enabled]) => (
|
||||
<ListItem
|
||||
key={reader}
|
||||
primaryText={label}
|
||||
rightToggle={<Toggle defaultToggled={enabled ? enabled : false} />}
|
||||
/>
|
||||
))}
|
||||
</List>
|
||||
</div>
|
||||
);
|
||||
}
|
||||
};
|
Loading…
Reference in New Issue