You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
devdocs/assets/javascripts/views/list/list_select.js

52 lines
1.1 KiB

app.views.ListSelect = class ListSelect extends app.View {
static activeClass = "active";
static events = { click: "onClick" };
deactivate() {
if (super.deactivate(...arguments)) {
this.deselect();
}
}
select(el) {
this.deselect();
if (el) {
el.classList.add(this.constructor.activeClass);
$.trigger(el, "select");
}
}
deselect() {
let selection;
if ((selection = this.getSelection())) {
selection.classList.remove(this.constructor.activeClass);
$.trigger(selection, "deselect");
}
}
selectByHref(href) {
if (this.getSelection()?.getAttribute("href") !== href) {
this.select(this.find(`a[href='${href}']`));
}
}
selectCurrent() {
this.selectByHref(location.pathname + location.hash);
}
getSelection() {
return this.findByClass(this.constructor.activeClass);
}
onClick(event) {
if (event.which !== 1 || event.metaKey || event.ctrlKey) {
return;
}
const target = $.eventTarget(event);
if (target.tagName === "A") {
this.select(target);
}
}
};