123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247 |
- // Copyright (c) 2017 Ultimaker B.V.
- // Cura is released under the terms of the LGPLv3 or higher.
- import QtQuick 2.2
- import QtQuick.Controls 1.1
- import QtQuick.Controls.Styles 1.1
- import QtQuick.Layouts 1.1
- import UM 1.4 as UM
- import Cura 1.0 as Cura
- import "Menus"
- Rectangle
- {
- id: base
- anchors.left: parent.left
- anchors.right: parent.right
- height: UM.Theme.getSize("sidebar_header").height
- color: UM.Controller.activeStage.stageId == "MonitorStage" ? UM.Theme.getColor("topbar_background_color_monitoring") : UM.Theme.getColor("topbar_background_color")
- property bool printerConnected: Cura.MachineManager.printerConnected
- property bool printerAcceptsCommands: printerConnected && Cura.MachineManager.printerOutputDevices[0].acceptsCommands
- property int rightMargin: UM.Theme.getSize("sidebar").width + UM.Theme.getSize("default_margin").width;
- property int allItemsWidth: 0;
- function updateMarginsAndSizes() {
- if (UM.Preferences.getValue("cura/sidebar_collapsed"))
- {
- rightMargin = UM.Theme.getSize("default_margin").width;
- }
- else
- {
- rightMargin = UM.Theme.getSize("sidebar").width + UM.Theme.getSize("default_margin").width;
- }
- allItemsWidth = (
- logo.width + UM.Theme.getSize("topbar_logo_right_margin").width +
- UM.Theme.getSize("topbar_logo_right_margin").width + stagesMenuContainer.width +
- UM.Theme.getSize("default_margin").width + viewModeButton.width +
- rightMargin);
- }
- UM.I18nCatalog
- {
- id: catalog
- name:"cura"
- }
- Image
- {
- id: logo
- anchors.left: parent.left
- anchors.leftMargin: UM.Theme.getSize("default_margin").width
- anchors.verticalCenter: parent.verticalCenter
- source: UM.Theme.getImage("logo");
- width: UM.Theme.getSize("logo").width;
- height: UM.Theme.getSize("logo").height;
- sourceSize.width: width;
- sourceSize.height: height;
- }
- Row
- {
- id: stagesMenuContainer
- anchors.left: logo.right
- anchors.leftMargin: UM.Theme.getSize("topbar_logo_right_margin").width
- spacing: UM.Theme.getSize("default_margin").width
- // The topbar is dynamically filled with all available stages
- Repeater
- {
- id: stagesMenu
- model: UM.StageModel{}
- delegate: Button
- {
- text: model.name
- checkable: true
- checked: model.active
- exclusiveGroup: topbarMenuGroup
- style: (model.stage.iconSource != "") ? UM.Theme.styles.topbar_header_tab_no_overlay : UM.Theme.styles.topbar_header_tab
- height: UM.Theme.getSize("sidebar_header").height
- onClicked: UM.Controller.setActiveStage(model.id)
- iconSource: model.stage.iconSource
- property color overlayColor: "transparent"
- property string overlayIconSource: ""
- }
- }
- ExclusiveGroup { id: topbarMenuGroup }
- }
- // View orientation Item
- Row
- {
- id: viewOrientationControl
- height: 30
- spacing: 2
- visible: UM.Controller.activeStage.stageId != "MonitorStage"
- anchors
- {
- verticalCenter: base.verticalCenter
- right: viewModeButton.left
- rightMargin: UM.Theme.getSize("default_margin").width
- }
- // #1 3d view
- Button
- {
- iconSource: UM.Theme.getIcon("view_3d")
- style: UM.Theme.styles.small_tool_button
- anchors.verticalCenter: viewOrientationControl.verticalCenter
- onClicked:UM.Controller.rotateView("3d", 0)
- visible: base.width - allItemsWidth - 4 * this.width > 0
- }
- // #2 Front view
- Button
- {
- iconSource: UM.Theme.getIcon("view_front")
- style: UM.Theme.styles.small_tool_button
- anchors.verticalCenter: viewOrientationControl.verticalCenter
- onClicked: UM.Controller.rotateView("home", 0);
- visible: base.width - allItemsWidth - 3 * this.width > 0
- }
- // #3 Top view
- Button
- {
- iconSource: UM.Theme.getIcon("view_top")
- style: UM.Theme.styles.small_tool_button
- anchors.verticalCenter: viewOrientationControl.verticalCenter
- onClicked: UM.Controller.rotateView("y", 90)
- visible: base.width - allItemsWidth - 2 * this.width > 0
- }
- // #4 Left view
- Button
- {
- iconSource: UM.Theme.getIcon("view_left")
- style: UM.Theme.styles.small_tool_button
- anchors.verticalCenter: viewOrientationControl.verticalCenter
- onClicked: UM.Controller.rotateView("x", 90)
- visible: base.width - allItemsWidth - 1 * this.width > 0
- }
- // #5 Right view
- Button
- {
- iconSource: UM.Theme.getIcon("view_right")
- style: UM.Theme.styles.small_tool_button
- anchors.verticalCenter: viewOrientationControl.verticalCenter
- onClicked: UM.Controller.rotateView("x", -90)
- visible: base.width - allItemsWidth > 0
- }
- }
- ComboBox
- {
- id: viewModeButton
- anchors {
- verticalCenter: parent.verticalCenter
- right: parent.right
- rightMargin: rightMargin
- }
- style: UM.Theme.styles.combobox
- visible: UM.Controller.activeStage.stageId != "MonitorStage"
- model: UM.ViewModel { }
- textRole: "name"
- // update the model's active index
- function updateItemActiveFlags () {
- currentIndex = getActiveIndex()
- for (var i = 0; i < model.rowCount(); i++) {
- model.getItem(i).active = (i == currentIndex)
- }
- }
- // get the index of the active model item on start
- function getActiveIndex () {
- for (var i = 0; i < model.rowCount(); i++) {
- if (model.getItem(i).active) {
- return i
- }
- }
- return 0
- }
- // set the active index
- function setActiveIndex (index) {
- UM.Controller.setActiveView(index)
- // the connection to UM.ActiveView will trigger update so there is no reason to call it manually here
- }
- onCurrentIndexChanged:
- {
- if (model.getItem(currentIndex).id != undefined)
- viewModeButton.setActiveIndex(model.getItem(currentIndex).id)
- }
- currentIndex: getActiveIndex()
- // watch the active view proxy for changes made from the menu item
- Connections
- {
- target: UM.ActiveView
- onActiveViewChanged: viewModeButton.updateItemActiveFlags()
- }
- }
- Loader
- {
- id: view_panel
- anchors.top: viewModeButton.bottom
- anchors.topMargin: UM.Theme.getSize("default_margin").height
- anchors.right: viewModeButton.right
- property var buttonTarget: Qt.point(viewModeButton.x + Math.round(viewModeButton.width / 2), viewModeButton.y + Math.round(viewModeButton.height / 2))
- height: childrenRect.height
- width: childrenRect.width
- source: UM.ActiveView.valid ? UM.ActiveView.activeViewPanel : "";
- }
- // Expand or collapse sidebar
- Connections
- {
- target: Cura.Actions.expandSidebar
- onTriggered: updateMarginsAndSizes()
- }
- Component.onCompleted:
- {
- updateMarginsAndSizes();
- }
- }
|