mirror of
https://github.com/GNS3/gns3-web-ui.git
synced 2025-01-18 18:56:26 +00:00
Toggle button added
This commit is contained in:
parent
fc21c0717f
commit
1db8157f1a
@ -153,6 +153,10 @@ export class D3MapComponent implements OnInit, OnChanges, OnDestroy {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public applyMapSettingsChanges() {
|
||||||
|
this.redraw();
|
||||||
|
}
|
||||||
|
|
||||||
public createGraph(domElement: HTMLElement) {
|
public createGraph(domElement: HTMLElement) {
|
||||||
const rootElement = select(domElement);
|
const rootElement = select(domElement);
|
||||||
this.svg = rootElement.select<SVGSVGElement>('svg');
|
this.svg = rootElement.select<SVGSVGElement>('svg');
|
||||||
|
@ -13,6 +13,7 @@ import { SelectionManager } from '../managers/selection-manager';
|
|||||||
import { LineElement } from '../models/drawings/line-element';
|
import { LineElement } from '../models/drawings/line-element';
|
||||||
import { EllipseElement } from '../models/drawings/ellipse-element';
|
import { EllipseElement } from '../models/drawings/ellipse-element';
|
||||||
import { RectElement } from '../models/drawings/rect-element';
|
import { RectElement } from '../models/drawings/rect-element';
|
||||||
|
import { MapSettingsService } from '../../services/mapsettings.service';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class DrawingWidget implements Widget {
|
export class DrawingWidget implements Widget {
|
||||||
@ -24,7 +25,8 @@ export class DrawingWidget implements Widget {
|
|||||||
private rectDrawingWidget: RectDrawingWidget,
|
private rectDrawingWidget: RectDrawingWidget,
|
||||||
private lineDrawingWidget: LineDrawingWidget,
|
private lineDrawingWidget: LineDrawingWidget,
|
||||||
private ellipseDrawingWidget: EllipseDrawingWidget,
|
private ellipseDrawingWidget: EllipseDrawingWidget,
|
||||||
private selectionManager: SelectionManager
|
private selectionManager: SelectionManager,
|
||||||
|
private mapSettingsService: MapSettingsService
|
||||||
) {
|
) {
|
||||||
this.drawingWidgets = [
|
this.drawingWidgets = [
|
||||||
this.textDrawingWidget,
|
this.textDrawingWidget,
|
||||||
@ -52,36 +54,40 @@ export class DrawingWidget implements Widget {
|
|||||||
});
|
});
|
||||||
|
|
||||||
drawing_body_merge.select('.layer_label_wrapper').remove();
|
drawing_body_merge.select('.layer_label_wrapper').remove();
|
||||||
drawing_body_merge
|
if (this.mapSettingsService.isLayerNumberVisible) {
|
||||||
.filter(n => ((n.element instanceof RectElement) || (n.element instanceof EllipseElement)))
|
drawing_body_merge
|
||||||
.append<SVGRectElement>('rect')
|
.filter(n => ((n.element instanceof RectElement) || (n.element instanceof EllipseElement)))
|
||||||
.attr('class', 'layer_label_wrapper')
|
.append<SVGRectElement>('rect')
|
||||||
.attr('width', '26')
|
.attr('class', 'layer_label_wrapper')
|
||||||
.attr('height', '26')
|
.attr('width', '26')
|
||||||
.attr('x', n => n.element ? n.element.width/2 - 13 : 0)
|
.attr('height', '26')
|
||||||
.attr('y', n => n.element ? n.element.height/2 - 13 : 0)
|
.attr('x', n => n.element ? n.element.width/2 - 13 : 0)
|
||||||
.attr('fill', 'red');
|
.attr('y', n => n.element ? n.element.height/2 - 13 : 0)
|
||||||
|
.attr('fill', 'red');
|
||||||
|
}
|
||||||
|
|
||||||
drawing_body_merge.select('.layer_label').remove();
|
drawing_body_merge.select('.layer_label').remove();
|
||||||
drawing_body_merge
|
if (this.mapSettingsService.isLayerNumberVisible) {
|
||||||
.filter(n => ((n.element instanceof RectElement) || (n.element instanceof EllipseElement)))
|
drawing_body_merge
|
||||||
.append<SVGTextElement>('text')
|
.filter(n => ((n.element instanceof RectElement) || (n.element instanceof EllipseElement)))
|
||||||
.attr('class', 'layer_label')
|
.append<SVGTextElement>('text')
|
||||||
.text((elem) => elem.z)
|
.attr('class', 'layer_label')
|
||||||
.attr('x', function(n) {
|
.text((elem) => elem.z)
|
||||||
if(n.z >= 100 ) return n.element ? n.element.width/2 - 13 : 0
|
.attr('x', function(n) {
|
||||||
else if(n.z >= 10 ) return n.element ? n.element.width/2 - 9 : 0
|
if(n.z >= 100 ) return n.element ? n.element.width/2 - 13 : 0
|
||||||
else return n.element.width/2 - 5
|
else if(n.z >= 10 ) return n.element ? n.element.width/2 - 9 : 0
|
||||||
})
|
else return n.element.width/2 - 5
|
||||||
.attr('y', n => n.element ? n.element.height/2 + 5 : 0)
|
})
|
||||||
.attr('style', () => {
|
.attr('y', n => n.element ? n.element.height/2 + 5 : 0)
|
||||||
const styles: string[] = [];
|
.attr('style', () => {
|
||||||
styles.push(`font-family: "Noto Sans"`);
|
const styles: string[] = [];
|
||||||
styles.push(`font-size: 11pt`);
|
styles.push(`font-family: "Noto Sans"`);
|
||||||
styles.push(`font-weight: bold`);
|
styles.push(`font-size: 11pt`);
|
||||||
return styles.join('; ');
|
styles.push(`font-weight: bold`);
|
||||||
})
|
return styles.join('; ');
|
||||||
.attr('fill', `#ffffff`);
|
})
|
||||||
|
.attr('fill', `#ffffff`);
|
||||||
|
}
|
||||||
|
|
||||||
drawing_body_merge
|
drawing_body_merge
|
||||||
.select<SVGAElement>('line.top')
|
.select<SVGAElement>('line.top')
|
||||||
|
@ -10,6 +10,7 @@ import { SelectionManager } from '../managers/selection-manager';
|
|||||||
import { LabelWidget } from './label';
|
import { LabelWidget } from './label';
|
||||||
import { NodesEventSource } from '../events/nodes-event-source';
|
import { NodesEventSource } from '../events/nodes-event-source';
|
||||||
import { ClickedDataEvent } from '../events/event-source';
|
import { ClickedDataEvent } from '../events/event-source';
|
||||||
|
import { MapSettingsService } from '../../services/mapsettings.service';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class NodeWidget implements Widget {
|
export class NodeWidget implements Widget {
|
||||||
@ -20,7 +21,8 @@ export class NodeWidget implements Widget {
|
|||||||
private graphDataManager: GraphDataManager,
|
private graphDataManager: GraphDataManager,
|
||||||
private selectionManager: SelectionManager,
|
private selectionManager: SelectionManager,
|
||||||
private labelWidget: LabelWidget,
|
private labelWidget: LabelWidget,
|
||||||
private nodesEventSource: NodesEventSource
|
private nodesEventSource: NodesEventSource,
|
||||||
|
private mapSettingsService: MapSettingsService
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
public draw(view: SVGSelection) {
|
public draw(view: SVGSelection) {
|
||||||
@ -43,34 +45,38 @@ export class NodeWidget implements Widget {
|
|||||||
});
|
});
|
||||||
|
|
||||||
node_body_merge.select('.layer_label_wrapper').remove();
|
node_body_merge.select('.layer_label_wrapper').remove();
|
||||||
node_body_merge
|
if (this.mapSettingsService.isLayerNumberVisible) {
|
||||||
.append<SVGRectElement>('rect')
|
node_body_merge
|
||||||
.attr('class', 'layer_label_wrapper')
|
.append<SVGRectElement>('rect')
|
||||||
.attr('width', '26')
|
.attr('class', 'layer_label_wrapper')
|
||||||
.attr('height', '26')
|
.attr('width', '26')
|
||||||
.attr('x', (n: MapNode) => n.width/2 - 13)
|
.attr('height', '26')
|
||||||
.attr('y', (n: MapNode) => n.height/2 - 13)
|
.attr('x', (n: MapNode) => n.width/2 - 13)
|
||||||
.attr('fill', 'red');
|
.attr('y', (n: MapNode) => n.height/2 - 13)
|
||||||
|
.attr('fill', 'red');
|
||||||
|
}
|
||||||
|
|
||||||
node_body_merge.select('.layer_label').remove();
|
node_body_merge.select('.layer_label').remove();
|
||||||
node_body_merge
|
if (this.mapSettingsService.isLayerNumberVisible) {
|
||||||
.append<SVGTextElement>('text')
|
node_body_merge
|
||||||
.attr('class', 'layer_label')
|
.append<SVGTextElement>('text')
|
||||||
.text((n: MapNode) => { return n.z})
|
.attr('class', 'layer_label')
|
||||||
.attr('x', function(n: MapNode) {
|
.text((n: MapNode) => { return n.z})
|
||||||
if(n.z >= 100 ) return n.width/2 - 13
|
.attr('x', function(n: MapNode) {
|
||||||
else if(n.z >= 10 ) return n.width/2 - 9
|
if(n.z >= 100 ) return n.width/2 - 13
|
||||||
else return n.width/2 - 5
|
else if(n.z >= 10 ) return n.width/2 - 9
|
||||||
})
|
else return n.width/2 - 5
|
||||||
.attr('y', (n: MapNode) => n.height/2 + 5)
|
})
|
||||||
.attr('style', () => {
|
.attr('y', (n: MapNode) => n.height/2 + 5)
|
||||||
const styles: string[] = [];
|
.attr('style', () => {
|
||||||
styles.push(`font-family: "Noto Sans"`);
|
const styles: string[] = [];
|
||||||
styles.push(`font-size: 11pt`);
|
styles.push(`font-family: "Noto Sans"`);
|
||||||
styles.push(`font-weight: bold`);
|
styles.push(`font-size: 11pt`);
|
||||||
return styles.join('; ');
|
styles.push(`font-weight: bold`);
|
||||||
})
|
return styles.join('; ');
|
||||||
.attr('fill', `#ffffff`);
|
})
|
||||||
|
.attr('fill', `#ffffff`);
|
||||||
|
}
|
||||||
|
|
||||||
// update image of node
|
// update image of node
|
||||||
node_body_merge
|
node_body_merge
|
||||||
|
@ -90,6 +90,9 @@
|
|||||||
<mat-checkbox [ngModel]="notificationsVisibility" (change)="toggleNotifications($event.checked)">
|
<mat-checkbox [ngModel]="notificationsVisibility" (change)="toggleNotifications($event.checked)">
|
||||||
Show notifications
|
Show notifications
|
||||||
</mat-checkbox>
|
</mat-checkbox>
|
||||||
|
<mat-checkbox [ngModel]="layersVisibility" (change)="toggleLayers($event.checked)">
|
||||||
|
Show layers
|
||||||
|
</mat-checkbox>
|
||||||
</div>
|
</div>
|
||||||
</mat-menu>
|
</mat-menu>
|
||||||
|
|
||||||
|
@ -83,6 +83,7 @@ export class ProjectMapComponent implements OnInit, OnDestroy {
|
|||||||
public isTopologySummaryVisible: boolean = false;
|
public isTopologySummaryVisible: boolean = false;
|
||||||
public isInterfaceLabelVisible: boolean = false;
|
public isInterfaceLabelVisible: boolean = false;
|
||||||
public notificationsVisibility: boolean = false;
|
public notificationsVisibility: boolean = false;
|
||||||
|
public layersVisibility: boolean = false;
|
||||||
|
|
||||||
tools = {
|
tools = {
|
||||||
selection: true,
|
selection: true,
|
||||||
@ -238,6 +239,7 @@ export class ProjectMapComponent implements OnInit, OnDestroy {
|
|||||||
}));
|
}));
|
||||||
|
|
||||||
this.notificationsVisibility = localStorage.getItem('notificationsVisibility') === 'true' ? true : false;
|
this.notificationsVisibility = localStorage.getItem('notificationsVisibility') === 'true' ? true : false;
|
||||||
|
this.layersVisibility = localStorage.getItem('layersVisibility') === 'true' ? true : false;
|
||||||
this.addKeyboardListeners();
|
this.addKeyboardListeners();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -479,6 +481,17 @@ export class ProjectMapComponent implements OnInit, OnDestroy {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public toggleLayers(visible: boolean) {
|
||||||
|
this.layersVisibility = visible;
|
||||||
|
this.mapSettingsService.toggleLayers(visible);
|
||||||
|
if (this.layersVisibility) {
|
||||||
|
localStorage.setItem('layersVisibility', 'true');
|
||||||
|
} else {
|
||||||
|
localStorage.removeItem('layersVisibility')
|
||||||
|
}
|
||||||
|
this.mapChild.applyMapSettingsChanges();
|
||||||
|
}
|
||||||
|
|
||||||
private showMessage(msg) {
|
private showMessage(msg) {
|
||||||
if (this.notificationsVisibility) {
|
if (this.notificationsVisibility) {
|
||||||
if (msg.type === 'error') this.toasterService.error(msg.message);
|
if (msg.type === 'error') this.toasterService.error(msg.message);
|
||||||
|
@ -6,9 +6,12 @@ export class MapSettingsService {
|
|||||||
public isMapLocked = new Subject<boolean>();
|
public isMapLocked = new Subject<boolean>();
|
||||||
public isTopologySummaryVisible: boolean = false;
|
public isTopologySummaryVisible: boolean = false;
|
||||||
public isLogConsoleVisible: boolean = false;
|
public isLogConsoleVisible: boolean = false;
|
||||||
|
public isLayerNumberVisible: boolean = false;
|
||||||
public interfaceLabels: Map<string, boolean> = new Map<string, boolean>();
|
public interfaceLabels: Map<string, boolean> = new Map<string, boolean>();
|
||||||
|
|
||||||
constructor() {}
|
constructor() {
|
||||||
|
this.isLayerNumberVisible = localStorage.getItem('layersVisibility') === 'true' ? true : false;
|
||||||
|
}
|
||||||
|
|
||||||
changeMapLockValue(value: boolean) {
|
changeMapLockValue(value: boolean) {
|
||||||
this.isMapLocked.next(value);
|
this.isMapLocked.next(value);
|
||||||
@ -22,6 +25,10 @@ export class MapSettingsService {
|
|||||||
this.isLogConsoleVisible = value;
|
this.isLogConsoleVisible = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
toggleLayers(value: boolean) {
|
||||||
|
this.isLayerNumberVisible = value;
|
||||||
|
}
|
||||||
|
|
||||||
toggleShowInterfaceLabels(projectId: string, value: boolean) {
|
toggleShowInterfaceLabels(projectId: string, value: boolean) {
|
||||||
this.interfaceLabels.set(projectId, value);
|
this.interfaceLabels.set(projectId, value);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user