Files
SCM-Manager/scm-ui/ui-components/src/forms/AddEntryToTableField.tsx

83 lines
1.9 KiB
TypeScript
Raw Normal View History

import React, { MouseEvent } from "react";
import { AddButton } from "../buttons";
import InputField from "./InputField";
type Props = {
addEntry: (p: string) => void;
disabled: boolean;
buttonLabel: string;
fieldLabel: string;
errorMessage: string;
helpText?: string;
validateEntry?: (p: string) => boolean;
};
type State = {
entryToAdd: string;
};
class AddEntryToTableField extends React.Component<Props, State> {
constructor(props: Props) {
super(props);
this.state = {
entryToAdd: ""
};
}
2019-02-07 06:01:13 +01:00
isValid = () => {
const { validateEntry } = this.props;
2019-10-21 10:57:56 +02:00
if (!this.state.entryToAdd || this.state.entryToAdd === "" || !validateEntry) {
2019-02-07 06:01:13 +01:00
return true;
} else {
return validateEntry(this.state.entryToAdd);
}
};
render() {
2019-10-21 10:57:56 +02:00
const { disabled, buttonLabel, fieldLabel, errorMessage, helpText } = this.props;
return (
<div className="field">
<InputField
label={fieldLabel}
errorMessage={errorMessage}
onChange={this.handleAddEntryChange}
2019-02-07 06:01:13 +01:00
validationError={!this.isValid()}
value={this.state.entryToAdd}
onReturnPressed={this.appendEntry}
disabled={disabled}
helpText={helpText}
/>
<AddButton
label={buttonLabel}
action={this.addButtonClicked}
disabled={disabled || this.state.entryToAdd === "" || !this.isValid()}
/>
</div>
);
}
addButtonClicked = (event: MouseEvent) => {
event.preventDefault();
this.appendEntry();
};
appendEntry = () => {
const { entryToAdd } = this.state;
this.props.addEntry(entryToAdd);
this.setState({
...this.state,
entryToAdd: ""
});
};
handleAddEntryChange = (entryname: string) => {
this.setState({
...this.state,
entryToAdd: entryname
});
};
}
export default AddEntryToTableField;