mirror of
https://git.rwth-aachen.de/acs/public/villas/web/
synced 2025-03-09 00:00:01 +01:00
fixed imaged widget, load image by id
This commit is contained in:
parent
e0c5ffbd8f
commit
e395b65fc1
2 changed files with 24 additions and 22 deletions
|
@ -21,37 +21,33 @@
|
|||
|
||||
import React, { Component } from 'react';
|
||||
|
||||
const API_URL = 'http://localhost:4000/';
|
||||
import AppDispatcher from '../app-dispatcher';
|
||||
import config from '../config';
|
||||
|
||||
class WidgetImage extends Component {
|
||||
constructor(props) {
|
||||
super(props);
|
||||
|
||||
this.state = {
|
||||
file: null
|
||||
};
|
||||
}
|
||||
|
||||
componentWillReceiveProps(nextProps) {
|
||||
// check if file is set
|
||||
if (nextProps.widget.file == null) {
|
||||
this.setState({ file: null });
|
||||
return;
|
||||
}
|
||||
|
||||
// get file by id
|
||||
nextProps.files.forEach(file => {
|
||||
if (file._id === nextProps.widget.file) {
|
||||
this.setState({ file: file });
|
||||
}
|
||||
});
|
||||
// Query the image referenced by the widget (public request, no token required)
|
||||
let widgetFile = nextProps.widget.file;
|
||||
if (widgetFile && !nextProps.files.find( file => file._id === widgetFile ) ) {
|
||||
|
||||
AppDispatcher.dispatch({
|
||||
type: 'files/start-load',
|
||||
data: widgetFile
|
||||
});
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
render() {
|
||||
|
||||
let file = this.props.files.find( (file) => file._id === this.props.widget.file );
|
||||
|
||||
return (
|
||||
<div>
|
||||
{this.state.file &&
|
||||
<img alt={this.state.file.name} style={{ width: this.props.widget.width - 20, height: this.props.widget.height - 20 }} src={API_URL + this.state.file.path} />
|
||||
<div className="full">
|
||||
{file &&
|
||||
<img className="full" alt={file.name} src={config.publicPathBase + file.path} onDragStart={ (e) => e.preventDefault() } />
|
||||
}
|
||||
</div>
|
||||
);
|
||||
|
|
6
src/config.js
Normal file
6
src/config.js
Normal file
|
@ -0,0 +1,6 @@
|
|||
|
||||
const config = {
|
||||
publicPathBase: 'public/'
|
||||
}
|
||||
|
||||
export default config
|
Loading…
Add table
Reference in a new issue