2020-09-19 12:06:45 +01:00
|
|
|
/**
|
|
|
|
* Submit on change
|
|
|
|
* Simply submits a parent form when this input is changed.
|
|
|
|
* @extends {Component}
|
|
|
|
*/
|
|
|
|
class SubmitOnChange {
|
|
|
|
|
|
|
|
setup() {
|
2021-08-04 20:48:23 +01:00
|
|
|
this.filter = this.$opts.filter;
|
|
|
|
|
|
|
|
this.$el.addEventListener('change', (event) => {
|
|
|
|
|
|
|
|
if (this.filter && !event.target.matches(this.filter)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-09-19 12:06:45 +01:00
|
|
|
const form = this.$el.closest('form');
|
|
|
|
if (form) {
|
|
|
|
form.submit();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
export default SubmitOnChange;
|