cspace-ui
Version:
CollectionSpace user interface for browsers
149 lines (146 loc) • 4.49 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _reactHelmet = require("react-helmet");
var _get = _interopRequireDefault(require("lodash/get"));
var _ImageViewer = _interopRequireDefault(require("../media/ImageViewer"));
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
const propTypes = {
location: _propTypes.default.shape({
search: _propTypes.default.string
}),
match: _propTypes.default.shape({
params: _propTypes.default.object
}),
readContent: _propTypes.default.func.isRequired,
renderError: _propTypes.default.func,
renderLoading: _propTypes.default.func
};
class ContentViewerPage extends _react.Component {
constructor() {
super();
this.state = {
blobUrl: null
};
}
componentDidMount() {
this.readContent();
}
componentDidUpdate(prevProps) {
const {
match
} = this.props;
const {
match: prevMatch
} = prevProps;
const contentPath = (0, _get.default)(match, ['params', 'contentPath']);
const prevContentPath = (0, _get.default)(prevMatch, ['params', 'contentPath']);
if (contentPath !== prevContentPath) {
this.reset();
this.readContent();
}
}
componentWillUnmount() {
this.reset();
this.isUnmounted = true;
}
reset() {
const {
blobUrl
} = this.state;
if (blobUrl) {
URL.revokeObjectURL(blobUrl);
this.setState({
blobUrl: null
});
}
}
readContent() {
const {
location,
match,
readContent
} = this.props;
readContent(location, match).then(response => {
if (response && response.status === 200 && response.data && !this.isUnmounted) {
const contentDisposition = response.headers['content-disposition'];
const filename = contentDisposition && contentDisposition.match(/filename="(.*?)"/) ? RegExp.$1 : null;
this.setState({
filename,
blobUrl: URL.createObjectURL(response.data),
contentType: response.headers['content-type']
});
}
}).catch(error => {
this.setState({
error
});
});
}
renderImageViewer() {
const {
blobUrl,
filename
} = this.state;
return /*#__PURE__*/_react.default.createElement(_ImageViewer.default, {
blobUrl: blobUrl,
filename: filename
});
}
renderBlobViewer() {
const {
blobUrl
} = this.state;
const style = {
position: 'fixed',
left: '0',
top: '0',
width: '100%',
height: '100%',
border: 'none'
};
// Load the blob into an iframe to get the default viewer.
return (
/*#__PURE__*/
// TODO: Make title a message.
_react.default.createElement("iframe", {
src: blobUrl,
style: style,
title: "File content"
})
);
}
render() {
const {
renderError,
renderLoading
} = this.props;
const {
blobUrl,
contentType,
error,
filename
} = this.state;
if (error) {
return renderError ? renderError(error) : null;
}
if (!blobUrl) {
return renderLoading ? renderLoading() : null;
}
const title = filename ? /*#__PURE__*/_react.default.createElement(_reactHelmet.Helmet, null, /*#__PURE__*/_react.default.createElement("title", null, filename)) : null;
let viewer;
if (contentType.startsWith('image/')) {
viewer = this.renderImageViewer();
} else {
viewer = this.renderBlobViewer();
}
return /*#__PURE__*/_react.default.createElement("div", null, title, viewer);
}
}
exports.default = ContentViewerPage;
ContentViewerPage.propTypes = propTypes;