diff options
| author | trialuser02 <trialuser02@90c681e8-e032-0410-971d-27865f9a5e38> | 2017-04-10 18:38:41 +0000 |
|---|---|---|
| committer | trialuser02 <trialuser02@90c681e8-e032-0410-971d-27865f9a5e38> | 2017-04-10 18:38:41 +0000 |
| commit | 12fefde04874839dc300a1a53b1a65422d102a98 (patch) | |
| tree | 6e5c15c96e0a68d8ce6829561b44b18a20e7b27c | |
| parent | bb1da332b9a71f59e22b1a9dae42e072e7e32bec (diff) | |
| download | qmmp-12fefde04874839dc300a1a53b1a65422d102a98.tar.gz qmmp-12fefde04874839dc300a1a53b1a65422d102a98.tar.bz2 qmmp-12fefde04874839dc300a1a53b1a65422d102a98.zip | |
added MetaDataFormatterMenu class
git-svn-id: http://svn.code.sf.net/p/qmmp-dev/code/trunk/qmmp@7114 90c681e8-e032-0410-971d-27865f9a5e38
26 files changed, 219 insertions, 308 deletions
diff --git a/src/plugins/Effect/filewriter/settingsdialog.cpp b/src/plugins/Effect/filewriter/settingsdialog.cpp index 424c1dc91..ec4393ceb 100644 --- a/src/plugins/Effect/filewriter/settingsdialog.cpp +++ b/src/plugins/Effect/filewriter/settingsdialog.cpp @@ -20,9 +20,9 @@ #include <QSettings> #include <QDesktopServices> -#include <QMenu> #include <qmmp/qmmp.h> #include <qmmpui/filedialog.h> +#include <qmmpui/metadataformattermenu.h> #include "settingsdialog.h" SettingsDialog::SettingsDialog(QWidget *parent) @@ -31,25 +31,10 @@ SettingsDialog::SettingsDialog(QWidget *parent) m_ui.setupUi(this); setAttribute(Qt::WA_DeleteOnClose, true); - QMenu *fileNameMenu = new QMenu(this); - fileNameMenu->addAction(tr("Artist"))->setData("%p"); - fileNameMenu->addAction(tr("Album"))->setData("%a"); - fileNameMenu->addAction(tr("Album Artist"))->setData("%aa"); - fileNameMenu->addAction(tr("Title"))->setData("%t"); - fileNameMenu->addAction(tr("Track Number"))->setData("%n"); - fileNameMenu->addAction(tr("Two-digit Track Number"))->setData("%NN"); - fileNameMenu->addAction(tr("Genre"))->setData("%g"); - fileNameMenu->addAction(tr("Comment"))->setData("%c"); - fileNameMenu->addAction(tr("Composer"))->setData("%C"); - fileNameMenu->addAction(tr("Duration"))->setData("%l"); - fileNameMenu->addAction(tr("Disc Number"))->setData("%D"); - fileNameMenu->addAction(tr("File Name"))->setData("%f"); - fileNameMenu->addAction(tr("File Path"))->setData("%F"); - fileNameMenu->addAction(tr("Year"))->setData("%y"); - fileNameMenu->addAction(tr("Condition"))->setData("%p%if(%p&%t, - ,)%t"); + MetaDataFormatterMenu *fileNameMenu = new MetaDataFormatterMenu(MetaDataFormatterMenu::TITLE_MENU, this); m_ui.fileNameButton->setMenu(fileNameMenu); m_ui.fileNameButton->setPopupMode(QToolButton::InstantPopup); - connect(fileNameMenu, SIGNAL(triggered(QAction *)), SLOT(addTitleString(QAction *))); + connect(fileNameMenu, SIGNAL(patternSelected(QString)), SLOT(addTitleString(QString))); QSettings settings(Qmmp::configFile(), QSettings::IniFormat); QString outDir = QDesktopServices::storageLocation(QDesktopServices::MusicLocation); @@ -71,12 +56,12 @@ void SettingsDialog::accept() QDialog::accept(); } -void SettingsDialog::addTitleString(QAction *a) +void SettingsDialog::addTitleString(const QString &str) { if (m_ui.outFileEdit->cursorPosition () < 1) - m_ui.outFileEdit->insert(a->data().toString()); + m_ui.outFileEdit->insert(str); else - m_ui.outFileEdit->insert(" - "+a->data().toString()); + m_ui.outFileEdit->insert(" - "+str); } void SettingsDialog::on_dirButton_clicked() diff --git a/src/plugins/Effect/filewriter/settingsdialog.h b/src/plugins/Effect/filewriter/settingsdialog.h index f90900abf..7f19f9f64 100644 --- a/src/plugins/Effect/filewriter/settingsdialog.h +++ b/src/plugins/Effect/filewriter/settingsdialog.h @@ -38,7 +38,7 @@ public slots: virtual void accept(); private slots: - void addTitleString(QAction *a); + void addTitleString(const QString &str); void on_dirButton_clicked(); private: diff --git a/src/plugins/General/converter/converterdialog.cpp b/src/plugins/General/converter/converterdialog.cpp index 164d592dd..97ac12699 100644 --- a/src/plugins/General/converter/converterdialog.cpp +++ b/src/plugins/General/converter/converterdialog.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2011-2016 by Ilya Kotov * + * Copyright (C) 2011-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -31,6 +31,7 @@ #include <qmmpui/metadataformatter.h> #include <qmmpui/filedialog.h> #include <qmmp/metadatamanager.h> +#include <qmmpui/metadataformattermenu.h> #include "converter.h" #include "preseteditor.h" #include "converterdialog.h" @@ -186,25 +187,10 @@ void ConverterDialog::reject() void ConverterDialog::createMenus() { - QMenu *fileNameMenu = new QMenu(this); - fileNameMenu->addAction(tr("Artist"))->setData("%p"); - fileNameMenu->addAction(tr("Album"))->setData("%a"); - fileNameMenu->addAction(tr("Album Artist"))->setData("%aa"); - fileNameMenu->addAction(tr("Title"))->setData("%t"); - fileNameMenu->addAction(tr("Track Number"))->setData("%n"); - fileNameMenu->addAction(tr("Two-digit Track Number"))->setData("%NN"); - fileNameMenu->addAction(tr("Genre"))->setData("%g"); - fileNameMenu->addAction(tr("Comment"))->setData("%c"); - fileNameMenu->addAction(tr("Composer"))->setData("%C"); - fileNameMenu->addAction(tr("Duration"))->setData("%l"); - fileNameMenu->addAction(tr("Disc Number"))->setData("%D"); - fileNameMenu->addAction(tr("File Name"))->setData("%f"); - fileNameMenu->addAction(tr("File Path"))->setData("%F"); - fileNameMenu->addAction(tr("Year"))->setData("%y"); - fileNameMenu->addAction(tr("Condition"))->setData("%if(%p&%t,%p - %t,%f)"); + MetaDataFormatterMenu *fileNameMenu = new MetaDataFormatterMenu(MetaDataFormatterMenu::TITLE_MENU, this); m_ui.fileNameButton->setMenu(fileNameMenu); m_ui.fileNameButton->setPopupMode(QToolButton::InstantPopup); - connect(fileNameMenu, SIGNAL(triggered(QAction *)), SLOT(addTitleString(QAction *))); + connect(fileNameMenu, SIGNAL(patternSelected(QString)), SLOT(addTitleString(QString))); QMenu *presetMenu = new QMenu(this); presetMenu->addAction(tr("Create"), this, SLOT(createPreset())); @@ -215,12 +201,12 @@ void ConverterDialog::createMenus() m_ui.presetButton->setPopupMode(QToolButton::InstantPopup); } -void ConverterDialog::addTitleString(QAction *a) +void ConverterDialog::addTitleString(const QString &str) { if (m_ui.outFileEdit->cursorPosition () < 1) - m_ui.outFileEdit->insert(a->data().toString()); + m_ui.outFileEdit->insert(str); else - m_ui.outFileEdit->insert(" - "+a->data().toString()); + m_ui.outFileEdit->insert(" - "+str); } void ConverterDialog::createPreset() diff --git a/src/plugins/General/converter/converterdialog.h b/src/plugins/General/converter/converterdialog.h index c8cb59838..23c7384d9 100644 --- a/src/plugins/General/converter/converterdialog.h +++ b/src/plugins/General/converter/converterdialog.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2011-2016 by Ilya Kotov * + * Copyright (C) 2011-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -26,7 +26,6 @@ #include <QCloseEvent> #include "ui_converterdialog.h" -class QAction; class PlayListTrack; class ConverterPreset; class Converter; @@ -50,7 +49,7 @@ private slots: void on_stopButton_clicked(); void onStateChanged(int row, QString message); void onConvertFinished(Converter *c); - void addTitleString(QAction *a); + void addTitleString(const QString &str); void createPreset(); void editPreset(); void copyPreset(); diff --git a/src/plugins/General/fileops/settingsdialog.cpp b/src/plugins/General/fileops/settingsdialog.cpp index 475949d33..1f0f7db8b 100644 --- a/src/plugins/General/fileops/settingsdialog.cpp +++ b/src/plugins/General/fileops/settingsdialog.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2009-2015 by Ilya Kotov * + * Copyright (C) 2009-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -18,7 +18,6 @@ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ #include <QSettings> -#include <QMenu> #include <QHeaderView> #include <QApplication> #include <QCheckBox> @@ -26,6 +25,7 @@ #include <QDesktopServices> #include <qmmp/qmmp.h> #include <qmmpui/filedialog.h> +#include <qmmpui/metadataformattermenu.h> #include "fileops.h" #include "hotkeydialog.h" #include "settingsdialog.h" @@ -216,30 +216,15 @@ void SettingsDialog::on_patternEdit_textChanged(QString pattern) void SettingsDialog::createMenus() { - QMenu *menu = new QMenu(this); - menu->addAction(tr("Artist"))->setData("%p"); - menu->addAction(tr("Album"))->setData("%a"); - menu->addAction(tr("Album Artist"))->setData("%aa"); - menu->addAction(tr("Title"))->setData("%t"); - menu->addAction(tr("Track Number"))->setData("%n"); - menu->addAction(tr("Two-digit Track Number"))->setData("%NN"); - menu->addAction(tr("Genre"))->setData("%g"); - menu->addAction(tr("Comment"))->setData("%c"); - menu->addAction(tr("Composer"))->setData("%C"); - menu->addAction(tr("Duration"))->setData("%l"); - menu->addAction(tr("Disc Number"))->setData("%D"); - menu->addAction(tr("File Name"))->setData("%f"); - menu->addAction(tr("File Path"))->setData("%F"); - menu->addAction(tr("Year"))->setData("%y"); - menu->addAction(tr("Condition"))->setData("%if(%p&%t,%p - %t,%f)"); + MetaDataFormatterMenu *menu = new MetaDataFormatterMenu(MetaDataFormatterMenu::TITLE_MENU, this); m_ui.patternButton->setMenu(menu); m_ui.patternButton->setPopupMode(QToolButton::InstantPopup); - connect(menu, SIGNAL(triggered (QAction *)), SLOT(addTitleString( QAction *))); + connect(menu, SIGNAL(patternSelected(QString)), SLOT(addTitleString(QString))); } -void SettingsDialog::addTitleString(QAction *a) +void SettingsDialog::addTitleString(const QString &str) { - m_ui.patternEdit->insert(a->data().toString()); + m_ui.patternEdit->insert(str); } void SettingsDialog::on_destButton_clicked() diff --git a/src/plugins/General/fileops/settingsdialog.h b/src/plugins/General/fileops/settingsdialog.h index 00bf112dd..4b538db32 100644 --- a/src/plugins/General/fileops/settingsdialog.h +++ b/src/plugins/General/fileops/settingsdialog.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2009-2015 by Ilya Kotov * + * Copyright (C) 2009-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -21,7 +21,6 @@ #define SETTINGSDIALOG_H #include <QDialog> - #include "ui_settingsdialog.h" /** @@ -47,7 +46,7 @@ private slots: void updateLineEdits(); void on_destinationEdit_textChanged(QString dest); void on_patternEdit_textChanged(QString pattern); - void addTitleString(QAction *action); + void addTitleString(const QString &str); void on_destButton_clicked(); void on_tableWidget_itemDoubleClicked (QTableWidgetItem *item); diff --git a/src/plugins/General/trackchange/settingsdialog.cpp b/src/plugins/General/trackchange/settingsdialog.cpp index 5cc8991fb..8c5ca71e0 100644 --- a/src/plugins/General/trackchange/settingsdialog.cpp +++ b/src/plugins/General/trackchange/settingsdialog.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2013-2015 by Ilya Kotov * + * Copyright (C) 2013-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -21,6 +21,7 @@ #include <QSettings> #include <QMenu> #include <qmmp/qmmp.h> +#include <qmmpui/metadataformattermenu.h> #include "settingsdialog.h" SettingsDialog::SettingsDialog(QWidget *parent) : QDialog(parent) @@ -53,28 +54,13 @@ void SettingsDialog::accept() void SettingsDialog::addMenu(QToolButton *button) { - QMenu *menu = new QMenu(this); - menu->addAction(tr("Artist"))->setData("%p"); - menu->addAction(tr("Album"))->setData("%a"); - menu->addAction(tr("Album Artist"))->setData("%aa"); - menu->addAction(tr("Title"))->setData("%t"); - menu->addAction(tr("Track Number"))->setData("%n"); - menu->addAction(tr("Two-digit Track Number"))->setData("%NN"); - menu->addAction(tr("Genre"))->setData("%g"); - menu->addAction(tr("Comment"))->setData("%c"); - menu->addAction(tr("Composer"))->setData("%C"); - menu->addAction(tr("Duration"))->setData("%l"); - menu->addAction(tr("Disc Number"))->setData("%D"); - menu->addAction(tr("File Name"))->setData("%f"); - menu->addAction(tr("File Path"))->setData("%F"); - menu->addAction(tr("Year"))->setData("%y"); - menu->addAction(tr("Condition"))->setData("%if(%p&%t,%p - %t,%f)"); + MetaDataFormatterMenu *menu = new MetaDataFormatterMenu(MetaDataFormatterMenu::TITLE_MENU, this); button->setMenu(menu); button->setPopupMode(QToolButton::InstantPopup); - connect(menu, SIGNAL(triggered (QAction *)), SLOT(addTemplateString(QAction *))); + connect(menu, SIGNAL(patternSelected(QString)), SLOT(addTemplateString(QString))); } -void SettingsDialog::addTemplateString(QAction *a) +void SettingsDialog::addTemplateString(const QString &str) { QMenu *menu = qobject_cast<QMenu*> (sender()); if(!menu) @@ -82,18 +68,18 @@ void SettingsDialog::addTemplateString(QAction *a) if(m_ui.newTrackButton->menu() == menu) { - m_ui.newTrackLineEdit->insert(a->data().toString()); + m_ui.newTrackLineEdit->insert(str); } else if(m_ui.endOfTrackButton->menu() == menu) { - m_ui.endOfTrackLineEdit->insert(a->data().toString()); + m_ui.endOfTrackLineEdit->insert(str); } else if(m_ui.endOfPlayListButton->menu() == menu) { - m_ui.endOfPlayListLineEdit->insert(a->data().toString()); + m_ui.endOfPlayListLineEdit->insert(str); } else if(m_ui.titleChangeButton->menu() == menu) { - m_ui.titleChangeLineEdit->insert(a->data().toString()); + m_ui.titleChangeLineEdit->insert(str); } } diff --git a/src/plugins/General/trackchange/settingsdialog.h b/src/plugins/General/trackchange/settingsdialog.h index e7e55ef0c..fa0b00e1e 100644 --- a/src/plugins/General/trackchange/settingsdialog.h +++ b/src/plugins/General/trackchange/settingsdialog.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2013 by Ilya Kotov * + * Copyright (C) 2013-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -41,7 +41,7 @@ public slots: void accept(); private slots: - void addTemplateString(QAction *); + void addTemplateString(const QString &str); private: void addMenu(QToolButton *button); diff --git a/src/plugins/Ui/qsui/popupsettings.cpp b/src/plugins/Ui/qsui/popupsettings.cpp index 3c57cc0ee..320e9970e 100644 --- a/src/plugins/Ui/qsui/popupsettings.cpp +++ b/src/plugins/Ui/qsui/popupsettings.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2009-2015 by Ilya Kotov * + * Copyright (C) 2009-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -19,8 +19,8 @@ ***************************************************************************/ #include <QSettings> -#include <QMenu> #include <qmmp/qmmp.h> +#include <qmmpui/metadataformattermenu.h> #include "popupwidget.h" #include "popupsettings.h" @@ -39,7 +39,6 @@ PopupSettings::PopupSettings(QWidget *parent) createMenu(); } - PopupSettings::~PopupSettings() {} @@ -58,29 +57,9 @@ void PopupSettings::accept() void PopupSettings::createMenu() { - QMenu *menu = new QMenu(this); - menu->addAction(tr("Artist"))->setData("%p"); - menu->addAction(tr("Album"))->setData("%a"); - menu->addAction(tr("Album Artist"))->setData("%aa"); - menu->addAction(tr("Title"))->setData("%t"); - menu->addAction(tr("Track Number"))->setData("%n"); - menu->addAction(tr("Two-digit Track Number"))->setData("%NN"); - menu->addAction(tr("Genre"))->setData("%g"); - menu->addAction(tr("Comment"))->setData("%c"); - menu->addAction(tr("Composer"))->setData("%C"); - menu->addAction(tr("Duration"))->setData("%l"); - menu->addAction(tr("Disc Number"))->setData("%D"); - menu->addAction(tr("File Name"))->setData("%f"); - menu->addAction(tr("File Path"))->setData("%F"); - menu->addAction(tr("Year"))->setData("%y"); - menu->addAction(tr("Condition"))->setData("%if(%p&%t,%p - %t,%f)"); + MetaDataFormatterMenu *menu = new MetaDataFormatterMenu(MetaDataFormatterMenu::TITLE_MENU, this); m_ui.insertButton->setMenu(menu); - connect(menu, SIGNAL(triggered (QAction *)), SLOT(insertExpression(QAction *))); -} - -void PopupSettings::insertExpression(QAction *a) -{ - m_ui.textEdit->insertPlainText(a->data().toString()); + connect(menu, SIGNAL(patternSelected(QString)), m_ui.textEdit, SLOT(insertPlainText(QString))); } void PopupSettings::on_resetButton_clicked() diff --git a/src/plugins/Ui/qsui/popupsettings.h b/src/plugins/Ui/qsui/popupsettings.h index 6c5b7f545..b653b8d3b 100644 --- a/src/plugins/Ui/qsui/popupsettings.h +++ b/src/plugins/Ui/qsui/popupsettings.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2009-2015 by Ilya Kotov * + * Copyright (C) 2009-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -23,8 +23,6 @@ #include <QDialog> #include "ui_popupsettings.h" -class Action; - /** @author Ilya Kotov <forkotov02@hotmail.ru> */ @@ -40,7 +38,6 @@ public slots: virtual void accept(); private slots: - void insertExpression(QAction *); void on_resetButton_clicked(); private: diff --git a/src/plugins/Ui/qsui/qsuisettings.cpp b/src/plugins/Ui/qsui/qsuisettings.cpp index d64443f24..dc175e914 100644 --- a/src/plugins/Ui/qsui/qsuisettings.cpp +++ b/src/plugins/Ui/qsui/qsuisettings.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2011-2015 by Ilya Kotov * + * Copyright (C) 2011-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -21,10 +21,10 @@ #include <QSettings> #include <QDir> #include <QFontDialog> -#include <QMenu> #include <qmmp/qmmp.h> #include <qmmpui/filedialog.h> #include <qmmpui/uihelper.h> +#include <qmmpui/metadataformattermenu.h> #include "actionmanager.h" #include "shortcutitem.h" #include "shortcutdialog.h" @@ -114,27 +114,10 @@ void QSUISettings::loadFonts() void QSUISettings::createActions() { - QMenu *menu = new QMenu(this); - menu->addAction(tr("Artist"))->setData("%p"); - menu->addAction(tr("Album"))->setData("%a"); - menu->addAction(tr("Album Artist"))->setData("%aa"); - menu->addAction(tr("Title"))->setData("%t"); - menu->addAction(tr("Track Number"))->setData("%n"); - menu->addAction(tr("Two-digit Track Number"))->setData("%NN"); - menu->addAction(tr("Genre"))->setData("%g"); - menu->addAction(tr("Comment"))->setData("%c"); - menu->addAction(tr("Composer"))->setData("%C"); - menu->addAction(tr("Duration"))->setData("%l"); - menu->addAction(tr("Disc Number"))->setData("%D"); - menu->addAction(tr("File Name"))->setData("%f"); - menu->addAction(tr("File Path"))->setData("%F"); - menu->addAction(tr("Year"))->setData("%y"); - menu->addAction(tr("Condition"))->setData("%if(%p&%t,%p - %t,%f)"); - menu->addAction(tr("Artist - Title"))->setData("%if(%p,%p - %t,%t)"); - + MetaDataFormatterMenu *menu = new MetaDataFormatterMenu(MetaDataFormatterMenu::TITLE_MENU, this); m_ui.windowTitleButton->setMenu(menu); m_ui.windowTitleButton->setPopupMode(QToolButton::InstantPopup); - connect(menu, SIGNAL(triggered (QAction *)), SLOT(addWindowTitleString(QAction *))); + connect(menu, SIGNAL(patternSelected(QString)), SLOT(addWindowTitleString(QString))); } void QSUISettings::on_popupTemplateButton_clicked() @@ -236,10 +219,10 @@ void QSUISettings::on_resetFontsButton_clicked() loadFonts(); } -void QSUISettings::addWindowTitleString(QAction *a) +void QSUISettings::addWindowTitleString(const QString &str) { if (m_ui.windowTitleLineEdit->cursorPosition () < 1) - m_ui.windowTitleLineEdit->insert(a->data().toString()); + m_ui.windowTitleLineEdit->insert(str); else - m_ui.windowTitleLineEdit->insert(" - "+a->data().toString()); + m_ui.windowTitleLineEdit->insert(" - "+str); } diff --git a/src/plugins/Ui/qsui/qsuisettings.h b/src/plugins/Ui/qsui/qsuisettings.h index a6396a5c8..ea052aab1 100644 --- a/src/plugins/Ui/qsui/qsuisettings.h +++ b/src/plugins/Ui/qsui/qsuisettings.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2011-2015 by Ilya Kotov * + * Copyright (C) 2011-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -25,8 +25,6 @@ #include <QFileInfo> #include "ui_qsuisettings.h" -class QAction; - /** @author Ilya Kotov <forkotov02@hotmail.ru> */ @@ -45,7 +43,7 @@ private slots: void on_tabsFontButton_clicked(); void on_popupTemplateButton_clicked(); void on_resetFontsButton_clicked(); - void addWindowTitleString(QAction *a); + void addWindowTitleString(const QString &str); private: void showEvent(QShowEvent *); diff --git a/src/plugins/Ui/skinned/popupsettings.cpp b/src/plugins/Ui/skinned/popupsettings.cpp index e057f72ec..c6ceef853 100644 --- a/src/plugins/Ui/skinned/popupsettings.cpp +++ b/src/plugins/Ui/skinned/popupsettings.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2009-2015 by Ilya Kotov * + * Copyright (C) 2009-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -19,22 +19,22 @@ ***************************************************************************/ #include <QSettings> -#include <QMenu> #include <qmmp/qmmp.h> +#include <qmmpui/metadataformattermenu.h> #include "popupwidget.h" #include "popupsettings.h" PopupSettings::PopupSettings(QWidget *parent) : QDialog(parent) { - ui.setupUi(this); + m_ui.setupUi(this); QSettings settings(Qmmp::configFile(), QSettings::IniFormat); settings.beginGroup("Skinned"); - ui.transparencySlider->setValue(100 - settings.value("popup_opacity", 1.0).toDouble()*100); - ui.coverSizeSlider->setValue(settings.value ("popup_cover_size", 48).toInt()); - ui.textEdit->setPlainText(settings.value ("popup_template", DEFAULT_TEMPLATE).toString()); - ui.delaySpinBox->setValue(settings.value("popup_delay", 2500).toInt()); - ui.coverCheckBox->setChecked(settings.value("popup_show_cover",true).toBool()); + m_ui.transparencySlider->setValue(100 - settings.value("popup_opacity", 1.0).toDouble()*100); + m_ui.coverSizeSlider->setValue(settings.value ("popup_cover_size", 48).toInt()); + m_ui.textEdit->setPlainText(settings.value ("popup_template", DEFAULT_TEMPLATE).toString()); + m_ui.delaySpinBox->setValue(settings.value("popup_delay", 2500).toInt()); + m_ui.coverCheckBox->setChecked(settings.value("popup_show_cover",true).toBool()); settings.endGroup(); createMenu(); } @@ -47,43 +47,23 @@ void PopupSettings::accept() { QSettings settings(Qmmp::configFile(), QSettings::IniFormat); settings.beginGroup("Skinned"); - settings.setValue("popup_opacity", 1.0 - (double)ui.transparencySlider->value()/100); - settings.setValue("popup_cover_size", ui.coverSizeSlider->value()); - settings.setValue("popup_template", ui.textEdit->toPlainText()); - settings.setValue("popup_delay", ui.delaySpinBox->value()); - settings.setValue("popup_show_cover", ui.coverCheckBox->isChecked()); + settings.setValue("popup_opacity", 1.0 - (double)m_ui.transparencySlider->value()/100); + settings.setValue("popup_cover_size", m_ui.coverSizeSlider->value()); + settings.setValue("popup_template", m_ui.textEdit->toPlainText()); + settings.setValue("popup_delay", m_ui.delaySpinBox->value()); + settings.setValue("popup_show_cover", m_ui.coverCheckBox->isChecked()); settings.endGroup(); QDialog::accept(); } void PopupSettings::createMenu() { - QMenu *menu = new QMenu(this); - menu->addAction(tr("Artist"))->setData("%p"); - menu->addAction(tr("Album"))->setData("%a"); - menu->addAction(tr("Album Artist"))->setData("%aa"); - menu->addAction(tr("Title"))->setData("%t"); - menu->addAction(tr("Track Number"))->setData("%n"); - menu->addAction(tr("Two-digit Track Number"))->setData("%NN"); - menu->addAction(tr("Genre"))->setData("%g"); - menu->addAction(tr("Comment"))->setData("%c"); - menu->addAction(tr("Composer"))->setData("%C"); - menu->addAction(tr("Duration"))->setData("%l"); - menu->addAction(tr("Disc Number"))->setData("%D"); - menu->addAction(tr("File Name"))->setData("%f"); - menu->addAction(tr("File Path"))->setData("%F"); - menu->addAction(tr("Year"))->setData("%y"); - menu->addAction(tr("Condition"))->setData("%if(%p&%t,%p - %t,%f)"); - ui.insertButton->setMenu(menu); - connect(menu, SIGNAL(triggered (QAction *)), SLOT(insertExpression(QAction *))); -} - -void PopupSettings::insertExpression(QAction *a) -{ - ui.textEdit->insertPlainText(a->data().toString()); + MetaDataFormatterMenu *menu = new MetaDataFormatterMenu(MetaDataFormatterMenu::TITLE_MENU, this); + m_ui.insertButton->setMenu(menu); + connect(menu, SIGNAL(patternSelected(QString)), m_ui.textEdit, SLOT(insertPlainText(QString))); } void PopupSettings::on_resetButton_clicked() { - ui.textEdit->setPlainText(DEFAULT_TEMPLATE); + m_ui.textEdit->setPlainText(DEFAULT_TEMPLATE); } diff --git a/src/plugins/Ui/skinned/popupsettings.h b/src/plugins/Ui/skinned/popupsettings.h index ae60e89a2..84af1e7a5 100644 --- a/src/plugins/Ui/skinned/popupsettings.h +++ b/src/plugins/Ui/skinned/popupsettings.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2009 by Ilya Kotov * + * Copyright (C) 2009-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -23,10 +23,8 @@ #include <QDialog> #include "ui_popupsettings.h" -class Action; - /** - @author Ilya Kotov <forkotov02@hotmail.ru> + @author Ilya Kotov <forkotov02@hotmail.ru> */ class PopupSettings : public QDialog { @@ -35,17 +33,15 @@ public: PopupSettings(QWidget *parent = 0); ~PopupSettings(); - public slots: virtual void accept(); private slots: - void insertExpression(QAction *); void on_resetButton_clicked(); private: void createMenu(); - Ui::PopupSettings ui; + Ui::PopupSettings m_ui; QMap<uint, QPushButton*> m_buttons; }; diff --git a/src/plugins/Ui/skinned/skinnedsettings.cpp b/src/plugins/Ui/skinned/skinnedsettings.cpp index b068e2e80..dbcab3ccb 100644 --- a/src/plugins/Ui/skinned/skinnedsettings.cpp +++ b/src/plugins/Ui/skinned/skinnedsettings.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2011-2015 by Ilya Kotov * + * Copyright (C) 2011-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -21,10 +21,10 @@ #include <QSettings> #include <QDir> #include <QFontDialog> -#include <QMenu> #include <qmmp/qmmp.h> #include <qmmpui/filedialog.h> #include <qmmpui/uihelper.h> +#include <qmmpui/metadataformattermenu.h> #include "skinreader.h" #include "skin.h" #include "popupsettings.h" @@ -179,27 +179,10 @@ void SkinnedSettings::findSkins(const QString &path) void SkinnedSettings::createActions() { - QMenu *menu = new QMenu(this); - menu->addAction(tr("Artist"))->setData("%p"); - menu->addAction(tr("Album"))->setData("%a"); - menu->addAction(tr("Album Artist"))->setData("%aa"); - menu->addAction(tr("Title"))->setData("%t"); - menu->addAction(tr("Track Number"))->setData("%n"); - menu->addAction(tr("Two-digit Track Number"))->setData("%NN"); - menu->addAction(tr("Genre"))->setData("%g"); - menu->addAction(tr("Comment"))->setData("%c"); - menu->addAction(tr("Composer"))->setData("%C"); - menu->addAction(tr("Duration"))->setData("%l"); - menu->addAction(tr("Disc Number"))->setData("%D"); - menu->addAction(tr("File Name"))->setData("%f"); - menu->addAction(tr("File Path"))->setData("%F"); - menu->addAction(tr("Year"))->setData("%y"); - menu->addAction(tr("Condition"))->setData("%if(%p&%t,%p - %t,%f)"); - menu->addAction(tr("Artist - Title"))->setData("%if(%p,%p - %t,%t)"); - + MetaDataFormatterMenu *menu = new MetaDataFormatterMenu(MetaDataFormatterMenu::TITLE_MENU, this); m_ui.windowTitleButton->setMenu(menu); m_ui.windowTitleButton->setPopupMode(QToolButton::InstantPopup); - connect(menu, SIGNAL(triggered (QAction *)), SLOT(addWindowTitleString(QAction *))); + connect(menu, SIGNAL(patternSelected(QString)), SLOT(addWindowTitleString(QString))); } void SkinnedSettings::loadSkins() @@ -245,12 +228,12 @@ void SkinnedSettings::on_popupTemplateButton_clicked() p->deleteLater(); } -void SkinnedSettings::addWindowTitleString(QAction *a) +void SkinnedSettings::addWindowTitleString(const QString &str) { if (m_ui.windowTitleLineEdit->cursorPosition () < 1) - m_ui.windowTitleLineEdit->insert(a->data().toString()); + m_ui.windowTitleLineEdit->insert(str); else - m_ui.windowTitleLineEdit->insert(" - "+a->data().toString()); + m_ui.windowTitleLineEdit->insert(" - "+str); } void SkinnedSettings::readSettings() diff --git a/src/plugins/Ui/skinned/skinnedsettings.h b/src/plugins/Ui/skinned/skinnedsettings.h index 756019981..4fa2de9ab 100644 --- a/src/plugins/Ui/skinned/skinnedsettings.h +++ b/src/plugins/Ui/skinned/skinnedsettings.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2011-2015 by Ilya Kotov * + * Copyright (C) 2011-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -45,7 +45,7 @@ private slots: void on_skinInstallButton_clicked(); void loadSkins(); void on_popupTemplateButton_clicked(); - void addWindowTitleString(QAction *a); + void addWindowTitleString(const QString &str); diff --git a/src/qmmpui/CMakeLists.txt b/src/qmmpui/CMakeLists.txt index 83ec1d1a2..6846265bd 100644 --- a/src/qmmpui/CMakeLists.txt +++ b/src/qmmpui/CMakeLists.txt @@ -45,6 +45,7 @@ SET(libqmmpui_SRCS tageditor.cpp playlistmanager.cpp metadataformatter.cpp + metadataformattermenu.cpp templateeditor.cpp uiloader.cpp jumptotrackdialog.cpp @@ -78,6 +79,7 @@ SET(libqmmpui_HDRS normalcontainer_p.h groupedcontainer_p.h metadataformatter.h + metadataformattermenu.h uiloader.h uifactory.h pluginitem_p.h @@ -98,6 +100,7 @@ SET(libqmmpui_DEVEL_HDRS general.h mediaplayer.h metadataformatter.h + metadataformattermenu.h playlistdownloader.h playlistformat.h playlistitem.h @@ -140,8 +143,8 @@ install(TARGETS qmmpui LIBRARY DESTINATION ${LIB_DIR} RUNTIME DESTINATION bin ARCHIVE DESTINATION ${LIB_DIR}) IF(NOT ${CMAKE_SYSTEM_NAME} MATCHES Darwin) - install(FILES ${libqmmpui_DEVEL_HDRS} DESTINATION include/qmmpui) + install(FILES ${libqmmpui_DEVEL_HDRS} DESTINATION include/qmmpui) - configure_file(${CMAKE_CURRENT_SOURCE_DIR}/qmmpui.pc.in ${CMAKE_CURRENT_BINARY_DIR}/qmmpui.pc @ONLY) - install(FILES ${CMAKE_CURRENT_BINARY_DIR}/qmmpui.pc DESTINATION ${LIB_DIR}/pkgconfig) + configure_file(${CMAKE_CURRENT_SOURCE_DIR}/qmmpui.pc.in ${CMAKE_CURRENT_BINARY_DIR}/qmmpui.pc @ONLY) + install(FILES ${CMAKE_CURRENT_BINARY_DIR}/qmmpui.pc DESTINATION ${LIB_DIR}/pkgconfig) ENDIF() diff --git a/src/qmmpui/columneditor.cpp b/src/qmmpui/columneditor.cpp index ecb131dcf..8c5664088 100644 --- a/src/qmmpui/columneditor.cpp +++ b/src/qmmpui/columneditor.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2015 by Ilya Kotov * + * Copyright (C) 2015-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -20,6 +20,7 @@ #include <QMenu> #include "columneditor_p.h" +#include "metadataformattermenu.h" #include "ui_columneditor.h" ColumnEditor::ColumnEditor(const QString &name, const QString &patt, QWidget *parent) : @@ -50,12 +51,12 @@ QString ColumnEditor::pattern() const return m_ui->formatLineEdit->text(); } -void ColumnEditor::insertExpression(QAction *a) +void ColumnEditor::insertExpression(const QString &str) { if (m_ui->formatLineEdit->cursorPosition () < 1) - m_ui->formatLineEdit->insert(a->data().toString()); + m_ui->formatLineEdit->insert(str); else - m_ui->formatLineEdit->insert(" - "+a->data().toString()); + m_ui->formatLineEdit->insert(" - "+str); } void ColumnEditor::on_comboBox_activated(int index) @@ -74,25 +75,9 @@ void ColumnEditor::on_formatLineEdit_textChanged(const QString &text) void ColumnEditor::createMenu() { - QMenu *menu = new QMenu(this); - menu->addAction(tr("Artist"))->setData("%p"); - menu->addAction(tr("Album"))->setData("%a"); - menu->addAction(tr("Album Artist"))->setData("%aa"); - menu->addAction(tr("Title"))->setData("%t"); - menu->addAction(tr("Track Number"))->setData("%n"); - menu->addAction(tr("Two-digit Track Number"))->setData("%NN"); - menu->addAction(tr("Genre"))->setData("%g"); - menu->addAction(tr("Comment"))->setData("%c"); - menu->addAction(tr("Composer"))->setData("%C"); - menu->addAction(tr("Duration"))->setData("%l"); - menu->addAction(tr("Disc Number"))->setData("%D"); - menu->addAction(tr("File Name"))->setData("%f"); - menu->addAction(tr("File Path"))->setData("%F"); - menu->addAction(tr("Year"))->setData("%y"); - menu->addAction(tr("Track Index"))->setData("%I"); - menu->addAction(tr("Condition"))->setData("%if(%p,%p - %t,%t)"); + MetaDataFormatterMenu *menu = new MetaDataFormatterMenu(MetaDataFormatterMenu::TITLE_MENU, this); m_ui->formatButton->setMenu(menu); - connect(menu, SIGNAL(triggered (QAction *)), SLOT(insertExpression(QAction *))); + connect(menu, SIGNAL(patternSelected(QString)), SLOT(insertExpression(QString))); } void ColumnEditor::fillTypes() @@ -114,5 +99,6 @@ void ColumnEditor::fillTypes() m_ui->comboBox->addItem(tr("File Path"),"%F"); m_ui->comboBox->addItem(tr("Track Index"), "%I"); m_ui->comboBox->addItem(tr("Year"),"%y"); + m_ui->comboBox->addItem(tr("Parent Directory"),"%dir(0)"); m_ui->comboBox->addItem(tr("Custom"),"custom"); } diff --git a/src/qmmpui/columneditor_p.h b/src/qmmpui/columneditor_p.h index dc6a2815c..931b65955 100644 --- a/src/qmmpui/columneditor_p.h +++ b/src/qmmpui/columneditor_p.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2015 by Ilya Kotov * + * Copyright (C) 2015-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -41,7 +41,7 @@ public: QString pattern() const; private slots: - void insertExpression(QAction *a); + void insertExpression(const QString &str); void on_comboBox_activated(int index); void on_formatLineEdit_textChanged(const QString &text); diff --git a/src/qmmpui/configdialog.cpp b/src/qmmpui/configdialog.cpp index 423c1aae9..98e7135c3 100644 --- a/src/qmmpui/configdialog.cpp +++ b/src/qmmpui/configdialog.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2007-2016 by Ilya Kotov * + * Copyright (C) 2007-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -21,12 +21,6 @@ #include <QSettings> #include <QFontDialog> #include <QTreeWidgetItem> -#include <QHeaderView> -#include <QCheckBox> -#include <QRadioButton> -#include <QMenu> -#include <QMessageBox> -#include <QTreeWidgetItem> #include <qmmp/decoder.h> #include <qmmp/output.h> #include <qmmp/decoderfactory.h> @@ -52,6 +46,7 @@ #include "qmmpuisettings.h" #include "playlistmodel.h" #include "winfileassocpage_p.h" +#include "metadataformattermenu.h" #include "configdialog.h" ConfigDialog::ConfigDialog (QWidget *parent) : QDialog (parent) @@ -298,23 +293,10 @@ void ConfigDialog::on_informationButton_clicked() void ConfigDialog::createMenus() { - QMenu *groupMenu = new QMenu(this); - - groupMenu->addAction(tr("Artist"))->setData("%p"); - groupMenu->addAction(tr("Album"))->setData("%a"); - groupMenu->addAction(tr("Album Artist"))->setData("%aa"); - groupMenu->addAction(tr("Genre"))->setData("%g"); - groupMenu->addAction(tr("Comment"))->setData("%c"); - groupMenu->addAction(tr("Composer"))->setData("%C"); - groupMenu->addAction(tr("Disc Number"))->setData("%D"); - groupMenu->addAction(tr("Year"))->setData("%y"); - groupMenu->addAction(tr("Condition"))->setData("%if(%p&%a,%p - %a,%p%a)"); - groupMenu->addAction(tr("Artist/Album"))->setData("%p%if(%p&%a, - ,)%a"); - groupMenu->addAction(tr("Artist/Year/Album"))->setData("%p%if(%p&%a, - %if(%y,[%y] ,),)%a"); - + MetaDataFormatterMenu *groupMenu = new MetaDataFormatterMenu(MetaDataFormatterMenu::GROUP_MENU, this); m_ui->groupButton->setMenu(groupMenu); m_ui->groupButton->setPopupMode(QToolButton::InstantPopup); - connect(groupMenu, SIGNAL(triggered (QAction *)), SLOT(addGroupString(QAction *))); + connect(groupMenu, SIGNAL(patternSelected(QString)), SLOT(addGroupString(QString))); m_ui->treeWidget->setContextMenuPolicy(Qt::ActionsContextMenu); m_preferencesAction = new QAction(QIcon::fromTheme("configure"),tr("Preferences"), m_ui->treeWidget); @@ -369,12 +351,12 @@ void ConfigDialog::loadLanguages() m_ui->langComboBox->setCurrentIndex(index); } -void ConfigDialog::addGroupString(QAction *a) +void ConfigDialog::addGroupString(const QString &str) { if (m_ui->groupLineEdit->cursorPosition () < 1) - m_ui->groupLineEdit->insert(a->data().toString()); + m_ui->groupLineEdit->insert(str); else - m_ui->groupLineEdit->insert(" - "+a->data().toString()); + m_ui->groupLineEdit->insert(" - "+str); } void ConfigDialog::saveSettings() diff --git a/src/qmmpui/configdialog.h b/src/qmmpui/configdialog.h index ccbaa43f4..8b05c421c 100644 --- a/src/qmmpui/configdialog.h +++ b/src/qmmpui/configdialog.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2007-2015 by Ilya Kotov * + * Copyright (C) 2007-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -62,7 +62,7 @@ private slots: void on_contentsWidget_currentItemChanged (QListWidgetItem *current, QListWidgetItem *previous); void on_preferencesButton_clicked(); void on_informationButton_clicked(); - void addGroupString(QAction *a); + void addGroupString(const QString &str); void saveSettings(); void on_treeWidget_itemChanged (QTreeWidgetItem *item, int column); void on_treeWidget_currentItemChanged (QTreeWidgetItem *current, QTreeWidgetItem *); diff --git a/src/qmmpui/metadataformattermenu.cpp b/src/qmmpui/metadataformattermenu.cpp new file mode 100644 index 000000000..e9d84869a --- /dev/null +++ b/src/qmmpui/metadataformattermenu.cpp @@ -0,0 +1,56 @@ +/*************************************************************************** + * Copyright (C) 2017 by Ilya Kotov * + * forkotov02@hotmail.ru * + * * + * This program 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. * + * * + * This program 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, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#include "metadataformattermenu.h" + +MetaDataFormatterMenu::MetaDataFormatterMenu(Type type, QWidget *parent) : + QMenu(parent) +{ + addAction(tr("Artist"))->setData("%p"); + addAction(tr("Album"))->setData("%a"); + addAction(tr("Album Artist"))->setData("%aa"); + if(type == TITLE_MENU) + { + addAction(tr("Title"))->setData("%t"); + addAction(tr("Track Number"))->setData("%n"); + addAction(tr("Two-digit Track Number"))->setData("%NN"); + } + addAction(tr("Genre"))->setData("%g"); + addAction(tr("Comment"))->setData("%c"); + addAction(tr("Composer"))->setData("%C"); + addAction(tr("Duration"))->setData("%l"); + addAction(tr("Disc Number"))->setData("%D"); + if(type == TITLE_MENU) + { + addAction(tr("File Name"))->setData("%f"); + addAction(tr("File Path"))->setData("%F"); + } + addAction(tr("Year"))->setData("%y"); + addAction(tr("Condition"))->setData("%if(%p&%t,%p - %t,%f)"); + addAction(tr("Artist - Title"))->setData("%if(%p,%p - %t,%t)"); + addAction(tr("Parent Directory Name"))->setData("%dir(0)"); + + connect(this, SIGNAL(triggered (QAction *)), SLOT(onActionTriggered(QAction*))); +} + +void MetaDataFormatterMenu::onActionTriggered(QAction *action) +{ + emit patternSelected(action->data().toString()); +} diff --git a/src/qmmpui/metadataformattermenu.h b/src/qmmpui/metadataformattermenu.h new file mode 100644 index 000000000..10f30cfad --- /dev/null +++ b/src/qmmpui/metadataformattermenu.h @@ -0,0 +1,49 @@ +/*************************************************************************** + * Copyright (C) 2017 by Ilya Kotov * + * forkotov02@hotmail.ru * + * * + * This program 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. * + * * + * This program 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, write to the * + * Free Software Foundation, Inc., * + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * + ***************************************************************************/ + +#ifndef METADATAFORMATTERMENU_H +#define METADATAFORMATTERMENU_H + +#include <QMenu> + +class QAction; + +class MetaDataFormatterMenu : public QMenu +{ + Q_OBJECT +public: + + enum Type + { + TITLE_MENU = 0, + GROUP_MENU + }; + + explicit MetaDataFormatterMenu(Type type, QWidget *parent = 0); + +signals: + void patternSelected(const QString &pattern); + +private slots: + void onActionTriggered(QAction *action); + +}; + +#endif // METADATAFORMATTERMENU_H diff --git a/src/qmmpui/qmmpui.pro b/src/qmmpui/qmmpui.pro index 91b78321c..7278445b8 100644 --- a/src/qmmpui/qmmpui.pro +++ b/src/qmmpui/qmmpui.pro @@ -71,7 +71,8 @@ HEADERS += general.h \ columneditor_p.h \ playlistheadermodel.h \ metadatahelper_p.h \ - coverviewer_p.h + coverviewer_p.h \ + metadataformattermenu.h SOURCES += general.cpp \ playlistparser.cpp \ @@ -109,7 +110,8 @@ SOURCES += general.cpp \ columneditor.cpp \ playlistheadermodel.cpp \ metadatahelper.cpp \ - coverviewer.cpp + coverviewer.cpp \ + metadataformattermenu.cpp FORMS += forms/detailsdialog.ui \ forms/tageditor.ui \ @@ -165,7 +167,8 @@ unix { playlistgroup.h \ playlisttrack.h \ metadataformatter.h \ - playlistheadermodel.h + playlistheadermodel.h \ + metadataformattermenu.h devel.path = /include/qmmpui INSTALLS += target \ diff --git a/src/qmmpui/templateeditor.cpp b/src/qmmpui/templateeditor.cpp index 558c46ac3..1c44a4803 100644 --- a/src/qmmpui/templateeditor.cpp +++ b/src/qmmpui/templateeditor.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2010-2014 by Ilya Kotov * + * Copyright (C) 2010-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -18,8 +18,7 @@ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ -#include <QMenu> -#include <QAction> +#include "metadataformattermenu.h" #include "ui_templateeditor.h" #include "templateeditor.h" @@ -46,29 +45,9 @@ void TemplateEditor::setDefaultTemplate(const QString &text) void TemplateEditor::createMenu() { - QMenu *menu = new QMenu(this); - menu->addAction(tr("Artist"))->setData("%p"); - menu->addAction(tr("Album"))->setData("%a"); - menu->addAction(tr("Album Artist"))->setData("%aa"); - menu->addAction(tr("Title"))->setData("%t"); - menu->addAction(tr("Track Number"))->setData("%n"); - menu->addAction(tr("Two-digit Track Number"))->setData("%NN"); - menu->addAction(tr("Genre"))->setData("%g"); - menu->addAction(tr("Comment"))->setData("%c"); - menu->addAction(tr("Composer"))->setData("%C"); - menu->addAction(tr("Duration"))->setData("%l"); - menu->addAction(tr("Disc Number"))->setData("%D"); - menu->addAction(tr("File Name"))->setData("%f"); - menu->addAction(tr("File Path"))->setData("%F"); - menu->addAction(tr("Year"))->setData("%y"); - menu->addAction(tr("Condition"))->setData("%if(%p&%t,%p - %t,%f)"); + MetaDataFormatterMenu *menu = new MetaDataFormatterMenu(MetaDataFormatterMenu::TITLE_MENU, this); m_ui->insertButton->setMenu(menu); - connect(menu, SIGNAL(triggered (QAction *)), SLOT(insertExpression(QAction *))); -} - -void TemplateEditor::insertExpression(QAction *a) -{ - m_ui->textEdit->insertPlainText(a->data().toString()); + connect(menu, SIGNAL(patternSelected(QString)), m_ui->textEdit, SLOT(insertPlainText(QString))); } void TemplateEditor::on_resetButton_clicked() diff --git a/src/qmmpui/templateeditor.h b/src/qmmpui/templateeditor.h index 04b7bef18..1bf3aac1d 100644 --- a/src/qmmpui/templateeditor.h +++ b/src/qmmpui/templateeditor.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2010 by Ilya Kotov * + * Copyright (C) 2010-2017 by Ilya Kotov * * forkotov02@hotmail.ru * * * * This program is free software; you can redistribute it and/or modify * @@ -26,8 +26,6 @@ namespace Ui { class TemplateEditor; } -class QAction; - /*! @brief The TemplateEditor class provides simple template editor dialog. * @author Ilya Kotov <forkotov02@hotmail.ru> @@ -66,7 +64,6 @@ public: const QString &default_template = QString(), bool *ok = 0); private slots: - void insertExpression(QAction *a); void on_resetButton_clicked(); private: |
