Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Quick action context menu for WTrackProperty #2612

Merged
merged 54 commits into from
Apr 17, 2020
Merged
Show file tree
Hide file tree
Changes from 9 commits
Commits
Show all changes
54 commits
Select commit Hold shift + click to select a range
d09484f
widget/wtrackproperty: create context menu with placeholder action
hacksdump Mar 28, 2020
246d453
widget/wtrackproperty: add destructor
hacksdump Mar 29, 2020
62e914b
widget/wtrackproperty: conditional context menu
hacksdump Mar 29, 2020
456878d
widget/wtrackproperty: implement open in system file browser
hacksdump Mar 29, 2020
a13a86f
widget/wtrackproperty: add (non-functional) add to playlist menu
hacksdump Mar 29, 2020
9f4d818
widget/wtrackproperty: implement add to playlist function
hacksdump Mar 29, 2020
313db52
widget/wtrackproperty: implement add to crate menu
hacksdump Mar 29, 2020
92d6ce9
widget/wtrackproperty: add styles for QMenu
hacksdump Mar 30, 2020
9abb8a6
widget/wtrackproperty: introduce new class to decouple context menu f…
hacksdump Apr 1, 2020
746a565
widget/wtrackmenu: move remaining actions from wtracktableview
hacksdump Apr 2, 2020
458a2be
widget/wtrackmenu: fix multiple segfaults
hacksdump Apr 2, 2020
8750927
widget/wtrackmenu: connect signal from wtrackmenu to wtracktableview
hacksdump Apr 2, 2020
f212a29
widget/wtrackmenu: remove m_pCoverMenu->clear() call
hacksdump Apr 2, 2020
34603bc
widget/wtrackmenu: refactor slot functions to be generic
hacksdump Apr 4, 2020
8942e91
widget/wtrackmenu: filter options
hacksdump Apr 4, 2020
5cad360
widget/wtrackmenu: initialize pointers and fix filters
hacksdump Apr 4, 2020
8eb4adc
widget/wtrackmenu: move options to track table dependent
hacksdump Apr 5, 2020
57ca3aa
widget/wtrackmenu: code cleanup
hacksdump Apr 5, 2020
65905a5
WTrackMenu: refactor to functor syntax
hacksdump Apr 6, 2020
126c264
WTrackMenu: rename action to reasonable name
hacksdump Apr 6, 2020
95e3b8d
WTrackMenu: use setters and getters
hacksdump Apr 8, 2020
334e7cb
WTrackMenu: use pragma once
hacksdump Apr 8, 2020
89577b6
WTrackMenu: remove redundant delete from destructor
hacksdump Apr 8, 2020
27347c0
WTrackMenu: optimize menu updation
hacksdump Apr 9, 2020
f39e9aa
WTrackMenu: add checks in constructor and popup
hacksdump Apr 9, 2020
2342cfc
WTrackMenu: make menu functions generic
hacksdump Apr 9, 2020
934db21
WTrackMenu: remove unused code
hacksdump Apr 10, 2020
f7b0e09
WTrackMenu: fix Tango style
hacksdump Apr 10, 2020
6e5d895
WTrackMenu: add Deere style
hacksdump Apr 10, 2020
ae5acf9
WTrackMenu: add LateNight style
hacksdump Apr 10, 2020
d3ed592
WTrackMenu: add Shade style
hacksdump Apr 10, 2020
7aadd94
WTrackMenu: remove redundant code
hacksdump Apr 11, 2020
f2dad91
WTrackMenu: make info and tag dialogs independent
hacksdump Apr 11, 2020
c192045
WTrackTableView: fix probable memory leak
hacksdump Apr 11, 2020
1da180d
Merge branch 'master' into context-menu
hacksdump Apr 11, 2020
6de5013
cmake: remove extraneous files from CMakeLists.txt
hacksdump Apr 11, 2020
0143e7e
TrackModel: add function to check capabilities
hacksdump Apr 13, 2020
460e18b
DlgTrackInfo: rename changeTrack to loadTrackInternal
hacksdump Apr 13, 2020
d6e5b7d
WTrackMenu: add more debug information
hacksdump Apr 13, 2020
450709a
WTrackMenu: remove LoadTo from TrackModelFilters
hacksdump Apr 13, 2020
ba7fdfa
DlgTrackInfo: add comments for lambda-based connect
hacksdump Apr 13, 2020
1345912
WTrackTableView: use unique_ptr to store m_pMenu
hacksdump Apr 13, 2020
fe48344
WTrackMenu: rename filter to feature
hacksdump Apr 13, 2020
6aa661f
Trackmodel: pass by copying value
hacksdump Apr 15, 2020
ea65616
WTrackTableView: use parented_ptr with explicit delete
hacksdump Apr 15, 2020
d8930a0
WTrackProperty: declare features in an anonymous namespace
hacksdump Apr 15, 2020
b593807
DlgTrackInfo: create signal source specific slots
hacksdump Apr 15, 2020
09ae551
WTrackMenu: change comment to indicate function hiding
hacksdump Apr 15, 2020
c119674
WTrackMenu: add documentation
hacksdump Apr 15, 2020
5a9ff3c
WTrackMenu: update loadTracks documentation
hacksdump Apr 15, 2020
c18131d
WTrackMenu: add reason for giving null parent
hacksdump Apr 15, 2020
649b336
WTrackText: add WTrackMenu
hacksdump Apr 16, 2020
02b71ec
add doxygen compatible documentation
hacksdump Apr 16, 2020
557f996
WTrackMenu: warn about function hiding in comment
hacksdump Apr 17, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -717,6 +717,7 @@ add_library(mixxx-lib STATIC EXCLUDE_FROM_ALL
src/widget/wstarrating.cpp
hacksdump marked this conversation as resolved.
Show resolved Hide resolved
src/widget/wstatuslight.cpp
src/widget/wtime.cpp
src/widget/wtrackmenu.cpp
src/widget/wtrackproperty.cpp
src/widget/wtracktableview.cpp
src/widget/wtracktableviewheader.cpp
Expand Down Expand Up @@ -836,7 +837,7 @@ elseif(UNIX)
endif()

# The mixxx executable
add_executable(mixxx WIN32 src/main.cpp)
add_executable(mixxx WIN32 src/main.cpp src/widget/random.cpp src/widget/random.h)
Be-ing marked this conversation as resolved.
Show resolved Hide resolved
target_link_libraries(mixxx PUBLIC mixxx-lib)

#
Expand Down
1 change: 1 addition & 0 deletions build/depends.py
Original file line number Diff line number Diff line change
Expand Up @@ -1018,6 +1018,7 @@ def sources(self, build):
"src/widget/wlibrarytableview.cpp",
"src/widget/wanalysislibrarytableview.cpp",
"src/widget/wlibrarytextbrowser.cpp",
"src/widget/wtrackmenu.cpp",

"src/database/mixxxdb.cpp",
"src/database/schemamanager.cpp",
Expand Down
43 changes: 34 additions & 9 deletions res/skins/Tango/style.qss
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ WCueMenuPopup,
WCueMenuPopup QMenu,
WCueMenuPopup QLabel,
WCoverArtMenu,
WTrackProperty QMenu,
#LibraryContainer QMenu QCheckBox,
QToolTip,
#LibraryContainer QHeaderView {
Expand Down Expand Up @@ -2080,11 +2081,14 @@ WCueMenuPopup,
WCueMenuPopup QMenu,
WCueMenuPopup QLabel,
WCoverArtMenu,
WTrackProperty QMenu,
#LibraryContainer QMenu::item,
WBeatSpinBox QMenu::item,
WCueMenuPopup QMenu::item,
WCoverArtMenu::item,
WTrackProperty QMenu::item,
#LibraryContainer QMenu QCheckBox,
WTrackProperty QMenu QCheckBox,
#SkinSettings,
WEffectSelector, WEffectSelector QAbstractScrollArea,
#fadeModeCombobox, #fadeModeCombobox QAbstractScrollArea,
Expand All @@ -2098,6 +2102,7 @@ WBeatSpinBox QMenu,
WCueMenuPopup,
WCueMenuPopup QMenu,
WCoverArtMenu,
WTrackProperty QMenu,
#SkinSettings,
WEffectSelector QAbstractScrollArea,
#fadeModeCombobox QAbstractScrollArea {
Expand All @@ -2115,6 +2120,7 @@ WEffectSelector QAbstractScrollArea,
WBeatSpinBox QMenu::separator,
WCueMenuPopup QMenu::separator,
WCoverArtMenu::separator,
WTrackProperty QMenu::separator,
WSpinny QMenu::separator {
height: 0px;
border-top: 1px solid #000;
Expand All @@ -2125,6 +2131,8 @@ WEffectSelector QAbstractScrollArea,
WBeatSpinBox QMenu::item,
WCueMenuPopup QMenu::item,
WCoverArtMenu::item,
WTrackProperty QMenu::item,
WTrackProperty QMenu QCheckBox,
#LibraryContainer QMenu QCheckBox,
#SkinSettingsLabel,
#SkinSettingsButton,
Expand All @@ -2137,13 +2145,15 @@ WEffectSelector QAbstractScrollArea,
#LibraryContainer QMenu::item,
WBeatSpinBox QMenu::item,
WCueMenuPopup QMenu::item,
WCoverArtMenu::item {
WCoverArtMenu::item,
WTrackProperty QMenu::item {
/* right padding creates a margin to the menu expand arrow,
left padding should be bigger than menu icon width + menu icon
margin */
padding: 5px 12px 5px 25px;
}
#LibraryContainer QMenu QCheckBox {
#LibraryContainer QMenu QCheckBox,
WTrackProperty QMenu QCheckBox {
padding: 2px 10px 2px 3px;
}
/* icons in editline menu (searchbox, editable track properties)
Expand All @@ -2153,16 +2163,21 @@ WEffectSelector QAbstractScrollArea,
WCueMenuPopup QMenu::icon,
/* checkbox in Crate name context menu:
"[ ] Auto DJ Track Source" */
#LibraryContainer QMenu::indicator {
#LibraryContainer QMenu::indicator,
WTrackProperty QMenu::indicator {
margin: 0px 4px 0px 2px;
}
#LibraryContainer QMenu::item:selected,
WBeatSpinBox QMenu::item:selected,
WCueMenuPopup QMenu::item:selected,
WCoverArtMenu::item:selected,
WTrackProperty QMenu::item:selected,
#LibraryContainer QMenu QCheckBox:selected,
WBeatSpinBox QMenu QCheckBox:focus, /* selected by keyboard */
#LibraryContainer QMenu QCheckBox:hover, /* mouse hover */
WTrackProperty QMenu QCheckBox:selected,
WTrackProperty QMenu QCheckBox:focus,
WTrackProperty QMenu QCheckBox:hover,
#SkinSettingsButton:hover,
#SkinSettingsCategoryButton:hover,
WEffectSelector::item:selected,
Expand All @@ -2173,7 +2188,9 @@ WEffectSelector QAbstractScrollArea,
outline: none;
}
#LibraryContainer QMenu QCheckBox::indicator,
#LibraryContainer QMenu::indicator {
WTrackProperty QMenu QCheckBox::indicator,
#LibraryContainer QMenu::indicator,
WTrackProperty QMenu::indicator{
width: 13px;
height: 13px;
background-color: #0f0f0f;
Expand All @@ -2183,23 +2200,29 @@ WEffectSelector QAbstractScrollArea,
outline: none;
}
#LibraryContainer QMenu QCheckBox::indicator:checked,
#LibraryContainer QMenu::indicator:checked {
WTrackProperty QMenu QCheckBox::indicator:checked,
#LibraryContainer QMenu::indicator:checked,
WTrackProperty QMenu::indicator:checked {
image: url(skin:/buttons/btn_lib_checkmark.svg);
border: 1px solid #1e1e1e;
}
/* disabled menu checkbox */
#LibraryContainer QMenu QCheckBox::indicator:!enabled {
#LibraryContainer QMenu QCheckBox::indicator:!enabled,
WTrackProperty QMenu QCheckBox::indicator:!enabled {
background-color: #333;
border: 1px solid #222;
}
#LibraryContainer QMenu QCheckBox::indicator:!enabled:checked {
#LibraryContainer QMenu QCheckBox::indicator:!enabled:checked,
WTrackProperty QMenu QCheckBox::indicator:!enabled:checked {
image: url(skin:/buttons/btn_lib_checkmark_grey.svg);
}

#LibraryContainer QMenu::item:!enabled,
WBeatSpinBox QMenu::item:!enabled,
WCueMenuPopup QMenu::item:!enabled,
WCoverArtMenu::item:!enabled,
WTrackProperty QMenu::item:!enabled,
WTrackProperty QMenu QCheckBox:!enabled,
#LibraryContainer QMenu QCheckBox:!enabled {
color: #555;
}
Expand All @@ -2211,13 +2234,15 @@ WCoverArtMenu::item:!enabled,
#LibraryContainer QCheckBox::indicator:indeterminate:!enabled {
image: url(skin:/buttons/btn_lib_checkmark_grey.svg);
}
#LibraryContainer QMenu::right-arrow {
#LibraryContainer QMenu::right-arrow,
WTrackProperty QMenu::right-arrow {
width: 8px;
height: 16px;
margin-right: 4px;
image: url(skin:/buttons/btn_arrow_right.svg);
}
#LibraryContainer QMenu::right-arrow {
#LibraryContainer QMenu::right-arrow,
WTrackProperty QMenu::right-arrow {
image: url(skin:/buttons/btn_arrow_right_hover.svg);
}

Expand Down
2 changes: 1 addition & 1 deletion src/skin/legacyskinparser.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1039,7 +1039,7 @@ QWidget* LegacySkinParser::parseTrackProperty(const QDomElement& node) {
if (!pPlayer)
return NULL;

WTrackProperty* p = new WTrackProperty(pSafeChannelStr, m_pConfig, m_pParent);
WTrackProperty* p = new WTrackProperty(pSafeChannelStr, m_pConfig, m_pParent, m_pLibrary->trackCollections());
setupLabelWidget(node, p);

connect(pPlayer, SIGNAL(newTrackLoaded(TrackPointer)),
Expand Down
199 changes: 199 additions & 0 deletions src/widget/wtrackmenu.cpp
Original file line number Diff line number Diff line change
@@ -0,0 +1,199 @@
#include "widget/wtrackmenu.h"

#include <utility>
#include <iostream>
hacksdump marked this conversation as resolved.
Show resolved Hide resolved
#include <library/trackmodel.h>
#include <util/desktophelper.h>
#include "widget/wlibrarytableview.h"
#include "library/dao/trackdao.h"
#include "library/trackcollection.h"


WTrackMenu::WTrackMenu(QWidget *parent, TrackCollectionManager* pTrackCollectionManager)
: QMenu(parent),
m_pTrackCollectionManager(pTrackCollectionManager){
hacksdump marked this conversation as resolved.
Show resolved Hide resolved
m_pLoadToMenu = new QMenu(this);
m_pLoadToMenu->setTitle(tr("Load to"));
m_pDeckMenu = new QMenu(this);
m_pDeckMenu->setTitle(tr("Deck"));
m_pSamplerMenu = new QMenu(this);
m_pSamplerMenu->setTitle(tr("Sampler"));

m_pPlaylistMenu = new QMenu(this);
m_pPlaylistMenu->setTitle(tr("Add to Playlist"));
connect(m_pPlaylistMenu, SIGNAL(aboutToShow()),
this, SLOT(slotPopulatePlaylistMenu()));
hacksdump marked this conversation as resolved.
Show resolved Hide resolved
m_pCrateMenu = new QMenu(this);
m_pCrateMenu->setTitle(tr("Crates"));
connect(m_pCrateMenu, SIGNAL(aboutToShow()),
this, SLOT(slotPopulateCrateMenu()));

m_pMetadataMenu = new QMenu(this);
m_pMetadataMenu->setTitle(tr("Metadata"));

m_pMetadataUpdateExternalCollectionsMenu = new QMenu(this);
m_pMetadataUpdateExternalCollectionsMenu->setTitle(tr("Update external collections"));

m_pBPMMenu = new QMenu(this);
m_pBPMMenu->setTitle(tr("Adjust BPM"));

m_pColorMenu = new QMenu(this);
m_pColorMenu->setTitle(tr("Select Color"));

m_pClearMetadataMenu = new QMenu(this);
//: Reset metadata in right click track context menu in library
m_pClearMetadataMenu->setTitle(tr("Reset"));

m_pCoverMenu = new WCoverArtMenu(this);
m_pCoverMenu->setTitle(tr("Cover Art"));

connect(m_pCoverMenu, SIGNAL(coverInfoSelected(const CoverInfoRelative&)),
this, SLOT(slotCoverInfoSelected(const CoverInfoRelative&)));
connect(m_pCoverMenu, SIGNAL(reloadCoverArt()),
this, SLOT(slotReloadCoverArt()));
createActions();
}

WTrackMenu::~WTrackMenu() {
delete m_pImportMetadataFromFileAct;
delete m_pImportMetadataFromMusicBrainzAct;
delete m_pExportMetadataAct;
delete m_pAddToPreviewDeck;
delete m_pAutoDJBottomAct;
delete m_pAutoDJTopAct;
delete m_pAutoDJReplaceAct;
delete m_pRemoveAct;
delete m_pRemovePlaylistAct;
delete m_pRemoveCrateAct;
delete m_pHideAct;
delete m_pUnhideAct;
delete m_pPropertiesAct;
delete m_pLoadToMenu;
delete m_pDeckMenu;
delete m_pSamplerMenu;
delete m_pPlaylistMenu;
delete m_pCrateMenu;
delete m_pMetadataMenu;
delete m_pClearMetadataMenu;
delete m_pCoverMenu;
delete m_pBpmLockAction;
delete m_pBpmUnlockAction;
delete m_pBpmDoubleAction;
delete m_pBpmHalveAction;
delete m_pBpmTwoThirdsAction;
delete m_pBpmThreeFourthsAction;
delete m_pBpmFourThirdsAction;
delete m_pBpmThreeHalvesAction;
delete m_pBPMMenu;
delete m_pColorMenu;
delete m_pClearBeatsAction;
delete m_pClearPlayCountAction;
delete m_pClearMainCueAction;
delete m_pClearHotCuesAction;
delete m_pClearIntroCueAction;
delete m_pClearOutroCueAction;
delete m_pClearLoopAction;
delete m_pClearReplayGainAction;
delete m_pClearWaveformAction;
delete m_pClearKeyAction;
delete m_pClearAllMetadataAction;
delete m_pPurgeAct;
delete m_pFileBrowserAct;
}


void WTrackMenu::createActions() {
// DEBUG_ASSERT(this);
// DEBUG_ASSERT(m_pSamplerMenu);
//
// m_pRemoveAct = new QAction(tr("Remove"), this);
// connect(m_pRemoveAct, SIGNAL(triggered()), this, SLOT(slotRemove()));
//
// m_pRemovePlaylistAct = new QAction(tr("Remove from Playlist"), this);
// connect(m_pRemovePlaylistAct, SIGNAL(triggered()), this, SLOT(slotRemove()));
//
// m_pRemoveCrateAct = new QAction(tr("Remove from Crate"), this);
// connect(m_pRemoveCrateAct, SIGNAL(triggered()), this, SLOT(slotRemove()));
//
// m_pHideAct = new QAction(tr("Hide from Library"), this);
// connect(m_pHideAct, SIGNAL(triggered()), this, SLOT(slotHide()));
//
// m_pUnhideAct = new QAction(tr("Unhide from Library"), this);
// connect(m_pUnhideAct, SIGNAL(triggered()), this, SLOT(slotUnhide()));
//
// m_pPurgeAct = new QAction(tr("Purge from Library"), this);
// connect(m_pPurgeAct, SIGNAL(triggered()), this, SLOT(slotPurge()));
//
// m_pPropertiesAct = new QAction(tr("Properties"), this);
// connect(m_pPropertiesAct, SIGNAL(triggered()),
// this, SLOT(slotShowTrackInfo()));
//
m_pFileBrowserAct = new QAction(tr("Open in File Browser"), this);
connect(m_pFileBrowserAct, SIGNAL(triggered()),
this, SLOT(slotOpenInFileBrowser()));
//
// m_pAutoDJBottomAct = new QAction(tr("Add to Auto DJ Queue (bottom)"), this);
// connect(m_pAutoDJBottomAct, SIGNAL(triggered()),
// this, SLOT(slotAddToAutoDJBottom()));
//
// m_pAutoDJTopAct = new QAction(tr("Add to Auto DJ Queue (top)"), this);
// connect(m_pAutoDJTopAct, SIGNAL(triggered()),
// this, SLOT(slotAddToAutoDJTop()));
//
// m_pAutoDJReplaceAct = new QAction(tr("Add to Auto DJ Queue (replace)"), this);
// connect(m_pAutoDJReplaceAct, SIGNAL(triggered()),
// this, SLOT(slotAddToAutoDJReplace()));
//
// m_pImportMetadataFromFileAct = new QAction(tr("Import From File Tags"), this);
// connect(m_pImportMetadataFromFileAct, SIGNAL(triggered()),
// this, SLOT(slotImportTrackMetadataFromFileTags()));
//
// m_pImportMetadataFromMusicBrainzAct = new QAction(tr("Import From MusicBrainz"),this);
// connect(m_pImportMetadataFromMusicBrainzAct, SIGNAL(triggered()),
// this, SLOT(slotShowDlgTagFetcher()));
//
// m_pExportMetadataAct = new QAction(tr("Export To File Tags"), this);
// connect(m_pExportMetadataAct, SIGNAL(triggered()),
// this, SLOT(slotExportTrackMetadataIntoFileTags()));
}

void WTrackMenu::setTracks(TrackIdList trackIdList) {
m_pTrackIdList = std::move(trackIdList);
// Store the track pointers at each initialization of track ids.
trackIdsToTrackPointers();
// Add actions to menu
setupActions();
}

void WTrackMenu::setTrack(TrackId trackId) {
// Create a QList of single track to maintain common functions
// for single and multi track selection.
TrackIdList singleItemTrackIdList;
singleItemTrackIdList.push_back(trackId);
setTracks(singleItemTrackIdList);
}

void WTrackMenu::setupActions() {
addAction(m_pFileBrowserAct);
}

void WTrackMenu::slotOpenInFileBrowser() {
TrackPointerList trackPointerList = getTrackPointerList();
QStringList locations;
for (const TrackPointer& trackPointer : trackPointerList) {
locations << trackPointer->getLocation();
}
mixxx::DesktopHelper::openInFileBrowser(locations);
}

TrackPointerList WTrackMenu::getTrackPointerList() {
return m_pTrackPointerList;
}

void WTrackMenu::trackIdsToTrackPointers() {
m_pTrackPointerList.clear();
for (const auto trackId : m_pTrackIdList) {
TrackPointer trackPointer = m_pTrackCollectionManager->internalCollection()->getTrackById(trackId);
m_pTrackPointerList.push_back(trackPointer);
}
}
Loading