mirror of
https://git.mirrors.martin98.com/https://github.com/Ultimaker/Cura
synced 2025-05-02 16:54:23 +08:00
203 lines
7.5 KiB
QML
203 lines
7.5 KiB
QML
// Copyright (c) 2015 Ultimaker B.V.
|
|
// Uranium is released under the terms of the AGPLv3 or higher.
|
|
|
|
import QtQuick 2.1
|
|
import QtQuick.Controls 1.1
|
|
import QtQuick.Layouts 1.1
|
|
import QtQuick.Controls.Styles 1.1
|
|
|
|
import UM 1.1 as UM
|
|
|
|
UM.PreferencesPage
|
|
{
|
|
//: General configuration page title
|
|
title: catalog.i18nc("@title:tab","General");
|
|
|
|
function reset()
|
|
{
|
|
UM.Preferences.resetPreference("general/language")
|
|
UM.Preferences.resetPreference("physics/automatic_push_free")
|
|
UM.Preferences.resetPreference("mesh/scale_to_fit")
|
|
UM.Preferences.resetPreference("info/send_slice_info")
|
|
pushFreeCheckbox.checked = boolCheck(UM.Preferences.getValue("physics/automatic_push_free"))
|
|
sendDataCheckbox.checked = boolCheck(UM.Preferences.getValue("info/send_slice_info"))
|
|
scaleToFitCheckbox.checked = boolCheck(UM.Preferences.getValue("mesh/scale_to_fit"))
|
|
languageComboBox.currentIndex = 0
|
|
}
|
|
|
|
GridLayout
|
|
{
|
|
columns: 2;
|
|
//: Language selection label
|
|
UM.I18nCatalog{id: catalog; name:"cura"}
|
|
Label
|
|
{
|
|
id: languageLabel
|
|
text: catalog.i18nc("@label","Language")
|
|
}
|
|
|
|
ComboBox
|
|
{
|
|
id: languageComboBox
|
|
model: ListModel
|
|
{
|
|
id: languageList
|
|
|
|
Component.onCompleted: {
|
|
append({ text: catalog.i18nc("@item:inlistbox", "Bulgarian"), code: "bg" })
|
|
append({ text: catalog.i18nc("@item:inlistbox", "Czech"), code: "cs" })
|
|
append({ text: catalog.i18nc("@item:inlistbox", "English"), code: "en" })
|
|
append({ text: catalog.i18nc("@item:inlistbox", "Finnish"), code: "fi" })
|
|
append({ text: catalog.i18nc("@item:inlistbox", "French"), code: "fr" })
|
|
append({ text: catalog.i18nc("@item:inlistbox", "German"), code: "de" })
|
|
append({ text: catalog.i18nc("@item:inlistbox", "Italian"), code: "it" })
|
|
append({ text: catalog.i18nc("@item:inlistbox", "Polish"), code: "pl" })
|
|
append({ text: catalog.i18nc("@item:inlistbox", "Russian"), code: "ru" })
|
|
append({ text: catalog.i18nc("@item:inlistbox", "Spanish"), code: "es" })
|
|
}
|
|
}
|
|
|
|
currentIndex:
|
|
{
|
|
var code = UM.Preferences.getValue("general/language");
|
|
for(var i = 0; i < languageList.count; ++i)
|
|
{
|
|
if(model.get(i).code == code)
|
|
{
|
|
return i
|
|
}
|
|
}
|
|
}
|
|
onActivated: UM.Preferences.setValue("general/language", model.get(index).code)
|
|
|
|
anchors.left: languageLabel.right
|
|
anchors.top: languageLabel.top
|
|
anchors.leftMargin: 20
|
|
|
|
Component.onCompleted:
|
|
{
|
|
// Because ListModel is stupid and does not allow using qsTr() for values.
|
|
for(var i = 0; i < languageList.count; ++i)
|
|
{
|
|
languageList.setProperty(i, "text", catalog.i18n(languageList.get(i).text));
|
|
}
|
|
|
|
// Glorious hack time. ComboBox does not update the text properly after changing the
|
|
// model. So change the indices around to force it to update.
|
|
currentIndex += 1;
|
|
currentIndex -= 1;
|
|
}
|
|
}
|
|
|
|
Label
|
|
{
|
|
id: languageCaption;
|
|
Layout.columnSpan: 2
|
|
|
|
//: Language change warning
|
|
text: catalog.i18nc("@label", "You will need to restart the application for language changes to have effect.")
|
|
wrapMode: Text.WordWrap
|
|
font.italic: true
|
|
}
|
|
|
|
CheckBox
|
|
{
|
|
id: pushFreeCheckbox
|
|
checked: boolCheck(UM.Preferences.getValue("physics/automatic_push_free"))
|
|
onCheckedChanged: UM.Preferences.setValue("physics/automatic_push_free", checked)
|
|
}
|
|
Button
|
|
{
|
|
id: pushFreeText //is a button so the user doesn't have te click inconvenientley precise to enable or disable the checkbox
|
|
|
|
//: Display Overhang preference checkbox
|
|
text: catalog.i18nc("@option:check", "Ensure objects are kept apart");
|
|
onClicked: pushFreeCheckbox.checked = !pushFreeCheckbox.checked
|
|
|
|
//: Display Overhang preference tooltip
|
|
tooltip: catalog.i18nc("@info:tooltip", "Should objects on the platform be moved so that they no longer intersect.")
|
|
|
|
style: ButtonStyle
|
|
{
|
|
background: Rectangle
|
|
{
|
|
border.width: 0
|
|
color: "transparent"
|
|
}
|
|
label: Text
|
|
{
|
|
renderType: Text.NativeRendering
|
|
horizontalAlignment: Text.AlignLeft
|
|
text: control.text
|
|
}
|
|
}
|
|
}
|
|
|
|
CheckBox
|
|
{
|
|
id: sendDataCheckbox
|
|
checked: boolCheck(UM.Preferences.getValue("info/send_slice_info"))
|
|
onCheckedChanged: UM.Preferences.setValue("info/send_slice_info", checked)
|
|
}
|
|
Button
|
|
{
|
|
id: sendDataText //is a button so the user doesn't have te click inconvenientley precise to enable or disable the checkbox
|
|
|
|
//: Display Overhang preference checkbox
|
|
text: catalog.i18nc("@option:check","Send (Anonymous) Print Information");
|
|
onClicked: sendDataCheckbox.checked = !sendDataCheckbox.checked
|
|
|
|
//: Display Overhang preference tooltip
|
|
tooltip: catalog.i18nc("@info:tooltip","Should anonymous data about your print be sent to Ultimaker? Note, no models, IP addresses or other personally identifiable information is sent or stored.")
|
|
|
|
style: ButtonStyle
|
|
{
|
|
background: Rectangle
|
|
{
|
|
border.width: 0
|
|
color: "transparent"
|
|
}
|
|
label: Text
|
|
{
|
|
renderType: Text.NativeRendering
|
|
horizontalAlignment: Text.AlignLeft
|
|
text: control.text
|
|
}
|
|
}
|
|
}
|
|
CheckBox
|
|
{
|
|
id: scaleToFitCheckbox
|
|
checked: boolCheck(UM.Preferences.getValue("mesh/scale_to_fit"))
|
|
onCheckedChanged: UM.Preferences.setValue("mesh/scale_to_fit", checked)
|
|
}
|
|
Button
|
|
{
|
|
id: scaleToFitText //is a button so the user doesn't have te click inconvenientley precise to enable or disable the checkbox
|
|
|
|
//: Display Overhang preference checkbox
|
|
text: catalog.i18nc("@option:check","Scale Too Large Files");
|
|
onClicked: scaleToFitCheckbox.checked = !scaleToFitCheckbox.checked
|
|
|
|
//: Display Overhang preference tooltip
|
|
tooltip: catalog.i18nc("@info:tooltip","Should opened files be scaled to the build volume when they are too large?")
|
|
|
|
style: ButtonStyle
|
|
{
|
|
background: Rectangle
|
|
{
|
|
border.width: 0
|
|
color: "transparent"
|
|
}
|
|
label: Text
|
|
{
|
|
renderType: Text.NativeRendering
|
|
horizontalAlignment: Text.AlignLeft
|
|
text: control.text
|
|
}
|
|
}
|
|
}
|
|
Item { Layout.fillHeight: true; Layout.columnSpan: 2 }
|
|
}
|
|
}
|