// Copyright(c) 2017-2018 Alejandro Sirgo Rica & 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 .
#include "confighandler.h"
#include
#include
#include
#include
ConfigHandler::ConfigHandler(){
m_settings.setDefaultFormat(QSettings::IniFormat);
}
QVector ConfigHandler::getButtons() {
QVector buttons;
if (m_settings.contains("buttons")) {
// TODO: remove toList in v1.0
QVector buttonsInt =
m_settings.value("buttons").value >().toVector();
bool modified = normalizeButtons(buttonsInt);
if (modified) {
m_settings.setValue("buttons", QVariant::fromValue(buttonsInt.toList()));
}
buttons = fromIntToButton(buttonsInt);
} else {
// Default tools
buttons << CaptureButton::TYPE_PENCIL
<< CaptureButton::TYPE_DRAWER
<< CaptureButton::TYPE_ARROW
<< CaptureButton::TYPE_SELECTION
<< CaptureButton::TYPE_RECTANGLE
<< CaptureButton::TYPE_CIRCLE
<< CaptureButton::TYPE_MARKER
<< CaptureButton::TYPE_BLUR
<< CaptureButton::TYPE_SELECTIONINDICATOR
<< CaptureButton::TYPE_MOVESELECTION
<< CaptureButton::TYPE_UNDO
<< CaptureButton::TYPE_REDO
<< CaptureButton::TYPE_COPY
<< CaptureButton::TYPE_SAVE
<< CaptureButton::TYPE_EXIT
<< CaptureButton::TYPE_IMAGEUPLOADER
<< CaptureButton::TYPE_OPEN_APP;
}
using bt = CaptureButton::ButtonType;
std::sort(buttons.begin(), buttons.end(), [](bt a, bt b){
return CaptureButton::getPriorityByButton(a) <
CaptureButton::getPriorityByButton(b);
});
return buttons;
}
void ConfigHandler::setButtons(const QVector &buttons) {
QVector l = fromButtonToInt(buttons);
normalizeButtons(l);
// TODO: remove toList in v1.0
m_settings.setValue("buttons", QVariant::fromValue(l.toList()));
}
QVector ConfigHandler::getUserColors() {
QVector colors;
const QVector &defaultColors = {
Qt::darkRed,
Qt::red,
Qt::yellow,
Qt::green,
Qt::darkGreen,
Qt::cyan,
Qt::blue,
Qt::magenta,
Qt::darkMagenta
};
if (m_settings.contains("userColors")) {
for (const QString &hex : m_settings.value("userColors").toStringList()) {
if (QColor::isValidColor(hex)) {
colors.append(QColor(hex));
}
}
if (colors.isEmpty()) {
colors = defaultColors;
}
} else {
colors = defaultColors;
}
return colors;
}
void ConfigHandler::setUserColors(const QVector &l) {
QStringList hexColors;
for (const QColor &color : l) {
hexColors.append(color.name());
}
m_settings.setValue("userColors", QVariant::fromValue(hexColors));
}
QString ConfigHandler::savePathValue() {
return m_settings.value("savePath").toString();
}
void ConfigHandler::setSavePath(const QString &savePath) {
m_settings.setValue("savePath", savePath);
}
QColor ConfigHandler::uiMainColorValue() {
QColor res = QColor(116, 0, 150);
if (m_settings.contains("uiColor")) {
QString hex = m_settings.value("uiColor").toString();
if (QColor::isValidColor(hex)) {
res = QColor(hex);
}
}
return res;
}
void ConfigHandler::setUIMainColor(const QColor &c) {
m_settings.setValue("uiColor", c.name());
}
QColor ConfigHandler::uiContrastColorValue() {
QColor res = QColor(86, 0, 120);
if (m_settings.contains("contastUiColor")) {
QString hex = m_settings.value("contastUiColor").toString();
if (QColor::isValidColor(hex)) {
res = QColor(hex);
}
}
return res;
}
void ConfigHandler::setUIContrastColor(const QColor &c) {
m_settings.setValue("contastUiColor", c.name());
}
QColor ConfigHandler::drawColorValue() {
QColor res(Qt::red);
if (m_settings.contains("drawColor")) {
QString hex = m_settings.value("drawColor").toString();
if (QColor::isValidColor(hex)) {
res = QColor(hex);
}
}
return res;
}
void ConfigHandler::setDrawColor(const QColor &c) {
m_settings.setValue("drawColor", c.name());
}
bool ConfigHandler::showHelpValue() {
bool res = true;
if (m_settings.contains("showHelp")) {
res = m_settings.value("showHelp").toBool();
}
return res;
}
void ConfigHandler::setShowHelp(const bool showHelp) {
m_settings.setValue("showHelp", showHelp);
}
bool ConfigHandler::desktopNotificationValue() {
bool res = true;
if (m_settings.contains("showDesktopNotification")) {
res = m_settings.value("showDesktopNotification").toBool();
}
return res;
}
void ConfigHandler::setDesktopNotification(const bool showDesktopNotification) {
m_settings.setValue("showDesktopNotification", showDesktopNotification);
}
QString ConfigHandler::filenamePatternValue() {
return m_settings.value("filenamePattern").toString();
}
void ConfigHandler::setFilenamePattern(const QString &pattern) {
return m_settings.setValue("filenamePattern", pattern);
}
bool ConfigHandler::disabledTrayIconValue() {
bool res = false;
if (m_settings.contains("disabledTrayIcon")) {
res = m_settings.value("disabledTrayIcon").toBool();
}
return res;
}
void ConfigHandler::setDisabledTrayIcon(const bool disabledTrayIcon) {
m_settings.setValue("disabledTrayIcon", disabledTrayIcon);
}
int ConfigHandler::drawThicknessValue() {
int res = 0;
if (m_settings.contains("drawThickness")) {
res = m_settings.value("drawThickness").toInt();
}
return res;
}
void ConfigHandler::setdrawThickness(const int thickness) {
m_settings.setValue("drawThickness", thickness);
}
bool ConfigHandler::keepOpenAppLauncherValue() {
return m_settings.value("keepOpenAppLauncher").toBool();
}
void ConfigHandler::setKeepOpenAppLauncher(const bool keepOpen) {
m_settings.setValue("keepOpenAppLauncher", keepOpen);
}
bool ConfigHandler::startupLaunchValue() {
bool res = false;
#if defined(Q_OS_LINUX) || defined(Q_OS_UNIX)
QString path = QDir::homePath() + "/.config/autostart/Flameshot.desktop";
res = QFile(path).exists();
#elif defined(Q_OS_WIN)
QSettings bootUpSettings(
"HKEY_CURRENT_USER\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run",
QSettings::NativeFormat);
res = bootUpSettings.value("Flameshot").toString() ==
QDir::toNativeSeparators(QCoreApplication::applicationFilePath());
#endif
return res;
}
void ConfigHandler::setStartupLaunch(const bool start) {
#if defined(Q_OS_LINUX) || defined(Q_OS_UNIX)
QString path = QDir::homePath() + "/.config/autostart/Flameshot.desktop";
QFile file(path);
if (start) {
if (file.open(QIODevice::WriteOnly)) {
QByteArray data("[Desktop Entry]\nName=flameshot\nIcon=flameshot"
"\nExec=flameshot\nTerminal=false\nType=Application"
"\nX-GNOME-Autostart-enabled=true\n");
file.write(data);
}
} else {
file.remove();
}
#elif defined(Q_OS_WIN)
QSettings bootUpSettings(
"HKEY_CURRENT_USER\\SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run",
QSettings::NativeFormat);
if (start) {
QString app_path =
QDir::toNativeSeparators(QCoreApplication::applicationFilePath());
bootUpSettings.setValue("Flameshot", app_path);
} else {
bootUpSettings.remove("Flameshot");
}
#endif
}
int ConfigHandler::contrastOpacityValue() {
int opacity = 190;
if (m_settings.contains("contrastOpacity")) {
opacity = m_settings.value("contrastOpacity").toInt();
opacity = qBound(0, opacity, 255);
}
return opacity;
}
void ConfigHandler::setContrastOpacity(const int transparency) {
m_settings.setValue("contrastOpacity", transparency);
}
void ConfigHandler::setDefaults() {
m_settings.clear();
}
void ConfigHandler::setAllTheButtons() {
QVector buttons;
auto listTypes = CaptureButton::getIterableButtonTypes();
for (const CaptureButton::ButtonType t: listTypes) {
buttons << static_cast(t);
}
// TODO: remove toList in v1.0
m_settings.setValue("buttons", QVariant::fromValue(buttons.toList()));
}
QString ConfigHandler::configFilePath() const {
return m_settings.fileName();
}
bool ConfigHandler::normalizeButtons(QVector &buttons) {
auto listTypes = CaptureButton::getIterableButtonTypes();
QVector listTypesInt;
for(auto i: listTypes)
listTypesInt << static_cast(i);
bool hasChanged = false;
for (int i = 0; i < buttons.size(); i++) {
if (!listTypesInt.contains(buttons.at(i))) {
buttons.remove(i);
hasChanged = true;
}
}
return hasChanged;
}
QVector ConfigHandler::fromIntToButton(
const QVector &l)
{
QVector buttons;
for (auto const i: l)
buttons << static_cast(i);
return buttons;
}
QVector ConfigHandler::fromButtonToInt(
const QVector &l)
{
QVector buttons;
for (auto const i: l)
buttons << static_cast(i);
return buttons;
}