1
0
mirror of https://github.com/yldio/copilot.git synced 2025-01-09 18:40:12 +02:00
copilot/spikes/stacks/redux-thunk/src/client/containers/print.js

137 lines
2.6 KiB
JavaScript
Raw Normal View History

2016-10-14 12:45:12 +03:00
const ReactRouter = require('react-router');
const ReactRedux = require('react-redux');
const React = require('react');
const find = require('lodash.find');
const Loader = require('../components/loader');
const Printers = require('../components/printers');
const Changes = require('../components/changes');
const Change = require('../components/change');
2016-10-17 03:30:20 +03:00
const actions = require('../state/actions');
2016-10-14 12:45:12 +03:00
const {
2016-10-17 00:35:09 +03:00
fetchChanges,
lockPrinter,
print,
transitionTo
2016-10-14 12:45:12 +03:00
} = actions;
const {
2016-10-17 03:30:20 +03:00
Match
2016-10-14 12:45:12 +03:00
} = ReactRouter;
const {
connect
} = ReactRedux;
const Print = ({
pathname,
printers = [],
changes = [],
lockPrinter,
fetchChanges,
2016-10-17 00:35:09 +03:00
onPrint,
2016-10-14 12:45:12 +03:00
loaded,
2016-10-17 00:35:09 +03:00
loading,
locked,
router
2016-10-14 12:45:12 +03:00
}) => {
const allChanges = () => {
return (
<div>
<p>Changes</p>
<Loader
loaded={loaded}
loading={loading}
fetch={fetchChanges}
>
<Changes
pathname={pathname}
changes={changes}
/>
</Loader>
</div>
);
};
const singleChange = ({
params
}) => {
const change = find(changes, (change) => {
return change.id === params.id;
});
2016-10-17 00:35:09 +03:00
if (!change) {
return (
<p>Change not found</p>
);
}
const _onPrint = (id) => {
return () => {
return onPrint(id);
};
};
2016-10-14 12:45:12 +03:00
// TODO: don't load all changes
return (
<div>
<p>Change</p>
<Loader
loaded={loaded}
loading={loading}
fetch={fetchChanges}
>
<Change {...change} />
</Loader>
2016-10-17 00:35:09 +03:00
<button onClick={_onPrint(params.id)}>Print</button>
2016-10-14 12:45:12 +03:00
</div>
);
};
return (
<div>
<div>
<p>Printers</p>
<Printers
printers={printers}
2016-10-17 00:35:09 +03:00
onClick={lockPrinter}
locked={locked}
2016-10-14 12:45:12 +03:00
/>
</div>
<Match pattern={`${pathname}/:id`} render={singleChange} />
<Match exactly pattern={pathname} render={allChanges} />
</div>
);
};
const mapStateToProps = (state) => {
return {
loaded: state.ui.changes.loaded,
loading: state.ui.changes.loading,
changes: state.data.changes,
2016-10-17 00:35:09 +03:00
printers: state.data.printers,
locked: state.ui.printers.locked
2016-10-14 12:45:12 +03:00
};
};
const mapDispatchToProps = (dispatch) => {
return {
2016-10-17 00:35:09 +03:00
lockPrinter: (id) => {
return dispatch(lockPrinter(id));
},
2016-10-14 12:45:12 +03:00
fetchChanges: () => {
2016-10-17 00:35:09 +03:00
return dispatch(fetchChanges());
},
onPrint: (id) => {
return dispatch(print(id)).then(() => {
return dispatch(transitionTo('/print'));
});
2016-10-14 12:45:12 +03:00
}
};
};
2016-10-17 03:30:20 +03:00
module.exports = connect(mapStateToProps, mapDispatchToProps)(Print);