kopia lustrzana https://github.com/OpenDroneMap/WebODM
152 wiersze
5.3 KiB
JavaScript
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;
|