Drawings module
Drawings List
data:image/s3,"s3://crabby-images/03ef5/03ef5c1d9d8dd54c7e8accef033fb8b72401738f" alt="Drawings list view"
API URL
/api/patients/{patientId}/drawings
GET response
{ date: 1423440000000 name: 'Cardiac Catherization' source: 'Marand' sourceId: "6ba725c8-9a61-41e9-82c0-d4c6788d9ec8" }
Component structure
//component template let templateDrawingsList = require('./drawings-list.html'); //controller init class DrawingsListController { constructor($scope, $state, $stateParams, $ngRedux, drawingsActions, serviceRequests, usSpinnerService, serviceFormatted) { } //component init const DrawingsListComponent = { template: templateDrawingsList, controller: DrawingsListController }; //inject services/modules to controller DrawingsListController.$inject = ['$scope', '$state', '$stateParams', '$ngRedux', 'drawingsActions', 'serviceRequests', 'usSpinnerService', 'serviceFormatted']; //es6 export for component export default DrawingsListComponent;
Drawings Detail
data:image/s3,"s3://crabby-images/d134a/d134a33d0a9db278f43f799a5348757a216b01de" alt="Drawings Detail Tab 1"
data:image/s3,"s3://crabby-images/59005/59005d568f87314d470678065db9995a09c00c3f" alt="Drawings Detail Tab 2"
API URL
/api/patients/{patientId}/drawings/{sourceId}
GET response
{ author: 'Dr Jhon Smith' date: 1423440000000 image64: 'data:image/png;base64,/...' name: 'Cardiac Catherization' source: 'Marand' sourceId: "6ba725c8-9a61-41e9-82c0-d4c6788d9ec8" }
Component structure
//component template let templateDrawingsDetail= require('./drawings-detail.html'); //controller init class DrawingsDetailController { constructor($scope, $state, $stateParams, $ngRedux, drawingsActions, usSpinnerService, serviceRequests, $timeout, $window) { } //component init const DrawingsDetailComponent = { template: templateDrawingsDetail, controller: DrawingsDetailController }; //inject services/modules to controller DrawingsDetailController.$inject = ['$scope', '$state', '$stateParams', '$ngRedux', 'drawingsActions', 'usSpinnerService', 'serviceRequests', '$timeout', '$window']; //es6 export for component export default DrawingsDetailComponent;
Drawings Create
data:image/s3,"s3://crabby-images/c32b9/c32b97db8c1d801d5d93fe18c0b9755d467b8d30" alt="Drawings Create"
API URL
/api/patients/{patientId}/drawings
POST data
{ author: 'Dr Jhon Smith' date: 1423440000000 image64: 'data:image/png;base64,/...' name: 'Cardiac Catherization' }
Component structure
//component template let templateCreate = require('./drawings-create.html'); //controller init class DrawingsCreateController { constructor($scope, $state, $stateParams, $ngRedux, drawingsActions, serviceRequests, serviceFormatted, usSpinnerService, $window) { } //component init const DrawingsCreateComponent = { template: templateCreate, controller: DrawingsCreateController }; //inject services/modules to controller DrawingsCreateController.$inject = ['$scope', '$state', '$stateParams', '$ngRedux', 'drawingsActions', 'serviceRequests', 'serviceFormatted', 'usSpinnerService', '$window']; //es6 export for component export default DrawingsCreateComponent;
Drawings Create
data:image/s3,"s3://crabby-images/c64e0/c64e0dfc517c418fb358037a33cd34a801a9c9c9" alt="Drawings Drawing work with Brushes"
data:image/s3,"s3://crabby-images/00300/003007159ff0d529847cb0c37f9719bc90888cc2" alt="Drawings Drawing work with Fonts"
data:image/s3,"s3://crabby-images/f1c33/f1c33c61b25e5cb73553aa6a08a61d2bd557ce57" alt="Drawings Drawing work with Pictures"
Component structure
//component template let templateDrawingsDrawing = require('./drawings-drawing.html'); //controller init class DrawingsDrawingController { constructor($scope, $state, $stateParams, serviceRequests, usSpinnerService, $timeout, $window) { } //component init const DrawingsDrawingComponent = { template: templateDrawingsDrawing, controller: DrawingsDrawingController }; //inject services/modules to controller DrawingsDrawingController.$inject = ['$scope', '$state', '$stateParams', 'serviceRequests', 'usSpinnerService', '$timeout', '$window']; //es6 export for component export default DrawingsDrawingComponent;
Drawings Actions
Component structure
//es6 import modules import {bindActionCreators} from 'redux'; import * as types from '../../../constants/ActionTypes'; //es6 export function export function all(patientId) { return { types: [types.DRAWINGS, types.DRAWINGS_SUCCESS, types.DRAWINGS_ERROR], shouldCallAPI: (state) => !state.drawings.response, config: { method: 'get', url: '/api/patients/' + patientId + '/drawings' }, d: { timestamp: Date.now() } }; }
Drawings Reducer
Component structure
//es6 import modules import * as types from '../../../constants/ActionTypes'; const INITIAL_STATE = { isFetching: false, error: false, data: null, dataGet: null, dataCreate: null }; //es6 export function export default function drawing(state = INITIAL_STATE, action) { const {payload} = action; //redux action for Drawings requests [types.DRAWINGS]: (state) => { state.dataCreate = null; state.dataUpdate = null; return Object.assign({}, state, { isFetching: true, error: false }); }