1
0
mirror of https://github.com/KDE/latte-dock.git synced 2025-01-25 14:03:58 +03:00

viewsdialog:implement cut action (send path)

--this is implementation when a user selects views
and chooses to Cut them so they are temporary stored
in the clipboard
This commit is contained in:
Michail Vourlakos 2021-04-26 18:11:43 +03:00
parent c6ee04c8cf
commit dfa0949330
5 changed files with 101 additions and 14 deletions

View File

@ -115,8 +115,8 @@ bool View::operator==(const View &rhs) const
return (id == rhs.id)
&& (name == rhs.name)
//&& (isActive == rhs.isActive) /*activeness is a state and is not considered*/
//&& (isMoveOrigin == rhs.isMoveOrigin) /*changing layouts is a state and is not considered*/
//&& (isMoveDestination == rhs.isMoveDestination) /*changing layouts is a state and is not considered*/
&& (isMoveOrigin == rhs.isMoveOrigin) /*changing layouts is a state and is not considered*/
&& (isMoveDestination == rhs.isMoveDestination) /*changing layouts is a state and is not considered*/
&& (onPrimary == rhs.onPrimary)
&& (screen == rhs.screen)
&& (screenEdgeMargin == rhs.screenEdgeMargin)
@ -142,6 +142,17 @@ View::operator QString() const
result += id;
result +=" : ";
result += isActive ? "Active" : "Inactive";
result +=" : ";
if (isMoveOrigin) {
result += "";
} else if (isMoveDestination) {
result += "";
} else if (isMoveOrigin && isMoveDestination) {
result += " ↑↓ ";
} else {
result += " - ";
}
result += " : ";
if (m_state == IsInvalid) {

View File

@ -111,6 +111,7 @@ void Views::init()
m_cutAction = new QAction(QIcon::fromTheme("edit-cut"), i18n("Cut"), m_view);
m_cutAction->setShortcut(QKeySequence(Qt::CTRL + Qt::Key_X));
connect(m_cutAction, &QAction::triggered, this, &Views::cutSelectedViews);
m_copyAction = new QAction(QIcon::fromTheme("edit-copy"), i18n("Copy"), m_view);
m_copyAction->setShortcut(QKeySequence(Qt::CTRL + Qt::Key_C));
@ -197,19 +198,16 @@ const Latte::Data::View Views::appendViewFromViewTemplate(const Data::View &view
return newview;
}
void Views::copySelectedViews()
Data::ViewsTable Views::selectedViewsForClipboard()
{
qDebug() << Q_FUNC_INFO;
Data::ViewsTable clipboardviews;
if (!hasSelectedView()) {
return;
return clipboardviews;
}
Data::ViewsTable selectedviews = selectedViewsCurrentData();
Latte::Data::Layout currentlayout = m_handler->currentData();
Data::ViewsTable clipboardviews;
for(int i=0; i<selectedviews.rowCount(); ++i) {
if (selectedviews[i].state() == Data::View::IsCreated) {
QString storedviewpath = m_handler->layoutsController()->templatesKeeper()->storedView(currentlayout.id, selectedviews[i].id);
@ -225,6 +223,39 @@ void Views::copySelectedViews()
}
}
return clipboardviews;
}
void Views::copySelectedViews()
{
qDebug() << Q_FUNC_INFO;
if (!hasSelectedView()) {
return;
}
Data::ViewsTable clipboardviews = selectedViewsForClipboard();
m_handler->layoutsController()->templatesKeeper()->setClipboardContents(clipboardviews);
}
void Views::cutSelectedViews()
{
qDebug() << Q_FUNC_INFO;
if (!hasSelectedView()) {
return;
}
Data::ViewsTable clipboardviews = selectedViewsForClipboard();
for (int i=0; i<clipboardviews.rowCount(); ++i) {
clipboardviews[i].isMoveOrigin = true;
Data::View tempview = m_model->currentData(clipboardviews[i].id);
tempview.isMoveOrigin = true;
m_model->updateCurrentView(tempview.id, tempview);
}
m_handler->layoutsController()->templatesKeeper()->setClipboardContents(clipboardviews);
}
@ -331,9 +362,15 @@ void Views::save()
Latte::Data::ViewsTable newViews = m_model->newViews();
QHash<QString, Data::View> newviewsresponses;
QHash<QString, Data::View> cuttedviews;
//! add new views
//! add new views that are accepted
for(int i=0; i<newViews.rowCount(); ++i){
if (newViews[i].isMoveOrigin) {
cuttedviews[newViews[i].id] = newViews[i];
continue;
}
if (newViews[i].state() == Data::View::OriginFromViewTemplate) {
Data::View addedview = central->newView(newViews[i]);
@ -349,19 +386,31 @@ void Views::save()
//! update altered views
for (int i=0; i<alteredViews.rowCount(); ++i) {
if (alteredViews[i].state() == Data::View::IsCreated) {
if (alteredViews[i].state() == Data::View::IsCreated && !alteredViews[i].isMoveOrigin) {
qDebug() << "org.kde.latte updating altered view :: " << alteredViews[i];
central->updateView(alteredViews[i]);
}
if (alteredViews[i].isMoveOrigin) {
cuttedviews[alteredViews[i].id] = alteredViews[i];
}
}
//! remove deprecated views
//! remove deprecated views that have been removed from user
Latte::Data::ViewsTable removedViews = originalViews.subtracted(currentViews);
for (int i=0; i<removedViews.rowCount(); ++i) {
central->removeView(removedViews[i]);
}
//! remove deprecated views that have been removed from Cut operation
for(const auto vid: cuttedviews.keys()){
if (cuttedviews[vid].state() == Data::View::IsCreated) {
central->removeView(cuttedviews[vid]);
}
}
//! update
if ((removedViews.rowCount() > 0) || (newViews.rowCount() > 0)) {
m_handler->corona()->layoutsManager()->synchronizer()->syncActiveLayoutsToOriginalFiles();
}
@ -371,12 +420,16 @@ void Views::save()
m_model->setOriginalView(vid, newviewsresponses[vid]);
}
//! update all table with latest data
currentViews = m_model->currentViewsData();
//! update/remove from model cutted views
for (const auto vid: cuttedviews.keys()) {
m_model->removeView(vid);
}
//! update model original data
//! update all table with latest data and make the original one
currentViews = m_model->currentViewsData();
m_model->setOriginalData(currentViews);
//! update model activeness
if (central->isActive()) {
m_model->updateActiveStatesBasedOn(central);
}

View File

@ -85,6 +85,7 @@ public:
public slots:
void copySelectedViews();
void cutSelectedViews();
void duplicateSelectedViews();
void pasteSelectedViews();
void removeSelectedViews();
@ -98,6 +99,8 @@ private:
int rowForId(QString id) const;
QString uniqueViewName(QString name);
Data::ViewsTable selectedViewsForClipboard();
private slots:
void loadConfig();
void saveConfig();

View File

@ -300,6 +300,25 @@ void Views::populateScreens()
}
}
void Views::updateCurrentView(QString currentViewId, Latte::Data::View &view)
{
if (!m_viewsTable.containsId(currentViewId)) {
return;
}
int currentrow = m_viewsTable.indexOf(currentViewId);
m_viewsTable[currentrow] = view;
QVector<int> roles;
roles << Qt::DisplayRole;
roles << Qt::UserRole;
roles << ISCHANGEDROLE;
roles << ISACTIVEROLE;
roles << HASCHANGEDVIEWROLE;
emit dataChanged(this->index(currentrow, IDCOLUMN), this->index(currentrow, SUBCONTAINMENTSCOLUMN), roles);
}
void Views::setOriginalView(QString currentViewId, Latte::Data::View &view)
{
if (!m_viewsTable.containsId(currentViewId)) {

View File

@ -108,6 +108,7 @@ public:
void setOriginalData(Latte::Data::ViewsTable &data);
void setOriginalView(QString currentViewId, Latte::Data::View &view);
void updateCurrentView(QString currentViewId, Latte::Data::View &view);
void updateActiveStatesBasedOn(const CentralLayout *layout);