2024-10-12 04:55:51 +08:00
|
|
|
import {onChildEvent} from '../services/dom.ts';
|
2024-10-10 19:03:24 +08:00
|
|
|
import {uniqueId} from '../services/util.ts';
|
2023-04-19 05:20:02 +08:00
|
|
|
import {Component} from './component';
|
2020-06-27 20:29:00 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* AddRemoveRows
|
|
|
|
* Allows easy row add/remove controls onto a table.
|
|
|
|
* Needs a model row to use when adding a new row.
|
|
|
|
*/
|
2022-11-15 07:19:02 +08:00
|
|
|
export class AddRemoveRows extends Component {
|
2023-04-19 05:20:02 +08:00
|
|
|
|
2020-06-27 20:29:00 +08:00
|
|
|
setup() {
|
|
|
|
this.modelRow = this.$refs.model;
|
|
|
|
this.addButton = this.$refs.add;
|
|
|
|
this.removeSelector = this.$opts.removeSelector;
|
2020-06-30 05:11:03 +08:00
|
|
|
this.rowSelector = this.$opts.rowSelector;
|
2020-06-27 20:29:00 +08:00
|
|
|
this.setupListeners();
|
|
|
|
}
|
|
|
|
|
|
|
|
setupListeners() {
|
2020-06-30 05:11:03 +08:00
|
|
|
this.addButton.addEventListener('click', this.add.bind(this));
|
2020-06-27 20:29:00 +08:00
|
|
|
|
2023-04-19 05:20:02 +08:00
|
|
|
onChildEvent(this.$el, this.removeSelector, 'click', e => {
|
2020-06-30 05:11:03 +08:00
|
|
|
const row = e.target.closest(this.rowSelector);
|
2020-06-27 20:29:00 +08:00
|
|
|
row.remove();
|
|
|
|
});
|
|
|
|
}
|
2020-06-30 05:11:03 +08:00
|
|
|
|
|
|
|
// For external use
|
|
|
|
add() {
|
|
|
|
const clone = this.modelRow.cloneNode(true);
|
|
|
|
clone.classList.remove('hidden');
|
|
|
|
this.setClonedInputNames(clone);
|
|
|
|
this.modelRow.parentNode.insertBefore(clone, this.modelRow);
|
2022-11-15 07:19:02 +08:00
|
|
|
window.$components.init(clone);
|
2020-06-30 05:11:03 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Update the HTML names of a clone to be unique if required.
|
|
|
|
* Names can use placeholder values. For exmaple, a model row
|
|
|
|
* may have name="tags[randrowid][name]".
|
|
|
|
* These are the available placeholder values:
|
|
|
|
* - randrowid - An random string ID, applied the same across the row.
|
|
|
|
* @param {HTMLElement} clone
|
|
|
|
*/
|
|
|
|
setClonedInputNames(clone) {
|
|
|
|
const rowId = uniqueId();
|
2023-04-19 05:20:02 +08:00
|
|
|
const randRowIdElems = clone.querySelectorAll('[name*="randrowid"]');
|
2020-06-30 05:11:03 +08:00
|
|
|
for (const elem of randRowIdElems) {
|
|
|
|
elem.name = elem.name.split('randrowid').join(rowId);
|
|
|
|
}
|
|
|
|
}
|
2023-04-19 05:20:02 +08:00
|
|
|
|
|
|
|
}
|