mirror of
https://gitgud.io/wackyideas/aerothemeplasma.git
synced 2024-08-15 00:43:43 +00:00
Very early KDE 6 release.
This commit is contained in:
parent
7cc4ccabbc
commit
686046d4f7
6272 changed files with 140920 additions and 529657 deletions
|
@ -0,0 +1,288 @@
|
|||
/*
|
||||
* Copyright 2013 Bhushan Shah <bhush94@gmail.com>
|
||||
* Copyright 2013 Sebastian Kügler <sebas@kde.org>
|
||||
* Copyright 2015 Kai Uwe Broulik <kde@privat.broulik.de>
|
||||
*
|
||||
* This program is free software; you can redistribute it and/or
|
||||
* modify it under the terms of the GNU General Public License as
|
||||
* published by the Free Software Foundation; either version 2 of
|
||||
* the License or (at your option) version 3 or any later version
|
||||
* accepted by the membership of KDE e.V. (or its successor approved
|
||||
* by the membership of KDE e.V.), which shall act as a proxy
|
||||
* defined in Section 14 of version 3 of the license.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>
|
||||
*/
|
||||
|
||||
import QtQuick 2.15
|
||||
import QtQuick.Controls as QtControls
|
||||
import QtQuick.Layouts 1.15 as QtLayouts
|
||||
import QtQuick.Dialogs 6.3 as QtDialogs
|
||||
import org.kde.plasma.plasmoid 2.0
|
||||
import org.kde.plasma.core as PlasmaCore
|
||||
import org.kde.kcmutils // For KCMLauncher
|
||||
import org.kde.config // For KAuthorized
|
||||
import org.kde.kirigami 2.20 as Kirigami
|
||||
import org.kde.plasma.workspace.calendar 2.0 as PlasmaCalendar
|
||||
|
||||
SimpleKCM {
|
||||
id: appearancePage
|
||||
width: childrenRect.width
|
||||
height: childrenRect.height
|
||||
|
||||
signal configurationChanged
|
||||
|
||||
property string cfg_fontFamily
|
||||
property string cfg_fontSize
|
||||
property alias cfg_boldText: boldCheckBox.checked
|
||||
property string cfg_timeFormat: ""
|
||||
property alias cfg_italicText: italicCheckBox.checked
|
||||
|
||||
property alias cfg_showLocalTimezone: showLocalTimezone.checked
|
||||
property alias cfg_displayTimezoneAsCode: timezoneCodeRadio.checked
|
||||
property alias cfg_showSeconds: showSeconds.checked
|
||||
|
||||
property alias cfg_showDate: showDate.checked
|
||||
property string cfg_dateFormat: "shortDate"
|
||||
property alias cfg_use24hFormat: use24hFormat.checkState
|
||||
|
||||
onCfg_fontFamilyChanged: {
|
||||
// HACK by the time we populate our model and/or the ComboBox is finished the value is still undefined
|
||||
if (cfg_fontFamily) {
|
||||
for (var i = 0, j = fontsModel.count; i < j; ++i) {
|
||||
if (fontsModel.get(i).value == cfg_fontFamily) {
|
||||
fontFamilyComboBox.currentIndex = i
|
||||
break
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
ListModel {
|
||||
id: fontsModel
|
||||
Component.onCompleted: {
|
||||
var arr = [] // use temp array to avoid constant binding stuff
|
||||
arr.push({text: i18nc("Use default font", "Default"), value: ""})
|
||||
|
||||
var fonts = Qt.fontFamilies()
|
||||
var foundIndex = 0
|
||||
for (var i = 0, j = fonts.length; i < j; ++i) {
|
||||
arr.push({text: fonts[i], value: fonts[i]})
|
||||
}
|
||||
append(arr)
|
||||
}
|
||||
}
|
||||
|
||||
ListModel {
|
||||
id: fontSizesModel
|
||||
Component.onCompleted: {
|
||||
var arr = [] // use temp array to avoid constant binding stuff
|
||||
arr.push({text: i18n("Use default font size"), value: ""})
|
||||
|
||||
var sizes = ['1', '2', '3', '4', '5', '6', '7', '8', '9', '10', '11', '12', '14', '16', '18', '20', '22', '24', '26', '28', '36', '48', '72']
|
||||
for (var i = 0, j = sizes.length; i < j; ++i) {
|
||||
arr.push({text: sizes[i], value: sizes[i]})
|
||||
}
|
||||
append(arr)
|
||||
}
|
||||
}
|
||||
|
||||
QtLayouts.ColumnLayout {
|
||||
anchors.left: parent.left
|
||||
|
||||
QtControls.GroupBox {
|
||||
QtLayouts.Layout.fillWidth: true
|
||||
title: i18n("Information")
|
||||
//flat: true
|
||||
|
||||
QtLayouts.ColumnLayout {
|
||||
QtControls.CheckBox {
|
||||
id: showDate
|
||||
text: i18n("Show date")
|
||||
}
|
||||
|
||||
QtControls.CheckBox {
|
||||
id: showSeconds
|
||||
text: i18n("Show seconds")
|
||||
}
|
||||
|
||||
QtControls.CheckBox {
|
||||
id: use24hFormat
|
||||
text: i18nc("Checkbox label; means 24h clock format, without am/pm", "Use 24-hour Clock")
|
||||
}
|
||||
|
||||
QtControls.CheckBox {
|
||||
id: showLocalTimezone
|
||||
text: i18n("Show local time zone")
|
||||
}
|
||||
|
||||
/*QtControls.Label {
|
||||
text: i18n("Display time zone as:")
|
||||
}*/
|
||||
|
||||
|
||||
QtControls.ButtonGroup {
|
||||
buttons: timezoneColumn.children
|
||||
}
|
||||
QtControls.GroupBox {
|
||||
QtLayouts.Layout.fillWidth: true
|
||||
visible: false
|
||||
//flat: true
|
||||
QtLayouts.ColumnLayout {
|
||||
|
||||
id: timezoneColumn
|
||||
//QtControls.ExclusiveGroup { id: timezoneDisplayType }
|
||||
|
||||
QtControls.RadioButton {
|
||||
id: timezoneCityRadio
|
||||
text: i18n("Time zone city")
|
||||
//exclusiveGroup: timezoneDisplayType
|
||||
}
|
||||
|
||||
QtControls.RadioButton {
|
||||
id: timezoneCodeRadio
|
||||
text: i18n("Time zone code")
|
||||
//exclusiveGroup: timezoneDisplayType
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
QtLayouts.RowLayout {
|
||||
QtControls.Label {
|
||||
text: i18n("Date format:")
|
||||
}
|
||||
|
||||
QtControls.ComboBox {
|
||||
id: dateFormat
|
||||
enabled: showDate.checked
|
||||
textRole: "label"
|
||||
model: [
|
||||
{
|
||||
'label': i18n("Long Date"),
|
||||
'name': "longDate"
|
||||
},
|
||||
{
|
||||
'label': i18n("Short Date"),
|
||||
'name': "shortDate"
|
||||
},
|
||||
{
|
||||
'label': i18n("ISO Date"),
|
||||
'name': "isoDate"
|
||||
}
|
||||
]
|
||||
onCurrentIndexChanged: cfg_dateFormat = model[currentIndex]["name"]
|
||||
|
||||
Component.onCompleted: {
|
||||
for (var i = 0; i < model.length; i++) {
|
||||
if (model[i]["name"] == Plasmoid.configuration.dateFormat) {
|
||||
dateFormat.currentIndex = i;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
QtLayouts.RowLayout {
|
||||
QtLayouts.Layout.fillWidth: true
|
||||
|
||||
QtControls.Label {
|
||||
text: i18n(" Font size px: ")
|
||||
}
|
||||
|
||||
QtControls.ComboBox {
|
||||
id: fontSizeComboBox
|
||||
QtLayouts.Layout.fillWidth: true
|
||||
// ComboBox's sizing is just utterly broken
|
||||
QtLayouts.Layout.minimumWidth: Kirigami.Units.iconSizes.small * 10
|
||||
model: fontSizesModel
|
||||
// doesn't autodeduce from model because we manually populate it
|
||||
textRole: "text"
|
||||
|
||||
onCurrentIndexChanged: {
|
||||
var current = model.get(currentIndex)
|
||||
if (current) {
|
||||
cfg_fontSize = current.value
|
||||
appearancePage.configurationChanged()
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
QtLayouts.RowLayout {
|
||||
QtLayouts.Layout.fillWidth: true
|
||||
|
||||
QtControls.Label {
|
||||
text: i18n(" Font style:")
|
||||
}
|
||||
|
||||
|
||||
QtControls.ComboBox {
|
||||
id: fontFamilyComboBox
|
||||
QtLayouts.Layout.fillWidth: true
|
||||
// ComboBox's sizing is just utterly broken
|
||||
QtLayouts.Layout.minimumWidth: Kirigami.Units.iconSizes.small * 10
|
||||
model: fontsModel
|
||||
// doesn't autodeduce from model because we manually populate it
|
||||
textRole: "text"
|
||||
|
||||
onCurrentIndexChanged: {
|
||||
var current = model.get(currentIndex)
|
||||
if (current) {
|
||||
cfg_fontFamily = current.value
|
||||
appearancePage.configurationChanged()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
QtControls.Button {
|
||||
id: boldCheckBox
|
||||
//tooltip: i18n("Bold text")
|
||||
icon.name: "format-text-bold"
|
||||
checkable: true
|
||||
//Accessible.name: tooltip
|
||||
}
|
||||
|
||||
QtControls.Button {
|
||||
id: italicCheckBox
|
||||
//tooltip: i18n("Italic text")
|
||||
icon.name: "format-text-italic"
|
||||
checkable: true
|
||||
//Accessible.name: tooltip
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Component.onCompleted: {
|
||||
if (Plasmoid.configuration.displayTimezoneAsCode) {
|
||||
timezoneCodeRadio.checked = true;
|
||||
} else {
|
||||
timezoneCityRadio.checked = true;
|
||||
}
|
||||
|
||||
for(var i = 0; i < fontsModel.count; i++) {
|
||||
if(fontsModel.get(i).value == Plasmoid.configuration.fontFamily) {
|
||||
fontFamilyComboBox.currentIndex = i;
|
||||
break;
|
||||
}
|
||||
}
|
||||
for(var i = 0; i < fontSizesModel.count; i++) {
|
||||
|
||||
if(fontSizesModel.get(i).value == Plasmoid.configuration.fontSize) {
|
||||
fontSizeComboBox.currentIndex = i;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
boldCheckBox.checked = Plasmoid.configuration.boldText;
|
||||
italicCheckBox.checked = Plasmoid.configuration.italicText;
|
||||
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue