OpenDroneMap-WebODM/app/static/app/js/components/EditPresetDialog.jsx

152 wiersze
5.3 KiB
JavaScript

import '../css/EditPresetDialog.scss';
import React from 'react';
import FormDialog from './FormDialog';
import ProcessingNodeOption from './ProcessingNodeOption';
import PresetUtils from '../classes/PresetUtils';
import PropTypes from 'prop-types';
import values from 'object.values';
import { _ } from '../classes/gettext';
if (!Object.values) {
values.shim();
}
// Do not apply to WebODM, can cause confusion
const OPTS_BLACKLIST = ['build-overviews', 'ignore-gsd', 'orthophoto-no-tiled', 'orthophoto-compression', 'orthophoto-png', 'orthophoto-kmz', 'pc-copc', 'pc-las', 'pc-ply', 'pc-csv', 'pc-ept', 'cog'];
class EditPresetDialog extends React.Component {
static defaultProps = {
};
static propTypes = {
preset: PropTypes.object.isRequired,
availableOptions: PropTypes.array.isRequired,
saveAction: PropTypes.func.isRequired,
deleteAction: PropTypes.func.isRequired,
onHide: PropTypes.func
};
constructor(props){
super(props);
// Refs to ProcessingNodeOption components
this.options = {};
this.state = {
name: props.preset.name,
search: "",
showSearch: false
};
this.getFormData = this.getFormData.bind(this);
this.onShow = this.onShow.bind(this);
this.setOptionRef = this.setOptionRef.bind(this);
this.getOptions = this.getOptions.bind(this);
this.isCustomPreset = this.isCustomPreset.bind(this);
}
setOptionRef(optionName){
return (component) => {
if (component) this.options[optionName] = component;
}
}
getOptions(){
return Object.values(this.options)
.map(option => {
return {
name: option.props.name,
value: option.getValue()
};
})
.filter(option => option.value !== undefined);
}
getFormData(){
return {
id: this.props.preset.id,
name: this.state.name,
options: this.getOptions()
};
}
isCustomPreset(){
return this.props.preset.id === -1;
}
onShow(){
if (!this.isCustomPreset()) this.nameInput.focus();
}
handleChange(field){
return (e) => {
let state = {};
state[field] = e.target.value;
this.setState(state);
}
}
toggleSearchControl = () => {
this.setState({showSearch: !this.state.showSearch});
}
componentDidUpdate(prevProps, prevState){
if (this.state.showSearch){
this.searchControl.focus();
}
}
render(){
let options = PresetUtils.getAvailableOptions(this.props.preset.options, this.props.availableOptions);
return (
<div className="edit-preset-dialog">
<FormDialog {...this.props}
getFormData={this.getFormData}
reset={() => {}}
show={true}
onShow={this.onShow}
saveIcon="far fa-edit"
title={_("Edit Task Options")}
saveAction={this.props.saveAction}
deleteWarning={false}
deleteAction={(this.props.preset.id !== -1 && !this.props.preset.system) ? this.props.deleteAction : undefined}>
{!this.isCustomPreset() ?
[<div className="row preset-name" key="preset">
<label className="col-sm-2 control-label">{_("Name")}</label>
<div className="col-sm-10" style={{marginRight: "40px"}}>
<input type="text" className="form-control" ref={(domNode) => { this.nameInput = domNode; }} value={this.state.name} onChange={this.handleChange('name')} />
</div>
</div>,
<hr key="hr"/>]
: ""}
<button type="submit" className="btn btn-default search-toggle btn-sm" title={_("Search")} onClick={this.toggleSearchControl}><i className="fa fa-filter"></i></button>
{this.state.showSearch ?
<div className="row search-controls">
<div className="col-sm-12">
<input type="text" className="form-control" value={this.state.search} ref={(node) => { this.searchControl = node}} onChange={this.handleChange('search')} />
</div>
</div>
: ""}
<div className="row">
<div className="col-sm-12">
{options.filter(option => OPTS_BLACKLIST.indexOf(option.name.toLowerCase()) === -1).filter(option => this.state.showSearch && this.state.search !== "" ?
option.name.toLowerCase().indexOf(this.state.search.toLowerCase()) !== -1 :
true)
.map(option =>
<ProcessingNodeOption {...option}
key={option.name}
ref={this.setOptionRef(option.name)} />
)}
</div>
</div>
</FormDialog>
</div>
);
}
}
export default EditPresetDialog;