1
0
mirror of https://github.com/KDE/latte-dock.git synced 2025-01-02 17:17:47 +03:00

get ready for Plasma LookNFeel packages

--introduce enable/disableAutostart from command line
--accept import-layout from command line when latte is already running
--introduce --suggested-layout-name to be used with
  import-layout in order to provide a preferred layout name
  e.g. latte-dock --import-layout /blah/blah/mywhat.layout.latte
       --suggested-layout-name MyAwesomeLayout
--dbus:introduce "setAutostart" function
--dbus:introduce "importLayoutFile" function

BUG:446249
FIXED-IN:0.10.5
This commit is contained in:
Michail Vourlakos 2021-11-30 20:29:23 +02:00
parent 127f24bb24
commit e0bfff4c48
7 changed files with 155 additions and 71 deletions

View File

@ -5,6 +5,9 @@
</method>
<method name="quitApplication">
</method>
<method name="setAutostart">
<arg name="enabled" type="b" direction="in"/>
</method>
<method name="updateDockItemBadge">
<arg name="identifier" type="s" direction="in"/>
<arg name="value" type="s" direction="in"/>
@ -15,6 +18,10 @@
<method name="switchToLayout">
<arg name="layout" type="s" direction="in"/>
</method>
<method name="importLayoutFile">
<arg name="filepath" type="s" direction="in"/>
<arg name="suggestedLayoutName" type="s" direction="in"/>
</method>
<method name="exportViewTemplate">
<arg name="containmentId" type="u" direction="in"/>
</method>

View File

@ -1082,41 +1082,57 @@ void Corona::updateDockItemBadge(QString identifier, QString value)
m_globalShortcuts->updateViewItemBadge(identifier, value);
}
void Corona::setAutostart(const bool &enabled)
{
m_universalSettings->setAutostart(enabled);
}
void Corona::switchToLayout(QString layout)
{
if ((layout.startsWith("file:/") || layout.startsWith("/")) && layout.endsWith(".layout.latte")) {
//! Import and load runtime a layout through dbus interface
//! It can be used from external programs that want to update runtime
//! the Latte shown layout
QString layoutPath = layout;
//! cleanup layout path
if (layoutPath.startsWith("file:///")) {
layoutPath = layout.remove("file://");
} else if (layoutPath.startsWith("file://")) {
layoutPath = layout.remove("file:/");
}
//! check out layoutpath existence
if (QFileInfo(layoutPath).exists()) {
qDebug() << " Layout is going to be imported and loaded from file :: " << layoutPath;
QString importedLayout = m_layoutsManager->importer()->importLayout(layoutPath);
if (importedLayout.isEmpty()) {
qDebug() << i18n("The layout cannot be imported from file :: ") << layoutPath;
} else {
m_layoutsManager->switchToLayout(importedLayout);
}
} else {
qDebug() << " Layout from missing file can not be imported and loaded :: " << layoutPath;
}
importLayoutFile(layout);
} else {
m_layoutsManager->switchToLayout(layout);
}
}
void Corona::importLayoutFile(const QString &filepath, const QString &suggestedLayoutName)
{
bool isFilepathValid = (filepath.startsWith("file:/") || filepath.startsWith("/")) && filepath.endsWith(".layout.latte");
if (!isFilepathValid) {
qDebug() << i18n("The layout cannot be imported from file :: ") << filepath;
return;
}
//! Import and load runtime a layout through dbus interface
//! It can be used from external programs that want to update runtime
//! the Latte shown layout
QString layoutPath = filepath;
//! cleanup layout path
if (layoutPath.startsWith("file:///")) {
layoutPath = layoutPath.remove("file://");
} else if (layoutPath.startsWith("file://")) {
layoutPath = layoutPath.remove("file:/");
}
//! check out layoutpath existence
if (QFileInfo(layoutPath).exists()) {
qDebug() << " Layout is going to be imported and loaded from file :: " << layoutPath << " with suggested name :: " << suggestedLayoutName;
QString importedLayout = m_layoutsManager->importer()->importLayout(layoutPath, suggestedLayoutName);
if (importedLayout.isEmpty()) {
qDebug() << i18n("The layout cannot be imported from file :: ") << layoutPath;
} else {
m_layoutsManager->switchToLayout(importedLayout, MemoryUsage::SingleLayout);
}
} else {
qDebug() << " Layout from missing file can not be imported and loaded :: " << layoutPath;
}
}
void Corona::showSettingsWindow(int page)
{
if (m_inStartup) {

View File

@ -144,6 +144,7 @@ public:
//! these functions are used from context menu through containmentactions
void quitApplication();
void switchToLayout(QString layout);
void importLayoutFile(const QString &filepath, const QString &suggestedLayoutName = QString());
void showSettingsWindow(int page);
QStringList contextMenuData(const uint &containmentId);
@ -154,6 +155,8 @@ public slots:
void activateLauncherMenu();
void loadDefaultLayout() override;
void setAutostart(const bool &enabled);
void addView(const uint &containmentId, const QString &templateId);
void duplicateView(const uint &containmentId);
void exportViewTemplate(const uint &containmentId);

View File

@ -358,7 +358,7 @@ bool Importer::importOldConfiguration(QString oldConfigPath, QString newName)
}
//! the old configuration contains also screen values, these must be updated also
/*
/*
* do not use any deprecated screen ids
* KSharedConfigPtr oldScreensConfig = KSharedConfig::openConfig(screensPath);
KConfigGroup m_screensGroup = KConfigGroup(oldScreensConfig, "ScreenConnectors");
@ -531,9 +531,56 @@ bool Importer::importHelper(QString fileName)
return true;
}
QString Importer::importLayout(QString fileName)
bool Importer::isAutostartEnabled()
{
QString newLayoutName = importLayoutHelper(fileName);
QFile autostartFile(Latte::configPath() + "/autostart/org.kde.latte-dock.desktop");
return autostartFile.exists();
}
void Importer::enableAutostart()
{
//! deprecated old file
QFile oldAutostartFile(Latte::configPath() + "/autostart/latte-dock.desktop");
if (oldAutostartFile.exists()) {
//! remove deprecated file
oldAutostartFile.remove();
}
QFile autostartFile(Latte::configPath() + "/autostart/org.kde.latte-dock.desktop");
QFile metaFile(standardPath("applications/org.kde.latte-dock.desktop", false));
if (metaFile.exists()) {
//! check if autostart folder exists and create otherwise
QDir autostartDir(Latte::configPath() + "/autostart");
if (!autostartDir.exists()) {
QDir configDir(Latte::configPath());
configDir.mkdir("autostart");
}
metaFile.copy(autostartFile.fileName());
}
}
void Importer::disableAutostart()
{
QFile oldAutostartFile(Latte::configPath() + "/autostart/latte-dock.desktop");
if (oldAutostartFile.exists()) {
//! remove deprecated file
oldAutostartFile.remove();
}
QFile autostartFile(Latte::configPath() + "/autostart/org.kde.latte-dock.desktop");
if (autostartFile.exists()) {
autostartFile.remove();
}
}
QString Importer::importLayout(const QString &fileName, const QString &suggestedLayoutName)
{
QString newLayoutName = importLayoutHelper(fileName, suggestedLayoutName);
if (!newLayoutName.isEmpty()) {
emit newLayoutAdded(layoutUserFilePath(newLayoutName));
@ -542,7 +589,7 @@ QString Importer::importLayout(QString fileName)
return newLayoutName;
}
QString Importer::importLayoutHelper(QString fileName)
QString Importer::importLayoutHelper(const QString &fileName, const QString &suggestedLayoutName)
{
LatteFileVersion version = fileVersion(fileName);
@ -550,7 +597,7 @@ QString Importer::importLayoutHelper(QString fileName)
return QString();
}
QString newLayoutName = Layout::AbstractLayout::layoutName(fileName);
QString newLayoutName = !suggestedLayoutName.isEmpty() ? suggestedLayoutName : Layout::AbstractLayout::layoutName(fileName);
newLayoutName = uniqueLayoutName(newLayoutName);
QString newPath = layoutUserFilePath(newLayoutName);
@ -560,7 +607,7 @@ QString Importer::importLayoutHelper(QString fileName)
if (newFileInfo.exists() && !newFileInfo.isWritable()) {
QFile(newPath).setPermissions(QFileDevice::ReadUser | QFileDevice::WriteUser | QFileDevice::ReadGroup | QFileDevice::ReadOther);
}
}
return newLayoutName;
}

View File

@ -61,8 +61,11 @@ public:
QString storageTmpDir() const;
//! imports the specific layout and return the new layout name.
//! if the function didn't succeed returns an empty string
QString importLayout(QString fileName);
QString importLayout(const QString &fileName, const QString &suggestedName = QString());
static void enableAutostart();
static void disableAutostart();
static bool isAutostartEnabled();
static Importer::LatteFileVersion fileVersion(QString file);
@ -80,7 +83,7 @@ public:
static bool layoutExists(QString layoutName);
//! imports the specific layout and return the new layout name.
//! if the function didn't succeed returns an empty string
static QString importLayoutHelper(QString fileName);
static QString importLayoutHelper(const QString &fileName, const QString &suggestedName = QString());
//! returns the file path of a layout either existing or not
static QString layoutUserFilePath(QString layoutName);

View File

@ -94,10 +94,13 @@ int main(int argc, char **argv)
{{"r", "replace"}, i18nc("command line", "Replace the current Latte instance.")}
, {{"d", "debug"}, i18nc("command line", "Show the debugging messages on stdout.")}
, {{"cc", "clear-cache"}, i18nc("command line", "Clear qml cache. It can be useful after system upgrades.")}
, {"enable-autostart", i18nc("command line", "Enable autostart for this application")}
, {"disable-autostart", i18nc("command line", "Disable autostart for this application")}
, {"default-layout", i18nc("command line", "Import and load default layout on startup.")}
, {"available-layouts", i18nc("command line", "Print available layouts")}
, {"layout", i18nc("command line", "Load specific layout on startup."), i18nc("command line: load", "layout_name")}
, {"import-layout", i18nc("command line", "Import and load a layout."), i18nc("command line: import", "file_name")}
, {"import-layout", i18nc("command line", "Import and load a layout."), i18nc("command line: import", "absolute_filepath")}
, {"suggested-layout-name", i18nc("command line", "Suggested layout name when importing a layout file"), i18nc("command line: import", "suggested_name")}
, {"import-full", i18nc("command line", "Import full configuration."), i18nc("command line: import", "file_name")}
, {"add-dock", i18nc("command line", "Add Dock/Panel"), i18nc("command line: add", "template_name")}
, {"single", i18nc("command line", "Single layout memory mode. Only one layout is active at any case.")}
@ -169,6 +172,14 @@ int main(int argc, char **argv)
parser.process(app);
if (parser.isSet(QStringLiteral("enable-autostart"))) {
Latte::Layouts::Importer::enableAutostart();
}
if (parser.isSet(QStringLiteral("disable-autostart"))) {
Latte::Layouts::Importer::disableAutostart();
}
//! print available-layouts
if (parser.isSet(QStringLiteral("available-layouts"))) {
QStringList layouts = Latte::Layouts::Importer::availableLayouts();
@ -239,19 +250,36 @@ int main(int argc, char **argv)
if (!lockFile.tryLock(timeout)) {
QDBusInterface iface("org.kde.lattedock", "/Latte", "", QDBusConnection::sessionBus());
bool addview{parser.isSet(QStringLiteral("add-dock"))};
bool importlayout{parser.isSet(QStringLiteral("import-layout"))};
bool enableautostart{parser.isSet(QStringLiteral("enable-autostart"))};
bool disableautostart{parser.isSet(QStringLiteral("disable-autostart"))};
bool validaction{false};
if (iface.isValid()) {
if (addview) {
validaction = true;
iface.call("addView", (uint)0, parser.value(QStringLiteral("add-dock")));
qGuiApp->exit();
return 0;
} else if (importlayout) {
validaction = true;
QString suggestedname = parser.isSet(QStringLiteral("suggested-layout-name")) ? parser.value(QStringLiteral("suggested-layout-name")) : QString();
iface.call("importLayoutFile", parser.value(QStringLiteral("import-layout")), suggestedname);
qGuiApp->exit();
return 0;
} else if (enableautostart || disableautostart){
validaction = true;
} else {
// LayoutPage = 0
iface.call("showSettingsWindow", 0);
}
}
qInfo() << i18n("An instance is already running!, use --replace to restart Latte");
if (!validaction) {
qInfo() << i18n("An instance is already running!, use --replace to restart Latte");
}
qGuiApp->exit();
return 0;
}
@ -279,7 +307,8 @@ int main(int argc, char **argv)
//! import-layout option
if (parser.isSet(QStringLiteral("import-layout"))) {
QString importedLayout = Latte::Layouts::Importer::importLayoutHelper(parser.value(QStringLiteral("import-layout")));
QString suggestedname = parser.isSet(QStringLiteral("suggested-layout-name")) ? parser.value(QStringLiteral("suggested-layout-name")) : QString();
QString importedLayout = Latte::Layouts::Importer::importLayoutHelper(parser.value(QStringLiteral("import-layout")), suggestedname);
if (importedLayout.isEmpty()) {
qInfo() << i18n("The layout cannot be imported");

View File

@ -78,7 +78,11 @@ void UniversalSettings::load()
bool autostartUserSet = m_universalGroup.readEntry("userConfiguredAutostart", false);
if (!autostartUserSet && !autostart()) {
//! the first time the application is running and autostart is not set, autostart is enabled
//! and from now own it will not be recreated in the beginning
setAutostart(true);
m_universalGroup.writeEntry("userConfiguredAutostart", true);
}
//! init screen scales
@ -237,47 +241,22 @@ void UniversalSettings::setLaunchers(QStringList launcherList)
bool UniversalSettings::autostart() const
{
QFile autostartFile(Latte::configPath() + "/autostart/org.kde.latte-dock.desktop");
return autostartFile.exists();
return Layouts::Importer::isAutostartEnabled();
}
void UniversalSettings::setAutostart(bool state)
{
//! remove old autostart file
QFile oldAutostartFile(Latte::configPath() + "/autostart/latte-dock.desktop");
if (oldAutostartFile.exists()) {
oldAutostartFile.remove();
if (autostart() == state) {
return;
}
//! end of removal of old autostart file
QFile autostartFile(Latte::configPath() + "/autostart/org.kde.latte-dock.desktop");
QFile metaFile(Layouts::Importer::standardPath("applications/org.kde.latte-dock.desktop", false));
if (!state && autostartFile.exists()) {
//! the first time that the user disables the autostart, this is recorded
//! and from now own it will not be recreated it in the beginning
if (!m_universalGroup.readEntry("userConfiguredAutostart", false)) {
m_universalGroup.writeEntry("userConfiguredAutostart", true);
}
autostartFile.remove();
emit autostartChanged();
} else if (state && metaFile.exists()) {
//! check if autostart folder exists and create otherwise
QDir autostartDir(Latte::configPath() + "/autostart");
if (!autostartDir.exists()) {
QDir configDir(Latte::configPath());
configDir.mkdir("autostart");
}
metaFile.copy(autostartFile.fileName());
//! I haven't added the flag "OnlyShowIn=KDE;" into the autostart file
//! because I fall onto a Plasma 5.8 case that this flag
//! didn't let the plasma desktop to start
emit autostartChanged();
if (state) {
Layouts::Importer::enableAutostart();
} else {
Layouts::Importer::disableAutostart();
}
emit autostartChanged();
}
bool UniversalSettings::badges3DStyle() const