mirror of
https://github.com/BookStackApp/BookStack.git
synced 2024-12-02 05:43:40 +08:00
9a17656f88
Updated dom layout of attahcments to prevent nested dropzones (No issue but potential to be one) and updated edit form dropzone handling so the dropzone item card was not as distracting.
58 lines
1.8 KiB
JavaScript
58 lines
1.8 KiB
JavaScript
import {Component} from './component';
|
|
|
|
export class EditorToolbox extends Component {
|
|
|
|
setup() {
|
|
// Elements
|
|
this.container = this.$el;
|
|
this.buttons = this.$manyRefs.tabButton;
|
|
this.contentElements = this.$manyRefs.tabContent;
|
|
this.toggleButton = this.$refs.toggle;
|
|
|
|
this.setupListeners();
|
|
|
|
// Set the first tab as active on load
|
|
this.setActiveTab(this.contentElements[0].dataset.tabContent);
|
|
}
|
|
|
|
setupListeners() {
|
|
// Toolbox toggle button click
|
|
this.toggleButton.addEventListener('click', () => this.toggle());
|
|
// Tab button click
|
|
this.container.addEventListener('click', event => {
|
|
const button = event.target.closest('button');
|
|
if (this.buttons.includes(button)) {
|
|
const name = button.dataset.tab;
|
|
this.setActiveTab(name, true);
|
|
}
|
|
});
|
|
}
|
|
|
|
toggle() {
|
|
this.container.classList.toggle('open');
|
|
const expanded = this.container.classList.contains('open') ? 'true' : 'false';
|
|
this.toggleButton.setAttribute('aria-expanded', expanded);
|
|
}
|
|
|
|
setActiveTab(tabName, openToolbox = false) {
|
|
// Set button visibility
|
|
for (const button of this.buttons) {
|
|
button.classList.remove('active');
|
|
const bName = button.dataset.tab;
|
|
if (bName === tabName) button.classList.add('active');
|
|
}
|
|
|
|
// Set content visibility
|
|
for (const contentEl of this.contentElements) {
|
|
contentEl.style.display = 'none';
|
|
const cName = contentEl.dataset.tabContent;
|
|
if (cName === tabName) contentEl.style.display = 'block';
|
|
}
|
|
|
|
if (openToolbox && !this.container.classList.contains('open')) {
|
|
this.toggle();
|
|
}
|
|
}
|
|
|
|
}
|