Controlando a Orientação
Agora é hora de melhorar a apresentação do nosso gráfico. Para isso, adicionaremos dois botões que encaixarão nosso painel à esquerda e na parte inferior da tela. Você só precisa adicionar o snippet abaixo dentro da função initialize
da classe PhasingPanel
:
...
initialize() {
this.title = this.createTitleBar(this.titleLabel || this.container.id);
this.title.style.overflow = 'auto';
this.initializeMoveHandlers(this.title);
this.container.appendChild(this.title);
this.div = document.createElement('div');
this.container.appendChild(this.div);
//Here we create a dropdown to control vision of the GANTT
this.dropdown = document.createElement('select');
this.dropdown.style.width = (this.options.dropdownWidth || 100) + 'px';
this.dropdown.style.height = (this.options.dropdownHeight || 28) + 'px';
this.dropdown.style.margin = (this.options.margin || 5) + 'px';
this.dropdown.style.verticalAlign = (this.options.verticalAlign || 'middle');
this.dropdown.style.backgroundColor = (this.options.backgroundColor || 'white');
this.dropdown.style.borderRadius = (this.options.borderRadius || 8) + 'px';
this.dropdown.style.borderStyle = (this.options.borderStyle || 'groove');
for (const viewMode of phasing_config.viewModes) {
let currentOption = document.createElement('option');
currentOption.value = viewMode;
currentOption.innerHTML = viewMode;
this.dropdown.appendChild(currentOption);
}
this.dropdown.onchange = this.changeViewMode.bind(this);
this.div.appendChild(this.dropdown);
//Here we create a switch to control vision of the schedule based on the GANTT chart
this.checkbox = document.createElement('input');
this.checkbox.type = 'checkbox';
this.checkbox.id = 'colormodel';
this.checkbox.style.width = (this.options.checkboxWidth || 30) + 'px';
this.checkbox.style.height = (this.options.checkboxHeight || 28) + 'px';
this.checkbox.style.margin = '0 0 0 ' + (this.options.margin || 5) + 'px';
this.checkbox.style.verticalAlign = (this.options.verticalAlign || 'middle');
this.checkbox.style.backgroundColor = (this.options.backgroundColor || 'white');
this.checkbox.style.borderRadius = (this.options.borderRadius || 8) + 'px';
this.checkbox.style.borderStyle = (this.options.borderStyle || 'groove');
this.checkbox.onchange = this.handleColors.bind(this);
this.div.appendChild(this.checkbox);
this.label = document.createElement('label');
this.label.for = 'colormodel';
this.label.innerHTML = 'Show Phases';
this.label.style.fontSize = (this.options.fontSize || 18) + 'px';
this.label.style.verticalAlign = (this.options.verticalAlign || 'middle');
this.div.appendChild(this.label);
//Here we add the svg for the GANTT chart
this.content = document.createElement('div');
this.content.style.backgroundColor = (this.options.backgroundColor || 'white');
this.content.innerHTML = `<svg id="phasing-container"></svg>`;
this.container.appendChild(this.content);
========START OF THE ADDITIONAL CONTENT========
this.dockleft = document.createElement('img');
//https://icons8.com/icon/105589/left-docking
this.dockleft.src = '';
this.dockleft.style.width = (this.options.imageWidth || 30) + 'px';
this.dockleft.style.height = (this.options.imageHeight || 28) + 'px';
this.dockleft.style.margin = '0 0 0 ' + (this.options.margin || 10) + 'px';
this.dockleft.style.verticalAlign = (this.options.verticalAlign || 'middle');
this.dockleft.onclick = this.toggleOrientation.bind(this, false);
this.div.appendChild(this.dockleft);
this.dockbottom = document.createElement('img');
//https://icons8.com/icon/105606/bottom-docking
this.dockbottom.src = '';
this.dockbottom.style.width = (this.options.imageWidth || 30) + 'px';
this.dockbottom.style.height = (this.options.imageHeight || 28) + 'px';
this.dockbottom.style.margin = '0 0 0 ' + (this.options.margin || 10) + 'px';
this.dockbottom.style.verticalAlign = (this.options.verticalAlign || 'middle');
this.dockbottom.onclick = this.toggleOrientation.bind(this, true);
this.div.appendChild(this.dockbottom);
========END OF THE ADDITIONAL CONTENT========
this.updateTasks();
}
changeViewMode(event) {
const viewMode = event ? event.target.value : this.currentViewMode;
this.gantt.change_view_mode(viewMode);
this.handleColors.call(this);
this.currentViewMode = viewMode;
}
========START OF THE ADDITIONAL CONTENT========
toggleOrientation(isVertical) {
const { left: startX, top: startY, right: endX, bottom: endY } = this.extension.viewer.impl.getCanvasBoundingClientRect();
let defaultPanelHeigth = (this.options.height || 400);
let defaultPanelWidth = (this.options.width || 500);
if (isVertical) {
this.container.style.width = (endX - startX - 20) + 'px';
this.container.style.height = defaultPanelHeigth + 'px';
this.container.style.left = (this.options.x || 0) + 'px';
this.container.style.top = (endY - startY - defaultPanelHeigth - this.options.y) + 'px';
}
else {
this.container.style.width = defaultPanelWidth + 'px';
this.container.style.height = (endY - startY - 20) + 'px';
this.container.style.left = (this.options.x || 0) + 'px';
this.container.style.top = (this.options.y || 0) + 'px';
}
}
========END OF THE ADDITIONAL CONTENT========
...