mirador
Version:
An open-source, web-based 'multi-up' viewer that supports zoom-pan-rotate functionality, ability to display/compare simple images, and images with annotations.
128 lines (122 loc) • 3.22 kB
JavaScript
import { compose } from 'redux';
import { connect } from 'react-redux';
import { withStyles } from '@material-ui/core';
import { withTranslation } from 'react-i18next';
import { withPlugins } from '../extend/withPlugins';
import * as actions from '../state/actions';
import { Window } from '../components/Window';
import { getManifestStatus, getManifestTitle, getThumbnailNavigationPosition, getWindow, getWorkspaceType, getWindowDraggability, getWindowViewType, getManifestError } from '../state/selectors';
/**
* mapStateToProps - used to hook up connect to action creators
* @memberof Window
* @private
*/
var mapStateToProps = function mapStateToProps(state, _ref) {
var windowId = _ref.windowId;
return {
isFetching: getManifestStatus(state, {
windowId: windowId
}).isFetching,
label: getManifestTitle(state, {
windowId: windowId
}),
manifestError: getManifestError(state, {
windowId: windowId
}),
maximized: (getWindow(state, {
windowId: windowId
}) || {}).maximized,
sideBarOpen: (getWindow(state, {
windowId: windowId
}) || {}).sideBarOpen,
thumbnailNavigationPosition: getThumbnailNavigationPosition(state, {
windowId: windowId
}),
view: getWindowViewType(state, {
windowId: windowId
}),
window: getWindow(state, {
windowId: windowId
}),
windowDraggable: getWindowDraggability(state, {
windowId: windowId
}),
workspaceType: getWorkspaceType(state)
};
};
/**
* mapDispatchToProps - used to hook up connect to action creators
* @memberof ManifestListItem
* @private
*/
var mapDispatchToProps = function mapDispatchToProps(dispatch, _ref2) {
var windowId = _ref2.windowId;
return {
focusWindow: function focusWindow() {
return dispatch(actions.focusWindow(windowId));
}
};
};
/**
* @param theme
*/
var styles = function styles(theme) {
return {
companionAreaBottom: {
display: 'flex',
flex: '0',
flexBasis: 'auto',
minHeight: 0
},
companionAreaRight: {
display: 'flex',
flex: '0 1 auto',
minHeight: 0
},
maximized: {},
middle: {
display: 'flex',
flex: '1',
flexDirection: 'row',
minHeight: 0
},
middleLeft: {
display: 'flex',
flex: '1',
flexDirection: 'column',
minHeight: 0
},
primaryWindow: {
display: 'flex',
flex: '1',
height: '300px',
minHeight: 0,
position: 'relative'
},
thumbnailArea: {
backgroundColor: theme.palette.shades.dark
},
thumbnailAreaBottom: {},
thumbnailAreaRight: {
minWidth: 100
},
window: {
'&$maximized': {
left: 0,
position: 'absolute',
top: 0,
zIndex: theme.zIndex.modal - 1
},
backgroundColor: theme.palette.shades.dark,
borderRadius: 0,
display: 'flex',
flexDirection: 'column',
height: '100%',
minHeight: 0,
overflow: 'hidden',
width: '100%'
}
};
};
var enhance = compose(withTranslation(), withStyles(styles), connect(mapStateToProps, mapDispatchToProps), withPlugins('Window'));
export default enhance(Window);