mirror of
https://github.com/home-assistant/frontend.git
synced 2025-06-21 09:36:33 +00:00
46 lines
1017 B
JavaScript
46 lines
1017 B
JavaScript
import { h, Component } from 'preact';
|
|
|
|
import JSONTextArea from '../json_textarea.js';
|
|
import { onChangeEvent } from '../../common/util/event.js';
|
|
|
|
export default class EventTrigger extends Component {
|
|
constructor() {
|
|
super();
|
|
|
|
this.onChange = onChangeEvent.bind(this, 'trigger');
|
|
this.eventDataChanged = this.eventDataChanged.bind(this);
|
|
}
|
|
|
|
/* eslint-disable camelcase */
|
|
eventDataChanged(event_data) {
|
|
this.props.onChange(this.props.index, {
|
|
...this.props.trigger,
|
|
event_data,
|
|
});
|
|
}
|
|
|
|
render({ trigger }) {
|
|
const { event_type, event_data } = trigger;
|
|
return (
|
|
<div>
|
|
<paper-input
|
|
label="Event Type"
|
|
name="event_type"
|
|
value={event_type}
|
|
onvalue-changed={this.onChange}
|
|
/>
|
|
<JSONTextArea
|
|
label="Event Data"
|
|
value={event_data}
|
|
onChange={this.eventDataChanged}
|
|
/>
|
|
</div>
|
|
);
|
|
}
|
|
}
|
|
|
|
EventTrigger.defaultConfig = {
|
|
event_type: '',
|
|
event_data: {},
|
|
};
|