mirror of
https://github.com/KDE/latte-dock.git
synced 2025-01-10 21:18:19 +03:00
41c2e2b033
--the new approach is much clearer and easy to read that the deprecated one
140 lines
4.1 KiB
C++
140 lines
4.1 KiB
C++
/*
|
|
* Copyright 2017 Smith AR <audoban@openmailbox.org>
|
|
* Michail Vourlakos <mvourlakos@gmail.com>
|
|
*
|
|
* This file is part of Latte-Dock
|
|
*
|
|
* Latte-Dock 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) any later version.
|
|
*
|
|
* Latte-Dock 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/>.
|
|
*/
|
|
|
|
#ifndef LAYOUTSMANAGER_H
|
|
#define LAYOUTSMANAGER_H
|
|
|
|
// local
|
|
#include "launcherssignals.h"
|
|
#include "synchronizer.h"
|
|
#include "../apptypes.h"
|
|
#include "../settings/dialogs/settingsdialog.h"
|
|
|
|
// Qt
|
|
#include <QAction>
|
|
#include <QObject>
|
|
#include <QPointer>
|
|
|
|
// KDE
|
|
#include <KLocalizedString>
|
|
|
|
namespace Plasma {
|
|
class Containment;
|
|
class Types;
|
|
}
|
|
|
|
namespace Latte {
|
|
class Corona;
|
|
class CentralLayout;
|
|
namespace Layouts {
|
|
class Importer;
|
|
class LaunchersSignals;
|
|
class Synchronizer;
|
|
}
|
|
}
|
|
|
|
namespace Latte {
|
|
namespace Layouts {
|
|
|
|
//! Layouts::Manager is a very IMPORTANT class which is responsible to
|
|
//! to provide the qml accessible Layouts manipulation API and at the
|
|
//! same time to interact with Latte::Corona in order
|
|
//! to update correctly the underlying Layouts files by using also
|
|
//! its Importer object
|
|
//!
|
|
//! This class is responsible both for ACTIVE/PASSIVE Layouts.
|
|
//!
|
|
//! ACTIVE Layout is consider one layout that is loaded and active in memory
|
|
//! PASSIVE Layouts is consider one layout that is not loaded/active in memory
|
|
//! and its properties are just stored in the filesystem
|
|
//!
|
|
|
|
class Manager : public QObject
|
|
{
|
|
Q_OBJECT
|
|
Q_PROPERTY(LaunchersSignals *launchersSignals READ launchersSignals NOTIFY launchersSignalsChanged)
|
|
|
|
public:
|
|
Manager(QObject *parent = nullptr);
|
|
~Manager() override;
|
|
|
|
Latte::Corona *corona();
|
|
Importer *importer();
|
|
|
|
void init();
|
|
void loadLayoutOnStartup(QString layoutName);
|
|
void setOnAllActivities(QString layoutName);
|
|
void showInfoWindow(QString info, int duration, QStringList activities = {"0"});
|
|
void unload();
|
|
|
|
QStringList currentLayoutsNames() const;
|
|
|
|
MemoryUsage::LayoutsMemory memoryUsage() const;
|
|
void setMemoryUsage(MemoryUsage::LayoutsMemory memoryUsage);
|
|
|
|
//! switch to specified layout, default previousMemoryUsage means that it didn't change
|
|
bool switchToLayout(QString layoutName, MemoryUsage::LayoutsMemory newMemoryUsage = MemoryUsage::Current);
|
|
|
|
//! returns the current and central layout based on activities and user preferences
|
|
QList<CentralLayout *>currentLayouts() const;
|
|
LaunchersSignals *launchersSignals() const;
|
|
Synchronizer *synchronizer() const;
|
|
|
|
public slots:
|
|
void showAboutDialog();
|
|
|
|
void hideLatteSettingsDialog();
|
|
Q_INVOKABLE void showLatteSettingsDialog(int firstPage = Settings::Dialog::LayoutPage, bool toggleCurrentPage = false);
|
|
Q_INVOKABLE QStringList centralLayoutsNames();
|
|
|
|
signals:
|
|
void centralLayoutsChanged();
|
|
void launchersSignalsChanged();
|
|
|
|
void currentLayoutIsSwitching(QString layoutName);
|
|
|
|
//! used from ConfigView(s) in order to be informed which is one should be shown
|
|
void lastConfigViewChangedFrom(Latte::View *view);
|
|
|
|
private:
|
|
void cleanupOnStartup(QString path); //!remove deprecated or oldstyle config options
|
|
void clearUnloadedContainmentsFromLinkedFile(QStringList containmentsIds, bool bypassChecks = false);
|
|
|
|
void loadLatteLayout(QString layoutPath);
|
|
|
|
void setMenuLayouts(QStringList layouts);
|
|
|
|
private:
|
|
QPointer<Latte::Settings::Dialog::SettingsDialog> m_latteSettingsDialog;
|
|
|
|
Latte::Corona *m_corona{nullptr};
|
|
Importer *m_importer{nullptr};
|
|
LaunchersSignals *m_launchersSignals{nullptr};
|
|
Synchronizer *m_synchronizer{nullptr};
|
|
|
|
friend class Latte::Settings::Dialog::SettingsDialog;
|
|
friend class Synchronizer;
|
|
};
|
|
|
|
}
|
|
}
|
|
|
|
#endif // LAYOUTSMANAGER_H
|