mirror of
https://github.com/AvengeMedia/DankMaterialShell.git
synced 2025-12-10 07:25:37 -05:00
plugins: fix variant syncing
This commit is contained in:
@@ -8,11 +8,12 @@ Item {
|
|||||||
|
|
||||||
required property string pluginId
|
required property string pluginId
|
||||||
property var pluginService: null
|
property var pluginService: null
|
||||||
default property alias content: settingsColumn.children
|
default property list<QtObject> content
|
||||||
|
|
||||||
signal settingChanged()
|
signal settingChanged()
|
||||||
|
|
||||||
property var variants: []
|
property var variants: []
|
||||||
|
property alias variantsModel: variantsListModel
|
||||||
|
|
||||||
implicitHeight: hasPermission ? settingsColumn.implicitHeight : errorText.implicitHeight
|
implicitHeight: hasPermission ? settingsColumn.implicitHeight : errorText.implicitHeight
|
||||||
height: implicitHeight
|
height: implicitHeight
|
||||||
@@ -33,8 +34,8 @@ Item {
|
|||||||
onPluginServiceChanged: {
|
onPluginServiceChanged: {
|
||||||
if (pluginService) {
|
if (pluginService) {
|
||||||
loadVariants()
|
loadVariants()
|
||||||
for (let i = 0; i < settingsColumn.children.length; i++) {
|
for (let i = 0; i < content.length; i++) {
|
||||||
const child = settingsColumn.children[i]
|
const child = content[i]
|
||||||
if (child.loadValue) {
|
if (child.loadValue) {
|
||||||
child.loadValue()
|
child.loadValue()
|
||||||
}
|
}
|
||||||
@@ -42,6 +43,15 @@ Item {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
onContentChanged: {
|
||||||
|
for (let i = 0; i < content.length; i++) {
|
||||||
|
const item = content[i]
|
||||||
|
if (item instanceof Item) {
|
||||||
|
item.parent = settingsColumn
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Connections {
|
Connections {
|
||||||
target: pluginService
|
target: pluginService
|
||||||
function onPluginDataChanged(changedPluginId) {
|
function onPluginDataChanged(changedPluginId) {
|
||||||
@@ -57,6 +67,22 @@ Item {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
variants = pluginService.getPluginVariants(pluginId)
|
variants = pluginService.getPluginVariants(pluginId)
|
||||||
|
syncVariantsToModel()
|
||||||
|
}
|
||||||
|
|
||||||
|
function syncVariantsToModel() {
|
||||||
|
variantsListModel.clear()
|
||||||
|
for (let i = 0; i < variants.length; i++) {
|
||||||
|
variantsListModel.append(variants[i])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
onVariantsChanged: {
|
||||||
|
syncVariantsToModel()
|
||||||
|
}
|
||||||
|
|
||||||
|
ListModel {
|
||||||
|
id: variantsListModel
|
||||||
}
|
}
|
||||||
|
|
||||||
function createVariant(variantName, variantConfig) {
|
function createVariant(variantName, variantConfig) {
|
||||||
|
|||||||
@@ -256,11 +256,9 @@ FocusScope {
|
|||||||
anchors.bottomMargin: pluginDelegate.isExpanded ? settingsContainer.height : 0
|
anchors.bottomMargin: pluginDelegate.isExpanded ? settingsContainer.height : 0
|
||||||
hoverEnabled: true
|
hoverEnabled: true
|
||||||
cursorShape: pluginDelegate.hasSettings ? Qt.PointingHandCursor : Qt.ArrowCursor
|
cursorShape: pluginDelegate.hasSettings ? Qt.PointingHandCursor : Qt.ArrowCursor
|
||||||
enabled: !pluginDelegate.isExpanded || !pluginDelegate.hasSettings
|
enabled: pluginDelegate.hasSettings
|
||||||
onClicked: {
|
onClicked: {
|
||||||
if (pluginDelegate.hasSettings) {
|
pluginsTab.expandedPluginId = pluginsTab.expandedPluginId === pluginDelegate.pluginId ? "" : pluginDelegate.pluginId
|
||||||
pluginsTab.expandedPluginId = pluginsTab.expandedPluginId === pluginDelegate.pluginId ? "" : pluginDelegate.pluginId
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user