mirror of
https://github.com/fergalmoran/flameshot.git
synced 2025-12-27 04:09:45 +00:00
Move storage upload configuration to separate tab, later it can be uses for a plugin manager
This commit is contained in:
@@ -12,4 +12,5 @@ target_sources(
|
|||||||
filepathconfiguration.cpp
|
filepathconfiguration.cpp
|
||||||
shortcutswidget.cpp
|
shortcutswidget.cpp
|
||||||
setshortcutwidget.cpp
|
setshortcutwidget.cpp
|
||||||
|
uploadstorageconfig.cpp
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -21,16 +21,15 @@
|
|||||||
#include "src/config/geneneralconf.h"
|
#include "src/config/geneneralconf.h"
|
||||||
#include "src/config/shortcutswidget.h"
|
#include "src/config/shortcutswidget.h"
|
||||||
#include "src/config/strftimechooserwidget.h"
|
#include "src/config/strftimechooserwidget.h"
|
||||||
|
#include "src/config/uploadstorageconfig.h"
|
||||||
#include "src/config/visualseditor.h"
|
#include "src/config/visualseditor.h"
|
||||||
#include "src/utils/colorutils.h"
|
#include "src/utils/colorutils.h"
|
||||||
#include "src/utils/confighandler.h"
|
#include "src/utils/confighandler.h"
|
||||||
#include "src/utils/globalvalues.h"
|
#include "src/utils/globalvalues.h"
|
||||||
#include "src/utils/pathinfo.h"
|
#include "src/utils/pathinfo.h"
|
||||||
#include "src/widgets/capture/capturetoolbutton.h"
|
|
||||||
#include <QFileSystemWatcher>
|
#include <QFileSystemWatcher>
|
||||||
#include <QIcon>
|
#include <QIcon>
|
||||||
#include <QKeyEvent>
|
#include <QKeyEvent>
|
||||||
#include <QLabel>
|
|
||||||
#include <QVBoxLayout>
|
#include <QVBoxLayout>
|
||||||
|
|
||||||
// ConfigWindow contains the menus where you can configure the application
|
// ConfigWindow contains the menus where you can configure the application
|
||||||
@@ -79,6 +78,12 @@ ConfigWindow::ConfigWindow(QWidget* parent)
|
|||||||
m_shortcuts = new ShortcutsWidget();
|
m_shortcuts = new ShortcutsWidget();
|
||||||
addTab(m_shortcuts, QIcon(modifier + "shortcut.svg"), tr("Shortcuts"));
|
addTab(m_shortcuts, QIcon(modifier + "shortcut.svg"), tr("Shortcuts"));
|
||||||
|
|
||||||
|
// upload storage configuration
|
||||||
|
m_uploadStorageConfig = new UploadStorageConfig();
|
||||||
|
addTab(m_uploadStorageConfig,
|
||||||
|
QIcon(modifier + "cloud-upload.svg"),
|
||||||
|
tr("Storage"));
|
||||||
|
|
||||||
// connect update sigslots
|
// connect update sigslots
|
||||||
connect(this,
|
connect(this,
|
||||||
&ConfigWindow::updateChildren,
|
&ConfigWindow::updateChildren,
|
||||||
|
|||||||
@@ -25,6 +25,7 @@ class ShortcutsWidget;
|
|||||||
class GeneneralConf;
|
class GeneneralConf;
|
||||||
class QFileSystemWatcher;
|
class QFileSystemWatcher;
|
||||||
class VisualsEditor;
|
class VisualsEditor;
|
||||||
|
class UploadStorageConfig;
|
||||||
|
|
||||||
class ConfigWindow : public QTabWidget
|
class ConfigWindow : public QTabWidget
|
||||||
{
|
{
|
||||||
@@ -42,6 +43,7 @@ private:
|
|||||||
FileNameEditor* m_filenameEditor;
|
FileNameEditor* m_filenameEditor;
|
||||||
ShortcutsWidget* m_shortcuts;
|
ShortcutsWidget* m_shortcuts;
|
||||||
GeneneralConf* m_generalConfig;
|
GeneneralConf* m_generalConfig;
|
||||||
|
UploadStorageConfig* m_uploadStorageConfig;
|
||||||
VisualsEditor* m_visuals;
|
VisualsEditor* m_visuals;
|
||||||
QFileSystemWatcher* m_configWatcher;
|
QFileSystemWatcher* m_configWatcher;
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -18,21 +18,18 @@
|
|||||||
#include "geneneralconf.h"
|
#include "geneneralconf.h"
|
||||||
#include "filepathconfiguration.h"
|
#include "filepathconfiguration.h"
|
||||||
#include "src/core/controller.h"
|
#include "src/core/controller.h"
|
||||||
#include "src/tools/storage/imgstorages.h"
|
|
||||||
#include "src/utils/confighandler.h"
|
#include "src/utils/confighandler.h"
|
||||||
#include "src/utils/filenamehandler.h"
|
|
||||||
#include <QCheckBox>
|
#include <QCheckBox>
|
||||||
#include <QFile>
|
#include <QFile>
|
||||||
#include <QFileDialog>
|
#include <QFileDialog>
|
||||||
#include <QGroupBox>
|
#include <QGroupBox>
|
||||||
#include <QHBoxLayout>
|
|
||||||
#include <QLineEdit>
|
#include <QLineEdit>
|
||||||
#include <QMessageBox>
|
#include <QMessageBox>
|
||||||
#include <QPushButton>
|
#include <QPushButton>
|
||||||
#include <QRadioButton>
|
|
||||||
#include <QStandardPaths>
|
#include <QStandardPaths>
|
||||||
#include <QTextCodec>
|
#include <QTextCodec>
|
||||||
#include <QVBoxLayout>
|
#include <QVBoxLayout>
|
||||||
|
|
||||||
GeneneralConf::GeneneralConf(QWidget* parent)
|
GeneneralConf::GeneneralConf(QWidget* parent)
|
||||||
: QWidget(parent)
|
: QWidget(parent)
|
||||||
{
|
{
|
||||||
@@ -48,7 +45,6 @@ GeneneralConf::GeneneralConf(QWidget* parent)
|
|||||||
initCopyAndCloseAfterUpload();
|
initCopyAndCloseAfterUpload();
|
||||||
initSaveAfterCopy();
|
initSaveAfterCopy();
|
||||||
initCopyPathAfterSave();
|
initCopyPathAfterSave();
|
||||||
initUploadStorage();
|
|
||||||
initFilePathConfiguration();
|
initFilePathConfiguration();
|
||||||
|
|
||||||
// this has to be at the end
|
// this has to be at the end
|
||||||
@@ -398,41 +394,6 @@ void GeneneralConf::initCopyPathAfterSave()
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
void GeneneralConf::initUploadStorage()
|
|
||||||
{
|
|
||||||
QGroupBox* groupBox = new QGroupBox(tr("Upload storage"));
|
|
||||||
|
|
||||||
// TODO - remove dependency injection (s3 & imgur)
|
|
||||||
// imgur
|
|
||||||
QRadioButton* storageImgUr = new QRadioButton(tr("Imgur storage"));
|
|
||||||
connect(storageImgUr, &QCheckBox::clicked, [](bool checked) {
|
|
||||||
ConfigHandler().setUploadStorage(SCREENSHOT_STORAGE_TYPE_IMGUR);
|
|
||||||
});
|
|
||||||
|
|
||||||
// s3
|
|
||||||
QRadioButton* storageImgS3 = new QRadioButton(
|
|
||||||
tr("S3 storage (require config.ini file with s3 credentials)"));
|
|
||||||
connect(storageImgS3, &QCheckBox::clicked, [](bool checked) {
|
|
||||||
ConfigHandler().setUploadStorage(SCREENSHOT_STORAGE_TYPE_S3);
|
|
||||||
});
|
|
||||||
|
|
||||||
// set current storage radiobutton active
|
|
||||||
if (ConfigHandler().uploadStorage() == SCREENSHOT_STORAGE_TYPE_IMGUR) {
|
|
||||||
storageImgUr->setChecked(true);
|
|
||||||
|
|
||||||
} else {
|
|
||||||
storageImgS3->setChecked(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
// draw configuration options for uploadStorage
|
|
||||||
QVBoxLayout* vbox = new QVBoxLayout;
|
|
||||||
vbox->addWidget(storageImgUr);
|
|
||||||
vbox->addWidget(storageImgS3);
|
|
||||||
vbox->addStretch(1);
|
|
||||||
groupBox->setLayout(vbox);
|
|
||||||
m_layout->addWidget(groupBox);
|
|
||||||
}
|
|
||||||
|
|
||||||
void GeneneralConf::initFilePathConfiguration()
|
void GeneneralConf::initFilePathConfiguration()
|
||||||
{
|
{
|
||||||
m_filePathConfiguration = new FilePathConfiguration();
|
m_filePathConfiguration = new FilePathConfiguration();
|
||||||
|
|||||||
@@ -79,6 +79,5 @@ private:
|
|||||||
void initCopyAndCloseAfterUpload();
|
void initCopyAndCloseAfterUpload();
|
||||||
void initSaveAfterCopy();
|
void initSaveAfterCopy();
|
||||||
void initCopyPathAfterSave();
|
void initCopyPathAfterSave();
|
||||||
void initUploadStorage();
|
|
||||||
void initFilePathConfiguration();
|
void initFilePathConfiguration();
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1,3 +1,20 @@
|
|||||||
|
// Copyright(c) 2020 Yurii Puchkov at Namecheap & Contributors
|
||||||
|
//
|
||||||
|
// This file is part of Flameshot.
|
||||||
|
//
|
||||||
|
// Flameshot 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 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// Flameshot 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 Flameshot. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
#include "setshortcutwidget.h"
|
#include "setshortcutwidget.h"
|
||||||
#include <QIcon>
|
#include <QIcon>
|
||||||
#include <QKeyEvent>
|
#include <QKeyEvent>
|
||||||
|
|||||||
@@ -1,3 +1,20 @@
|
|||||||
|
// Copyright(c) 2020 Yurii Puchkov at Namecheap & Contributors
|
||||||
|
//
|
||||||
|
// This file is part of Flameshot.
|
||||||
|
//
|
||||||
|
// Flameshot 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 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// Flameshot 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 Flameshot. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
#ifndef SETSHORTCUTWIDGET_H
|
#ifndef SETSHORTCUTWIDGET_H
|
||||||
#define SETSHORTCUTWIDGET_H
|
#define SETSHORTCUTWIDGET_H
|
||||||
|
|
||||||
|
|||||||
@@ -1,3 +1,20 @@
|
|||||||
|
// Copyright(c) 2020 Yurii Puchkov at Namecheap & Contributors
|
||||||
|
//
|
||||||
|
// This file is part of Flameshot.
|
||||||
|
//
|
||||||
|
// Flameshot 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 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// Flameshot 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 Flameshot. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
#include "shortcutswidget.h"
|
#include "shortcutswidget.h"
|
||||||
#include "setshortcutwidget.h"
|
#include "setshortcutwidget.h"
|
||||||
#include <QHeaderView>
|
#include <QHeaderView>
|
||||||
|
|||||||
@@ -1,3 +1,20 @@
|
|||||||
|
// Copyright(c) 2020 Yurii Puchkov at Namecheap & Contributors
|
||||||
|
//
|
||||||
|
// This file is part of Flameshot.
|
||||||
|
//
|
||||||
|
// Flameshot 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 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// Flameshot 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 Flameshot. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
#ifndef HOTKEYSCONFIG_H
|
#ifndef HOTKEYSCONFIG_H
|
||||||
#define HOTKEYSCONFIG_H
|
#define HOTKEYSCONFIG_H
|
||||||
|
|
||||||
|
|||||||
64
src/config/uploadstorageconfig.cpp
Normal file
64
src/config/uploadstorageconfig.cpp
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
// Copyright(c) 2020 Yurii Puchkov at Namecheap & Contributors
|
||||||
|
//
|
||||||
|
// This file is part of Flameshot.
|
||||||
|
//
|
||||||
|
// Flameshot 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 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// Flameshot 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 Flameshot. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
#include "uploadstorageconfig.h"
|
||||||
|
#include "src/tools/storage/imgstorages.h"
|
||||||
|
#include "src/utils/confighandler.h"
|
||||||
|
|
||||||
|
#include <QCheckBox>
|
||||||
|
#include <QGroupBox>
|
||||||
|
#include <QRadioButton>
|
||||||
|
#include <QVBoxLayout>
|
||||||
|
|
||||||
|
UploadStorageConfig::UploadStorageConfig(QWidget* parent)
|
||||||
|
: QWidget(parent)
|
||||||
|
{
|
||||||
|
m_layout = new QVBoxLayout(this);
|
||||||
|
m_layout->setAlignment(Qt::AlignTop);
|
||||||
|
|
||||||
|
QGroupBox* groupBox = new QGroupBox(tr("Upload storage"));
|
||||||
|
|
||||||
|
// TODO - remove dependency injection (s3 & imgur)
|
||||||
|
// imgur
|
||||||
|
QRadioButton* storageImgUr = new QRadioButton(tr("Imgur storage"));
|
||||||
|
connect(storageImgUr, &QCheckBox::clicked, [](bool checked) {
|
||||||
|
ConfigHandler().setUploadStorage(SCREENSHOT_STORAGE_TYPE_IMGUR);
|
||||||
|
});
|
||||||
|
|
||||||
|
// s3
|
||||||
|
QRadioButton* storageImgS3 = new QRadioButton(
|
||||||
|
tr("S3 storage (require config.ini file with s3 credentials)"));
|
||||||
|
connect(storageImgS3, &QCheckBox::clicked, [](bool checked) {
|
||||||
|
ConfigHandler().setUploadStorage(SCREENSHOT_STORAGE_TYPE_S3);
|
||||||
|
});
|
||||||
|
|
||||||
|
// set current storage radiobutton active
|
||||||
|
if (ConfigHandler().uploadStorage() == SCREENSHOT_STORAGE_TYPE_IMGUR) {
|
||||||
|
storageImgUr->setChecked(true);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
storageImgS3->setChecked(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
// draw configuration options for uploadStorage
|
||||||
|
QVBoxLayout* vbox = new QVBoxLayout;
|
||||||
|
vbox->addWidget(storageImgUr);
|
||||||
|
vbox->addWidget(storageImgS3);
|
||||||
|
vbox->addStretch(1);
|
||||||
|
groupBox->setLayout(vbox);
|
||||||
|
m_layout->addWidget(groupBox);
|
||||||
|
}
|
||||||
36
src/config/uploadstorageconfig.h
Normal file
36
src/config/uploadstorageconfig.h
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
// Copyright(c) 2020 Yurii Puchkov at Namecheap & Contributors
|
||||||
|
//
|
||||||
|
// This file is part of Flameshot.
|
||||||
|
//
|
||||||
|
// Flameshot 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 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// Flameshot 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 Flameshot. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
#ifndef FLAMESHOT_UPLOADSTORAGECONFIG_H
|
||||||
|
#define FLAMESHOT_UPLOADSTORAGECONFIG_H
|
||||||
|
|
||||||
|
#include <QObject>
|
||||||
|
#include <QWidget>
|
||||||
|
|
||||||
|
class QVBoxLayout;
|
||||||
|
|
||||||
|
class UploadStorageConfig : public QWidget
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
explicit UploadStorageConfig(QWidget* parent = nullptr);
|
||||||
|
|
||||||
|
private:
|
||||||
|
QVBoxLayout* m_layout;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // FLAMESHOT_UPLOADSTORAGECONFIG_H
|
||||||
Reference in New Issue
Block a user