1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92
|
/*
* 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.5
import QtQuick.Controls 2.5 as QQC2
import org.kde.kcm 1.1 as KCM
import org.kde.plasma.core 2.0 as PlasmaCore
KCM.GridView {
id: appearancePage
property string cfg_color
contentWidth: implicitWidth
contentHeight: implicitHeight
PlasmaCore.Svg {
id: noteSvg
imagePath: "widgets/notes"
}
view.model: ["white", "black", "red", "orange", "yellow", "green", "blue", "pink", "translucent", "translucent-light"]
view.currentIndex: view.model.indexOf(cfg_color)
view.onCurrentIndexChanged: cfg_color = view.model[view.currentIndex]
view.delegate: KCM.GridDelegate {
id: delegate
thumbnailAvailable: true
thumbnail: PlasmaCore.SvgItem {
anchors.fill: parent
anchors.margins: units.gridUnit / 2
svg: noteSvg
elementId: modelData + "-notes"
QQC2.Label {
anchors.fill: parent
horizontalAlignment: Text.AlignHCenter
verticalAlignment: Text.AlignVCenter
text: {
switch (modelData) {
case "white": return i18n("A white sticky note")
case "black": return i18n("A black sticky note")
case "red": return i18n("A red sticky note")
case "orange": return i18n("An orange sticky note")
case "yellow": return i18n("A yellow sticky note")
case "green": return i18n("A green sticky note")
case "blue": return i18n("A blue sticky note")
case "pink": return i18n("A pink sticky note")
case "translucent": return i18n("A translucent sticky note")
case "translucent-light": return i18n("A translucent sticky note with light text")
}
}
elide: Text.ElideRight
wrapMode: Text.WordWrap
//this is deliberately _NOT_ the theme color as we are over a known bright background
//an unknown colour over a known colour is a bad move as you end up with white on yellow
color: {
if (modelData === "black" || modelData === "translucent-light") {
return "#dfdfdf"
} else {
return "#202020"
}
}
}
}
onClicked: {
cfg_color = modelData
appearancePage.forceActiveFocus();
}
}
}
|