2023-04-18 23:20:02 +02:00
|
|
|
import {Component} from './component';
|
2017-08-28 14:38:32 +02:00
|
|
|
|
2023-04-19 16:20:04 +02:00
|
|
|
function toggleElem(elem, show) {
|
2023-12-12 16:38:09 +01:00
|
|
|
elem.toggleAttribute('hidden', !show);
|
2023-04-19 16:20:04 +02:00
|
|
|
}
|
|
|
|
|
2022-11-15 13:44:57 +01:00
|
|
|
export class PagePicker extends Component {
|
2017-08-28 14:38:32 +02:00
|
|
|
|
2022-11-15 13:44:57 +01:00
|
|
|
setup() {
|
|
|
|
this.input = this.$refs.input;
|
|
|
|
this.resetButton = this.$refs.resetButton;
|
|
|
|
this.selectButton = this.$refs.selectButton;
|
|
|
|
this.display = this.$refs.display;
|
|
|
|
this.defaultDisplay = this.$refs.defaultDisplay;
|
|
|
|
this.buttonSep = this.$refs.buttonSeperator;
|
2017-08-28 14:38:32 +02:00
|
|
|
|
2023-12-19 13:09:57 +01:00
|
|
|
this.selectorEndpoint = this.$opts.selectorEndpoint;
|
|
|
|
|
2017-08-28 14:38:32 +02:00
|
|
|
this.value = this.input.value;
|
|
|
|
this.setupListeners();
|
|
|
|
}
|
|
|
|
|
|
|
|
setupListeners() {
|
2018-09-20 16:27:30 +02:00
|
|
|
this.selectButton.addEventListener('click', this.showPopup.bind(this));
|
|
|
|
this.display.parentElement.addEventListener('click', this.showPopup.bind(this));
|
2023-12-12 16:38:09 +01:00
|
|
|
this.display.addEventListener('click', e => e.stopPropagation());
|
2017-08-28 14:38:32 +02:00
|
|
|
|
2023-04-19 16:20:04 +02:00
|
|
|
this.resetButton.addEventListener('click', () => {
|
2017-08-28 14:38:32 +02:00
|
|
|
this.setValue('', '');
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2018-09-20 16:27:30 +02:00
|
|
|
showPopup() {
|
2023-04-18 23:20:02 +02:00
|
|
|
/** @type {EntitySelectorPopup} * */
|
2022-11-15 13:44:57 +01:00
|
|
|
const selectorPopup = window.$components.first('entity-selector-popup');
|
|
|
|
selectorPopup.show(entity => {
|
2018-09-20 16:27:30 +02:00
|
|
|
this.setValue(entity.id, entity.name);
|
2024-01-23 16:39:09 +01:00
|
|
|
}, {
|
|
|
|
initialValue: '',
|
2023-12-19 13:09:57 +01:00
|
|
|
searchEndpoint: this.selectorEndpoint,
|
|
|
|
entityTypes: 'page',
|
|
|
|
entityPermission: 'view',
|
2018-09-20 16:27:30 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2017-08-28 14:38:32 +02:00
|
|
|
setValue(value, name) {
|
|
|
|
this.value = value;
|
|
|
|
this.input.value = value;
|
|
|
|
this.controlView(name);
|
|
|
|
}
|
|
|
|
|
|
|
|
controlView(name) {
|
2022-11-15 13:44:57 +01:00
|
|
|
const hasValue = this.value && this.value !== 0;
|
2017-08-28 14:38:32 +02:00
|
|
|
toggleElem(this.resetButton, hasValue);
|
|
|
|
toggleElem(this.buttonSep, hasValue);
|
|
|
|
toggleElem(this.defaultDisplay, !hasValue);
|
|
|
|
toggleElem(this.display, hasValue);
|
|
|
|
if (hasValue) {
|
2023-04-18 23:20:02 +02:00
|
|
|
const id = this.getAssetIdFromVal();
|
2017-08-28 14:38:32 +02:00
|
|
|
this.display.textContent = `#${id}, ${name}`;
|
|
|
|
this.display.href = window.baseUrl(`/link/${id}`);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
getAssetIdFromVal() {
|
|
|
|
return Number(this.value);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|