From f56e171e5aaf4f0459fa74ef671cee9a5e2f411b Mon Sep 17 00:00:00 2001 From: Oliver Kopp Date: Sun, 15 Mar 2020 23:22:12 +0100 Subject: [PATCH 01/20] Fix setting of title (and remove obsolete comments) --- src/main/java/org/jabref/gui/BasePanel.java | 18 ++------ src/main/java/org/jabref/gui/JabRefFrame.java | 46 ++++++------------- .../bibtexfields/NormalizePagesFormatter.java | 2 +- 3 files changed, 20 insertions(+), 46 deletions(-) diff --git a/src/main/java/org/jabref/gui/BasePanel.java b/src/main/java/org/jabref/gui/BasePanel.java index 548fe11456e..1e77ffb301e 100644 --- a/src/main/java/org/jabref/gui/BasePanel.java +++ b/src/main/java/org/jabref/gui/BasePanel.java @@ -70,7 +70,6 @@ public class BasePanel extends StackPane { private final FileAnnotationCache annotationCache; private final JabRefFrame frame; - // The undo manager. private final CountingUndoManager undoManager; private final SidePaneManager sidePaneManager; @@ -80,13 +79,10 @@ public class BasePanel extends StackPane { private final DialogService dialogService; private MainTable mainTable; private BasePanelPreferences preferences; - // To contain instantiated entry editors. This is to save time - // As most enums, this must not be null private BasePanelMode mode = BasePanelMode.SHOWING_NOTHING; private SplitPane splitPane; private DatabaseChangePane changePane; private boolean saving; - // AutoCompleter used in the search bar private PersonNameSuggestionProvider searchAutoCompleter; private boolean baseChanged; private boolean nonUndoableChange; @@ -539,11 +535,12 @@ public void updateEntryEditorIfShowing() { } } + /** + * Put an asterisk behind the filename to indicate the database has changed. + */ public void markBaseChanged() { baseChanged = true; - // Put an asterisk behind the filename to indicate the database has changed. - frame.setWindowTitle(); - DefaultTaskExecutor.runInJavaFXThread(frame::updateAllTabTitles); + frame.refreshTitleAndTabs(); } public void markNonUndoableBaseChanged() { @@ -558,13 +555,8 @@ public synchronized void markChangedOrUnChanged() { } } else if (baseChanged && !nonUndoableChange) { baseChanged = false; - if (getBibDatabaseContext().getDatabaseFile().isPresent()) { - frame.setTabTitle(this, getTabTitle(), getBibDatabaseContext().getDatabaseFile().get().getAbsolutePath()); - } else { - frame.setTabTitle(this, Localization.lang("untitled"), null); - } } - frame.setWindowTitle(); + frame.refreshTitleAndTabs(); } public BibDatabase getDatabase() { diff --git a/src/main/java/org/jabref/gui/JabRefFrame.java b/src/main/java/org/jabref/gui/JabRefFrame.java index f904f291fb5..0a0097fe6d2 100644 --- a/src/main/java/org/jabref/gui/JabRefFrame.java +++ b/src/main/java/org/jabref/gui/JabRefFrame.java @@ -147,7 +147,6 @@ */ public class JabRefFrame extends BorderPane { - // Frame titles. public static final String FRAME_TITLE = "JabRef"; private static final Logger LOGGER = LoggerFactory.getLogger(JabRefFrame.class); @@ -164,7 +163,6 @@ public class JabRefFrame extends BorderPane { private final CountingUndoManager undoManager; private final PushToApplicationsManager pushToApplicationsManager; private final DialogService dialogService; - private final JabRefExecutorService executorService; private SidePaneManager sidePaneManager; private TabPane tabbedPane; private SidePane sidePane; @@ -176,7 +174,6 @@ public JabRefFrame(Stage mainStage) { this.pushToApplicationsManager = new PushToApplicationsManager(dialogService, stateManager); this.undoManager = Globals.undoManager; this.fileHistory = new FileHistoryMenu(prefs, dialogService, getOpenDatabaseAction()); - this.executorService = JabRefExecutorService.INSTANCE; } private static BasePanel getBasePanel(Tab tab) { @@ -281,39 +278,26 @@ private Void showTrackingNotification() { public void refreshTitleAndTabs() { DefaultTaskExecutor.runInJavaFXThread(() -> { - - setWindowTitle(); updateAllTabTitles(); + setWindowTitle(); }); } /** * Sets the title of the main window. + * + * Relies on the result of updateAllTabTitles(). */ - public void setWindowTitle() { + private void setWindowTitle() { BasePanel panel = getCurrentBasePanel(); // no database open if (panel == null) { - //setTitle(FRAME_TITLE); + mainStage.setTitle(FRAME_TITLE); return; } - String mode = panel.getBibDatabaseContext().getMode().getFormattedName(); - String modeInfo = String.format(" (%s)", Localization.lang("%0 mode", mode)); - boolean isAutosaveEnabled = Globals.prefs.getBoolean(JabRefPreferences.LOCAL_AUTO_SAVE); - - if (panel.getBibDatabaseContext().getLocation() == DatabaseLocation.LOCAL) { - String changeFlag = panel.isModified() && !isAutosaveEnabled ? "*" : ""; - String databaseFile = panel.getBibDatabaseContext() - .getDatabaseFile() - .map(File::getPath) - .orElse(Localization.lang("untitled")); - //setTitle(FRAME_TITLE + " - " + databaseFile + changeFlag + modeInfo); - } else if (panel.getBibDatabaseContext().getLocation() == DatabaseLocation.SHARED) { - //setTitle(FRAME_TITLE + " - " + panel.getBibDatabaseContext().getDBMSSynchronizer().getDBName() + " [" - // + Localization.lang("shared") + "]" + modeInfo); - } + mainStage.setTitle(tabbedPane.getSelectionModel().getSelectedItem().getText() + " \u2013 " + FRAME_TITLE); } /** @@ -961,7 +945,7 @@ private List collectDatabaseFilePaths() { dbPaths.add(""); } } catch (IOException ex) { - LOGGER.error("Invalid database file path: " + ex.getMessage()); + LOGGER.error("Invalid database file path", ex); } } return dbPaths; @@ -969,34 +953,35 @@ private List collectDatabaseFilePaths() { private List getUniquePathParts() { List dbPaths = collectDatabaseFilePaths(); - return FileUtil.uniquePathSubstrings(dbPaths); } - public void updateAllTabTitles() { + private void updateAllTabTitles() { List paths = getUniquePathParts(); for (int i = 0; i < getBasePanelCount(); i++) { String uniqPath = paths.get(i); Optional file = getBasePanelAt(i).getBibDatabaseContext().getDatabaseFile(); + String newTitle; + if (file.isPresent()) { if (!uniqPath.equals(file.get().getName()) && uniqPath.contains(File.separator)) { // remove filename uniqPath = uniqPath.substring(0, uniqPath.lastIndexOf(File.separator)); - tabbedPane.getTabs().get(i).setText(getBasePanelAt(i).getTabTitle() + " \u2014 " + uniqPath); + newTitle = getBasePanelAt(i).getTabTitle() + " \u2013 " + uniqPath; } else { // set original filename (again) - tabbedPane.getTabs().get(i).setText(getBasePanelAt(i).getTabTitle()); + newTitle = getBasePanelAt(i).getTabTitle(); } } else { - tabbedPane.getTabs().get(i).setText(getBasePanelAt(i).getTabTitle()); + newTitle = getBasePanelAt(i).getTabTitle(); } + tabbedPane.getTabs().get(i).setText(newTitle); tabbedPane.getTabs().get(i).setTooltip(new Tooltip(file.map(File::getAbsolutePath).orElse(null))); } } public void addTab(BasePanel basePanel, boolean raisePanel) { - // add tab Tab newTab = new Tab(basePanel.getTabTitle(), basePanel); tabbedPane.getTabs().add(newTab); newTab.setOnCloseRequest(event -> { @@ -1004,14 +989,12 @@ public void addTab(BasePanel basePanel, boolean raisePanel) { event.consume(); }); - // update all tab titles updateAllTabTitles(); if (raisePanel) { tabbedPane.getSelectionModel().select(newTab); } - // Register undo/redo listener basePanel.getUndoManager().registerListener(new UndoRedoEventManager()); BibDatabaseContext context = basePanel.getBibDatabaseContext(); @@ -1023,7 +1006,6 @@ public void addTab(BasePanel basePanel, boolean raisePanel) { BackupManager.start(context, Globals.entryTypesManager, prefs); - // Track opening trackOpenNewDatabase(basePanel); } diff --git a/src/main/java/org/jabref/logic/formatter/bibtexfields/NormalizePagesFormatter.java b/src/main/java/org/jabref/logic/formatter/bibtexfields/NormalizePagesFormatter.java index 7829a0c928b..18c7bac8ebf 100644 --- a/src/main/java/org/jabref/logic/formatter/bibtexfields/NormalizePagesFormatter.java +++ b/src/main/java/org/jabref/logic/formatter/bibtexfields/NormalizePagesFormatter.java @@ -62,7 +62,7 @@ public String format(String value) { // Remove pages prefix String cleanValue = value.replace("pp.", "").replace("p.", ""); - // remove unwanted literals incl. whitespace + // remove unwanted literals including en dash, em dash, and whitespace cleanValue = cleanValue.replaceAll("\u2013|\u2014", "-").replaceAll(REJECT_LITERALS, ""); // try to find pages pattern Matcher matcher = PAGES_DETECT_PATTERN.matcher(cleanValue); From ffad7e825aead8e8900d674ec28ba9541c79fefa Mon Sep 17 00:00:00 2001 From: Oliver Kopp Date: Mon, 16 Mar 2020 07:39:03 +0100 Subject: [PATCH 02/20] Tab titles is determined in JabRefFrame only --- src/main/java/org/jabref/gui/BasePanel.java | 32 +-- src/main/java/org/jabref/gui/JabRefFrame.java | 190 ++++++++++++------ .../gui/exporter/SaveDatabaseAction.java | 6 +- .../gui/shared/SharedDatabaseUIManager.java | 2 +- 4 files changed, 134 insertions(+), 96 deletions(-) diff --git a/src/main/java/org/jabref/gui/BasePanel.java b/src/main/java/org/jabref/gui/BasePanel.java index 1e77ffb301e..c671bd15479 100644 --- a/src/main/java/org/jabref/gui/BasePanel.java +++ b/src/main/java/org/jabref/gui/BasePanel.java @@ -142,34 +142,6 @@ public SuggestionProviders getSuggestionProviders() { return suggestionProviders; } - public String getTabTitle() { - StringBuilder title = new StringBuilder(); - DatabaseLocation databaseLocation = this.bibDatabaseContext.getLocation(); - boolean isAutosaveEnabled = Globals.prefs.getBoolean(JabRefPreferences.LOCAL_AUTO_SAVE); - - if (databaseLocation == DatabaseLocation.LOCAL) { - if (this.bibDatabaseContext.getDatabaseFile().isPresent()) { - // check if file is modified - String changeFlag = isModified() && !isAutosaveEnabled ? "*" : ""; - title.append(this.bibDatabaseContext.getDatabaseFile().get().getName()).append(changeFlag); - } else { - title.append(Localization.lang("untitled")); - - if (getDatabase().hasEntries()) { - // if the database is not empty and no file is assigned, - // the database came from an import and has to be treated somehow - // -> mark as changed - // This also happens internally at basepanel to ensure consistency line 224 - title.append('*'); - } - } - } else if (databaseLocation == DatabaseLocation.SHARED) { - title.append(this.bibDatabaseContext.getDBMSSynchronizer().getDBName() + " [" + Localization.lang("shared") + "]"); - } - - return title.toString(); - } - public boolean isModified() { return baseChanged; } @@ -540,7 +512,7 @@ public void updateEntryEditorIfShowing() { */ public void markBaseChanged() { baseChanged = true; - frame.refreshTitleAndTabs(); + frame.refreshWindowAndTabTitles(); } public void markNonUndoableBaseChanged() { @@ -556,7 +528,7 @@ public synchronized void markChangedOrUnChanged() { } else if (baseChanged && !nonUndoableChange) { baseChanged = false; } - frame.refreshTitleAndTabs(); + frame.refreshWindowAndTabTitles(); } public BibDatabase getDatabase() { diff --git a/src/main/java/org/jabref/gui/JabRefFrame.java b/src/main/java/org/jabref/gui/JabRefFrame.java index 0a0097fe6d2..80159810e11 100644 --- a/src/main/java/org/jabref/gui/JabRefFrame.java +++ b/src/main/java/org/jabref/gui/JabRefFrame.java @@ -12,6 +12,7 @@ import java.util.Objects; import java.util.Optional; import java.util.TimerTask; +import java.util.stream.Collectors; import javafx.application.Platform; import javafx.beans.value.ChangeListener; @@ -276,28 +277,127 @@ private Void showTrackingNotification() { return null; } - public void refreshTitleAndTabs() { + /** + * Determines the titles of all tabs - and the window title. + * + * We aim for following in a tab: + * + * filename (datbase-mode) – path-fragment – JabRef + * + * path-fragment is only shown if filename is not (globally) unique + * + * Example: + * + * jabref-authors.bib (BibLaTeX) – testbib – JabRef + * + * For the JabRef window, it should be + * + * full-path (database-mode) – JabRef + * + * Example: + * + * C:\git-repositories\jabref\src\test\resources\testbib\jabref-authors.bib (BibLaTeX) – JabRef + */ + public void refreshWindowAndTabTitles() { DefaultTaskExecutor.runInJavaFXThread(() -> { - updateAllTabTitles(); - setWindowTitle(); + int selectedTabIndex = tabbedPane.getSelectionModel().getSelectedIndex(); + + List uniquePathParts = getUniquePathParts(); + for (int i = 0; i < getBasePanelCount(); i++) { + BasePanel panel = getBasePanelAt(i); + BibDatabaseContext bibDatabaseContext = panel.getBibDatabaseContext(); + DatabaseLocation databaseLocation = bibDatabaseContext.getLocation(); + Optional file = bibDatabaseContext.getDatabasePath(); + boolean isAutosaveEnabled = Globals.prefs.getBoolean(JabRefPreferences.LOCAL_AUTO_SAVE); + + StringBuilder tabTitle = new StringBuilder(); + StringBuilder toolTipText = new StringBuilder(); + StringBuilder windowTitle = new StringBuilder(); + + if (file.isPresent()) { + Path databasePath = file.get(); + String fileName = databasePath.getFileName().toString(); + tabTitle.append(fileName); + windowTitle.append(fileName); + toolTipText.append(databasePath.toAbsolutePath().toString()); + if (panel.isModified() && !isAutosaveEnabled) { + tabTitle.append('*'); + windowTitle.append('*'); + } + + if (databaseLocation == DatabaseLocation.SHARED) { + tabTitle.append(" \u2013 "); + addSharedDbInformation(tabTitle, bibDatabaseContext); + toolTipText.append(' '); + addSharedDbInformation(toolTipText, bibDatabaseContext); + windowTitle.append(" \u2013 "); + addSharedDbInformation(windowTitle, bibDatabaseContext); + } + + addModeInfo(toolTipText, bibDatabaseContext); + addModeInfo(windowTitle, bibDatabaseContext); + + if (panel.isModified() && !isAutosaveEnabled) { + addChangedInformation(toolTipText, fileName); + } + + String uniquePath = uniquePathParts.get(i); + if (!uniquePath.equals(fileName) && uniquePath.contains(File.separator)) { + // remove filename + uniquePath = uniquePath.substring(0, uniquePath.lastIndexOf(File.separator)); + tabTitle.append(" \u2013 ").append(uniquePath); + windowTitle.append(" \u2013 ").append(uniquePath); + } + } else { + if (databaseLocation == DatabaseLocation.LOCAL) { + tabTitle.append(Localization.lang("untitled")); + windowTitle.append(Localization.lang("untitled")); + if (bibDatabaseContext.getDatabase().hasEntries()) { + // if the database is not empty and no file is assigned, + // the database came from an import and has to be treated somehow + // -> mark as changed + tabTitle.append('*'); + windowTitle.append('*'); + } + } else { + addSharedDbInformation(tabTitle, bibDatabaseContext); + addSharedDbInformation(toolTipText, bibDatabaseContext); + } + addModeInfo(toolTipText, bibDatabaseContext); + addModeInfo(windowTitle, bibDatabaseContext); + if (databaseLocation == DatabaseLocation.LOCAL && bibDatabaseContext.getDatabase().hasEntries()) { + addChangedInformation(toolTipText, Localization.lang("untitled")); + } + } + + tabbedPane.getTabs().get(i).setText(tabTitle.toString()); + tabbedPane.getTabs().get(i).setTooltip(new Tooltip(toolTipText.toString())); + + if (i == selectedTabIndex) { + windowTitle.append(" \u2013 "); + windowTitle.append(FRAME_TITLE); + mainStage.setTitle(windowTitle.toString()); + } + } }); } - /** - * Sets the title of the main window. - * - * Relies on the result of updateAllTabTitles(). - */ - private void setWindowTitle() { - BasePanel panel = getCurrentBasePanel(); + private void addChangedInformation(StringBuilder text, String fileName) { + text.append(". "); + text.append(Localization.lang("Library '%0' has changed.", fileName)); + } - // no database open - if (panel == null) { - mainStage.setTitle(FRAME_TITLE); - return; - } + private void addModeInfo(StringBuilder text, BibDatabaseContext bibDatabaseContext) { + String mode = bibDatabaseContext.getMode().getFormattedName(); + String modeInfo = String.format(" (%s)", Localization.lang("%0 mode", mode)); + text.append(modeInfo); + } - mainStage.setTitle(tabbedPane.getSelectionModel().getSelectedItem().getText() + " \u2013 " + FRAME_TITLE); + private void addSharedDbInformation(StringBuilder text, BibDatabaseContext bibDatabaseContext) { + text.append(bibDatabaseContext.getDBMSSynchronizer().getDBName()); + text.append(" ["); + text.append(Localization.lang("shared")); + text.append("]"); } /** @@ -509,14 +609,12 @@ public BasePanel getBasePanelAt(int i) { } /** - * Returns a list of BasePanel. + * Returns a list of all BasePanels in this frame. */ public List getBasePanelList() { - List returnList = new ArrayList<>(); - for (int i = 0; i < getBasePanelCount(); i++) { - returnList.add(getBasePanelAt(i)); - } - return returnList; + return tabbedPane.getTabs().stream() + .map(tab -> (BasePanel) tab.getContent()) + .collect(Collectors.toList()); } public void showBasePanelAt(int i) { @@ -585,7 +683,11 @@ public void init() { //generalFetcher.getToggleCommand().setSelected(sidePaneManager.isComponentVisible(WebSearchPane.class)); //openOfficePanel.getToggleCommand().setSelected(sidePaneManager.isComponentVisible(OpenOfficeSidePanel.class)); - setWindowTitle(); + // We need to refresh the window title only + // There is currently no optimized method to set the title only (because that lead to code duplication) + // Thus, we refresh everything + refreshWindowAndTabTitles(); + // Update search autocompleter with information for the correct database: newBasePanel.updateSearchManager(); @@ -629,14 +731,6 @@ public TabPane getTabbedPane() { return tabbedPane; } - public void setTabTitle(BasePanel comp, String title, String toolTip) { - DefaultTaskExecutor.runInJavaFXThread(() -> { - Tab tab = getTab(comp); - tab.setText(title); - tab.setTooltip(new Tooltip(toolTip)); - }); - } - private MenuBar createMenu() { ActionFactory factory = new ActionFactory(Globals.getKeyPrefs()); Menu file = new Menu(Localization.lang("File")); @@ -956,40 +1050,16 @@ private List getUniquePathParts() { return FileUtil.uniquePathSubstrings(dbPaths); } - private void updateAllTabTitles() { - List paths = getUniquePathParts(); - for (int i = 0; i < getBasePanelCount(); i++) { - String uniqPath = paths.get(i); - Optional file = getBasePanelAt(i).getBibDatabaseContext().getDatabaseFile(); - - String newTitle; - - if (file.isPresent()) { - if (!uniqPath.equals(file.get().getName()) && uniqPath.contains(File.separator)) { - // remove filename - uniqPath = uniqPath.substring(0, uniqPath.lastIndexOf(File.separator)); - newTitle = getBasePanelAt(i).getTabTitle() + " \u2013 " + uniqPath; - } else { - // set original filename (again) - newTitle = getBasePanelAt(i).getTabTitle(); - } - } else { - newTitle = getBasePanelAt(i).getTabTitle(); - } - tabbedPane.getTabs().get(i).setText(newTitle); - tabbedPane.getTabs().get(i).setTooltip(new Tooltip(file.map(File::getAbsolutePath).orElse(null))); - } - } - public void addTab(BasePanel basePanel, boolean raisePanel) { - Tab newTab = new Tab(basePanel.getTabTitle(), basePanel); + // "" is passed as title, because it is updated below at "refreshWindowAndTabTitles()" + Tab newTab = new Tab("", basePanel); tabbedPane.getTabs().add(newTab); newTab.setOnCloseRequest(event -> { closeTab((BasePanel) newTab.getContent()); event.consume(); }); - updateAllTabTitles(); + refreshWindowAndTabTitles(); if (raisePanel) { tabbedPane.getSelectionModel().select(newTab); @@ -1164,9 +1234,7 @@ private void removeTab(BasePanel panel) { DefaultTaskExecutor.runInJavaFXThread(() -> { panel.cleanUp(); tabbedPane.getTabs().remove(getTab(panel)); - setWindowTitle(); - // update tab titles - updateAllTabTitles(); + this.refreshWindowAndTabTitles(); }); } diff --git a/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java b/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java index aedef2b2534..cc57329a459 100644 --- a/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java +++ b/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java @@ -129,7 +129,7 @@ boolean saveAs(Path file, SaveDatabaseMode mode) { // we managed to successfully save the file // thus, we can store the store the path into the context context.setDatabasePath(file); - frame.refreshTitleAndTabs(); + frame.refreshWindowAndTabTitles(); // Reinstall AutosaveManager and BackupManager for the new file name panel.resetChangeMonitorAndChangePane(); @@ -200,9 +200,7 @@ private boolean save(Path targetPath, SaveDatabaseMode mode) { panel.setNonUndoableChange(false); panel.setBaseChanged(false); - frame.setTabTitle(panel, panel.getTabTitle(), targetPath.toAbsolutePath().toString()); - frame.setWindowTitle(); - frame.updateAllTabTitles(); + frame.refreshWindowAndTabTitles(); } return success; } catch (SaveException ex) { diff --git a/src/main/java/org/jabref/gui/shared/SharedDatabaseUIManager.java b/src/main/java/org/jabref/gui/shared/SharedDatabaseUIManager.java index 56fd9dd74ba..546a4931c91 100644 --- a/src/main/java/org/jabref/gui/shared/SharedDatabaseUIManager.java +++ b/src/main/java/org/jabref/gui/shared/SharedDatabaseUIManager.java @@ -67,7 +67,7 @@ public void listen(ConnectionLostEvent connectionLostEvent) { } else if (answer.get().equals(workOffline)) { connectionLostEvent.getBibDatabaseContext().convertToLocalDatabase(); - jabRefFrame.refreshTitleAndTabs(); + jabRefFrame.refreshWindowAndTabTitles(); jabRefFrame.getDialogService().notify(Localization.lang("Working offline.")); } } else { From ce0e098ae37832b79fbb77079c26e405bebb3e16 Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Sun, 27 Sep 2020 16:20:03 +0200 Subject: [PATCH 03/20] Fixed some small merge errors and code optimizations --- src/main/java/org/jabref/gui/BasePanel.java | 7 +-- src/main/java/org/jabref/gui/JabRefFrame.java | 33 -------------- .../java/org/jabref/gui/edit/EditAction.java | 44 ++++++------------- .../org/jabref/gui/maintable/MainTable.java | 27 ++++++------ 4 files changed, 27 insertions(+), 84 deletions(-) diff --git a/src/main/java/org/jabref/gui/BasePanel.java b/src/main/java/org/jabref/gui/BasePanel.java index c9c631f39ab..cc77cc61d79 100644 --- a/src/main/java/org/jabref/gui/BasePanel.java +++ b/src/main/java/org/jabref/gui/BasePanel.java @@ -32,7 +32,6 @@ import org.jabref.logic.l10n.Localization; import org.jabref.logic.pdf.FileAnnotationCache; import org.jabref.logic.search.SearchQuery; -import org.jabref.logic.shared.DatabaseLocation; import org.jabref.logic.util.UpdateField; import org.jabref.model.FieldChange; import org.jabref.model.database.BibDatabase; @@ -149,10 +148,6 @@ public JabRefFrame frame() { return frame; } - public void output(String s) { - dialogService.notify(s); - } - /** * Removes the selected entries from the database * @@ -182,7 +177,7 @@ private void delete(boolean cut, List entries) { ensureNotShowingBottomPanel(entries); markBaseChanged(); - this.output(formatOutputMessage(cut ? Localization.lang("Cut") : Localization.lang("Deleted"), entries.size())); + dialogService.notify(formatOutputMessage(cut ? Localization.lang("Cut") : Localization.lang("Deleted"), entries.size())); // prevent the main table from loosing focus mainTable.requestFocus(); diff --git a/src/main/java/org/jabref/gui/JabRefFrame.java b/src/main/java/org/jabref/gui/JabRefFrame.java index 4e78eaa52c0..c876a90c5c5 100644 --- a/src/main/java/org/jabref/gui/JabRefFrame.java +++ b/src/main/java/org/jabref/gui/JabRefFrame.java @@ -135,9 +135,7 @@ import org.jabref.logic.util.OS; import org.jabref.logic.util.io.FileUtil; import org.jabref.model.database.BibDatabaseContext; -import org.jabref.model.entry.BibEntry; import org.jabref.model.entry.field.SpecialField; -import org.jabref.model.entry.field.StandardField; import org.jabref.model.entry.types.StandardEntryType; import org.jabref.preferences.JabRefPreferences; import org.jabref.preferences.LastFocusedTabPreferences; @@ -182,7 +180,6 @@ public JabRefFrame(Stage mainStage) { this.pushToApplicationsManager = new PushToApplicationsManager(dialogService, stateManager, prefs); this.undoManager = Globals.undoManager; this.fileHistory = new FileHistoryMenu(prefs, dialogService, getOpenDatabaseAction()); - this.executorService = JabRefExecutorService.INSTANCE; this.setOnKeyTyped(key -> { if (this.fileHistory.isShowing()) { if (this.fileHistory.openFileByKey(key)) { @@ -1253,36 +1250,6 @@ public FileHistoryMenu getFileHistory() { return fileHistory; } - /** - * Return a boolean, if the selected entry have file - * - * @param selectEntryList A selected entries list of the current base pane - * @return true, if the selected entry contains file. false, if multiple entries are selected or the selected entry - * doesn't contains file - */ - private boolean isExistFile(List selectEntryList) { - if (selectEntryList.size() == 1) { - BibEntry selectedEntry = selectEntryList.get(0); - return selectedEntry.getField(StandardField.FILE).isPresent(); - } - return false; - } - - /** - * Return a boolean, if the selected entry have url or doi - * - * @param selectEntryList A selected entries list of the current base pane - * @return true, if the selected entry contains url or doi. false, if multiple entries are selected or the selected - * entry doesn't contains url or doi - */ - private boolean isExistURLorDOI(List selectEntryList) { - if (selectEntryList.size() == 1) { - BibEntry selectedEntry = selectEntryList.get(0); - return (selectedEntry.getField(StandardField.URL).isPresent() || selectedEntry.getField(StandardField.DOI).isPresent()); - } - return false; - } - /** * Ask if the user really wants to close the given database * diff --git a/src/main/java/org/jabref/gui/edit/EditAction.java b/src/main/java/org/jabref/gui/edit/EditAction.java index a979e51e7ec..643cc37d9ec 100644 --- a/src/main/java/org/jabref/gui/edit/EditAction.java +++ b/src/main/java/org/jabref/gui/edit/EditAction.java @@ -44,49 +44,31 @@ public String toString() { @Override public void execute() { stateManager.getFocusOwner().ifPresent(focusOwner -> { - LOGGER.debug("EditAction - focusOwner: {}; Action: {}", focusOwner.toString(), action.getText()); + LOGGER.debug("focusOwner: {}; Action: {}", focusOwner.toString(), action.getText()); if (focusOwner instanceof TextInputControl) { // Focus is on text field -> copy/paste/cut selected text TextInputControl textInput = (TextInputControl) focusOwner; + // DELETE_ENTRY in text field should do forward delete switch (action) { - case COPY: - textInput.copy(); - break; - case CUT: - textInput.cut(); - break; - case PASTE: - textInput.paste(); - break; - case DELETE_ENTRY: - // DELETE_ENTRY in text field should do forward delete - textInput.deleteNextChar(); - break; - default: - throw new IllegalStateException("Only cut/copy/paste supported in TextInputControl but got " + action); + case COPY -> textInput.copy(); + case CUT -> textInput.cut(); + case PASTE -> textInput.paste(); + case DELETE_ENTRY -> textInput.deleteNextChar(); + default -> throw new IllegalStateException("Only cut/copy/paste supported in TextInputControl but got " + action); } } else if (!(focusOwner instanceof CodeArea)) { - LOGGER.debug("EditAction - Else: {}", frame.getCurrentBasePanel().getTabTitle()); + LOGGER.debug("Else: {}", focusOwner.getClass().getSimpleName()); // Not sure what is selected -> copy/paste/cut selected entries // ToDo: Should be handled by BibDatabaseContext instead of BasePanel switch (action) { - case COPY: - frame.getCurrentBasePanel().copy(); - break; - case CUT: - frame.getCurrentBasePanel().cut(); - break; - case PASTE: - frame.getCurrentBasePanel().paste(); - break; - case DELETE_ENTRY: - frame.getCurrentBasePanel().delete(false); - break; - default: - throw new IllegalStateException("Only cut/copy/paste supported but got " + action); + case COPY -> frame.getCurrentBasePanel().copy(); + case CUT -> frame.getCurrentBasePanel().cut(); + case PASTE -> frame.getCurrentBasePanel().paste(); + case DELETE_ENTRY -> frame.getCurrentBasePanel().delete(false); + default -> throw new IllegalStateException("Only cut/copy/paste supported but got " + action); } } }); diff --git a/src/main/java/org/jabref/gui/maintable/MainTable.java b/src/main/java/org/jabref/gui/maintable/MainTable.java index c1c5cab22ab..d13ccf54285 100644 --- a/src/main/java/org/jabref/gui/maintable/MainTable.java +++ b/src/main/java/org/jabref/gui/maintable/MainTable.java @@ -58,6 +58,7 @@ public class MainTable extends TableView { private static final Logger LOGGER = LoggerFactory.getLogger(MainTable.class); private final BasePanel panel; + private final DialogService dialogService; private final BibDatabaseContext database; private final MainTableDataModel model; @@ -78,6 +79,7 @@ public MainTable(MainTableDataModel model, super(); this.panel = panel; + this.dialogService = dialogService; this.database = Objects.requireNonNull(database); this.model = model; UndoManager undoManager = panel.getUndoManager(); @@ -221,7 +223,7 @@ public void copy() { if (!selectedEntries.isEmpty()) { try { Globals.clipboardManager.setContent(selectedEntries); - panel.output(panel.formatOutputMessage(Localization.lang("Copied"), selectedEntries.size())); + dialogService.notify(panel.formatOutputMessage(Localization.lang("Copied"), selectedEntries.size())); } catch (IOException e) { LOGGER.error("Error while copying selected entries to clipboard", e); } @@ -348,29 +350,26 @@ private void handleOnDragDropped(TableRow row, BibEntryT // Different actions depending on where the user releases the drop in the target row // Bottom + top -> import entries // Center -> link files to entry + // Depending on the pressed modifier, move/copy/link files to drop target switch (ControlHelper.getDroppingMouseLocation(row, event)) { - case TOP: - case BOTTOM: - importHandler.importAsNewEntries(files); - break; - case CENTER: - // Depending on the pressed modifier, move/copy/link files to drop target + case TOP, BOTTOM -> importHandler.importAsNewEntries(files); + case CENTER -> { BibEntry entry = target.getEntry(); switch (event.getTransferMode()) { - case LINK: + case LINK -> { LOGGER.debug("Mode LINK"); // shift on win or no modifier importHandler.getLinker().addFilesToEntry(entry, files); - break; - case MOVE: + } + case MOVE -> { LOGGER.debug("Mode MOVE"); // alt on win importHandler.getLinker().moveFilesToFileDirAndAddToEntry(entry, files); - break; - case COPY: + } + case COPY -> { LOGGER.debug("Mode Copy"); // ctrl on win importHandler.getLinker().copyFilesToFileDirAndAddToEntry(entry, files); - break; + } } - break; + } } success = true; From f3dacfc08bde09bf8fe594d841f87afad67bbef3 Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Tue, 29 Sep 2020 00:30:03 +0200 Subject: [PATCH 04/20] Refactored BasePanel to LibraryTab and applied some IntelliJ suggestions --- .../java/org/jabref/gui/EntryTypeView.java | 13 +- .../org/jabref/gui/EntryTypeViewModel.java | 26 +- src/main/java/org/jabref/gui/JabRefFrame.java | 235 ++++++++---------- src/main/java/org/jabref/gui/JabRefGUI.java | 16 +- .../gui/{BasePanel.java => LibraryTab.java} | 14 +- .../jabref/gui/WaitForSaveFinishedDialog.java | 8 +- .../jabref/gui/auximport/FromAuxDialog.java | 8 +- .../CitationKeyPatternAction.java | 2 +- .../CitationKeyPatternDialog.java | 14 +- .../CitationKeyPatternPanel.java | 16 +- .../GenerateCitationKeyAction.java | 2 +- .../org/jabref/gui/cleanup/CleanupAction.java | 4 +- .../ContentSelectorDialogView.java | 10 +- .../ContentSelectorDialogViewModel.java | 14 +- .../ManageContentSelectorAction.java | 6 +- .../jabref/gui/dialogs/AutosaveUiManager.java | 14 +- .../duplicationFinder/DuplicateSearch.java | 20 +- .../java/org/jabref/gui/edit/EditAction.java | 10 +- .../jabref/gui/edit/ReplaceStringAction.java | 2 +- .../jabref/gui/edit/ReplaceStringView.java | 6 +- .../gui/edit/ReplaceStringViewModel.java | 10 +- .../jabref/gui/entryeditor/EntryEditor.java | 50 ++-- .../entryeditor/OpenEntryEditorAction.java | 2 +- .../gui/entryeditor/PreviewSwitchAction.java | 4 +- .../jabref/gui/exporter/ExportCommand.java | 10 +- .../gui/exporter/ExportToClipboardAction.java | 8 +- .../org/jabref/gui/exporter/SaveAction.java | 2 +- .../jabref/gui/exporter/SaveAllAction.java | 6 +- .../gui/exporter/SaveDatabaseAction.java | 12 +- .../IdentifierEditorViewModel.java | 4 +- .../org/jabref/gui/importer/ImportAction.java | 9 +- .../gui/importer/ImportEntriesViewModel.java | 2 +- .../jabref/gui/importer/NewEntryAction.java | 6 +- .../actions/CheckForNewEntryTypesAction.java | 4 +- .../importer/actions/GUIPostOpenAction.java | 4 +- .../actions/MergeReviewIntoCommentAction.java | 6 +- .../importer/actions/OpenDatabaseAction.java | 40 +-- .../fetcher/WebSearchPaneViewModel.java | 4 +- .../gui/integrity/IntegrityCheckAction.java | 2 +- .../gui/integrity/IntegrityCheckDialog.java | 10 +- .../jabref/gui/journals/AbbreviateAction.java | 20 +- .../LibraryPropertiesAction.java | 2 +- .../LibraryPropertiesDialogView.java | 10 +- .../gui/linkedfile/AttachFileAction.java | 15 +- .../org/jabref/gui/maintable/MainTable.java | 36 +-- .../jabref/gui/maintable/RightClickMenu.java | 38 +-- .../gui/mergeentries/FetchAndMergeEntry.java | 18 +- .../gui/mergeentries/MergeEntriesAction.java | 2 +- .../MergeWithFetchedEntryAction.java | 10 +- .../gui/openoffice/OpenOfficePanel.java | 30 +-- .../PreferencesDialogViewModel.java | 2 +- .../gui/preferences/PreviewTabViewModel.java | 6 +- .../jabref/gui/search/GlobalSearchBar.java | 2 +- .../SharedDatabaseLoginDialogViewModel.java | 23 +- .../gui/shared/SharedDatabaseUIManager.java | 12 +- .../gui/specialfields/SpecialFieldAction.java | 6 +- .../org/jabref/gui/undo/UndoRedoAction.java | 16 +- .../gui/exporter/SaveDatabaseActionTest.java | 22 +- 58 files changed, 444 insertions(+), 461 deletions(-) rename src/main/java/org/jabref/gui/{BasePanel.java => LibraryTab.java} (98%) diff --git a/src/main/java/org/jabref/gui/EntryTypeView.java b/src/main/java/org/jabref/gui/EntryTypeView.java index f304238b688..83d7baa191c 100644 --- a/src/main/java/org/jabref/gui/EntryTypeView.java +++ b/src/main/java/org/jabref/gui/EntryTypeView.java @@ -23,6 +23,7 @@ import org.jabref.gui.util.IconValidationDecorator; import org.jabref.gui.util.ViewModelListCellFactory; import org.jabref.logic.importer.IdBasedFetcher; +import org.jabref.logic.importer.WebFetcher; import org.jabref.logic.l10n.Localization; import org.jabref.model.database.BibDatabaseMode; import org.jabref.model.entry.BibEntryType; @@ -60,7 +61,7 @@ public class EntryTypeView extends BaseDialog { @FXML private TitledPane customTitlePane; @FXML private TitledPane biblatexSoftwareTitlePane; - private final BasePanel basePanel; + private final LibraryTab libraryTab; private final DialogService dialogService; private final JabRefPreferences prefs; @@ -68,8 +69,8 @@ public class EntryTypeView extends BaseDialog { private EntryTypeViewModel viewModel; private final ControlsFxVisualizer visualizer = new ControlsFxVisualizer(); - public EntryTypeView(BasePanel basePanel, DialogService dialogService, JabRefPreferences preferences) { - this.basePanel = basePanel; + public EntryTypeView(LibraryTab libraryTab, DialogService dialogService, JabRefPreferences preferences) { + this.libraryTab = libraryTab; this.dialogService = dialogService; this.prefs = preferences; @@ -120,7 +121,7 @@ private void addEntriesToPane(FlowPane pane, Collection @FXML public void initialize() { visualizer.setDecoration(new IconValidationDecorator()); - viewModel = new EntryTypeViewModel(prefs, basePanel, dialogService, stateManager); + viewModel = new EntryTypeViewModel(prefs, libraryTab, dialogService, stateManager); idBasedFetchers.itemsProperty().bind(viewModel.fetcherItemsProperty()); idTextField.textProperty().bindBidirectional(viewModel.idTextProperty()); @@ -133,7 +134,7 @@ public void initialize() { } }); - new ViewModelListCellFactory().withText(item -> item.getName()).install(idBasedFetchers); + new ViewModelListCellFactory().withText(WebFetcher::getName).install(idBasedFetchers); // we set the managed property so that they will only be rendered when they are visble so that the Nodes only take the space when visible // avoids removing and adding from the scence graph @@ -143,7 +144,7 @@ public void initialize() { customTitlePane.managedProperty().bind(customTitlePane.visibleProperty()); biblatexSoftwareTitlePane.managedProperty().bind(biblatexSoftwareTitlePane.visibleProperty()); - if (basePanel.getBibDatabaseContext().isBiblatexMode()) { + if (libraryTab.getBibDatabaseContext().isBiblatexMode()) { addEntriesToPane(biblatexPane, BiblatexEntryTypeDefinitions.ALL); addEntriesToPane(biblatexSoftwarePane, BiblatexSoftwareEntryTypeDefinitions.ALL); diff --git a/src/main/java/org/jabref/gui/EntryTypeViewModel.java b/src/main/java/org/jabref/gui/EntryTypeViewModel.java index 926ad996e08..c2d055c08bb 100644 --- a/src/main/java/org/jabref/gui/EntryTypeViewModel.java +++ b/src/main/java/org/jabref/gui/EntryTypeViewModel.java @@ -46,13 +46,13 @@ public class EntryTypeViewModel { private final StringProperty idText = new SimpleStringProperty(); private final BooleanProperty focusAndSelectAllProperty = new SimpleBooleanProperty(); private Task> fetcherWorker = new FetcherWorker(); - private final BasePanel basePanel; + private final LibraryTab libraryTab; private final DialogService dialogService; private final Validator idFieldValidator; private final StateManager stateManager; - public EntryTypeViewModel(JabRefPreferences preferences, BasePanel basePanel, DialogService dialogService, StateManager stateManager) { - this.basePanel = basePanel; + public EntryTypeViewModel(JabRefPreferences preferences, LibraryTab libraryTab, DialogService dialogService, StateManager stateManager) { + this.libraryTab = libraryTab; this.prefs = preferences; this.dialogService = dialogService; this.stateManager = stateManager; @@ -147,22 +147,22 @@ public void runFetcherWorker() { Optional result = fetcherWorker.getValue(); if (result.isPresent()) { final BibEntry entry = result.get(); - ImportCleanup cleanup = new ImportCleanup(basePanel.getBibDatabaseContext().getMode()); + ImportCleanup cleanup = new ImportCleanup(libraryTab.getBibDatabaseContext().getMode()); cleanup.doPostCleanup(entry); - Optional duplicate = new DuplicateCheck(Globals.entryTypesManager).containsDuplicate(basePanel.getDatabase(), entry, basePanel.getBibDatabaseContext().getMode()); + Optional duplicate = new DuplicateCheck(Globals.entryTypesManager).containsDuplicate(libraryTab.getDatabase(), entry, libraryTab.getBibDatabaseContext().getMode()); if ((duplicate.isPresent())) { - DuplicateResolverDialog dialog = new DuplicateResolverDialog(entry, duplicate.get(), DuplicateResolverDialog.DuplicateResolverType.IMPORT_CHECK, basePanel.getBibDatabaseContext(), stateManager); + DuplicateResolverDialog dialog = new DuplicateResolverDialog(entry, duplicate.get(), DuplicateResolverDialog.DuplicateResolverType.IMPORT_CHECK, libraryTab.getBibDatabaseContext(), stateManager); switch (dialog.showAndWait().orElse(DuplicateResolverDialog.DuplicateResolverResult.BREAK)) { case KEEP_LEFT: - basePanel.getDatabase().removeEntry(duplicate.get()); - basePanel.getDatabase().insertEntry(entry); + libraryTab.getDatabase().removeEntry(duplicate.get()); + libraryTab.getDatabase().insertEntry(entry); break; case KEEP_BOTH: - basePanel.getDatabase().insertEntry(entry); + libraryTab.getDatabase().insertEntry(entry); break; case KEEP_MERGE: - basePanel.getDatabase().removeEntry(duplicate.get()); - basePanel.getDatabase().insertEntry(dialog.getMergedEntry()); + libraryTab.getDatabase().removeEntry(duplicate.get()); + libraryTab.getDatabase().insertEntry(dialog.getMergedEntry()); break; default: // Do nothing @@ -170,8 +170,8 @@ public void runFetcherWorker() { } } else { // Regenerate CiteKey of imported BibEntry - new CitationKeyGenerator(basePanel.getBibDatabaseContext(), prefs.getCitationKeyPatternPreferences()).generateAndSetKey(entry); - basePanel.insertEntry(entry); + new CitationKeyGenerator(libraryTab.getBibDatabaseContext(), prefs.getCitationKeyPatternPreferences()).generateAndSetKey(entry); + libraryTab.insertEntry(entry); } searchSuccesfulProperty.set(true); } else if (StringUtil.isBlank(idText.getValue())) { diff --git a/src/main/java/org/jabref/gui/JabRefFrame.java b/src/main/java/org/jabref/gui/JabRefFrame.java index c876a90c5c5..25f9e030e25 100644 --- a/src/main/java/org/jabref/gui/JabRefFrame.java +++ b/src/main/java/org/jabref/gui/JabRefFrame.java @@ -189,10 +189,6 @@ public JabRefFrame(Stage mainStage) { }); } - private static BasePanel getBasePanel(Tab tab) { - return (BasePanel) tab.getContent(); - } - private void initDragAndDrop() { Tab dndIndicator = new Tab(Localization.lang("Open files..."), null); dndIndicator.getStyleClass().add("drop"); @@ -233,7 +229,7 @@ private void initKeyBindings() { if (keyBinding.isPresent()) { switch (keyBinding.get()) { case FOCUS_ENTRY_TABLE: - getCurrentBasePanel().getMainTable().requestFocus(); + getCurrentLibraryTab().getMainTable().requestFocus(); event.consume(); break; case NEXT_LIBRARY: @@ -336,14 +332,14 @@ private Void showTrackingNotification() { public void refreshWindowAndTabTitles() { DefaultTaskExecutor.runInJavaFXThread(() -> { int selectedTabIndex = tabbedPane.getSelectionModel().getSelectedIndex(); + boolean isAutosaveEnabled = Globals.prefs.getBoolean(JabRefPreferences.LOCAL_AUTO_SAVE); List uniquePathParts = getUniquePathParts(); for (int i = 0; i < getBasePanelCount(); i++) { - BasePanel panel = getBasePanelAt(i); - BibDatabaseContext bibDatabaseContext = panel.getBibDatabaseContext(); + LibraryTab libraryTab = getLibraryTabAt(i); + BibDatabaseContext bibDatabaseContext = libraryTab.getBibDatabaseContext(); DatabaseLocation databaseLocation = bibDatabaseContext.getLocation(); Optional file = bibDatabaseContext.getDatabasePath(); - boolean isAutosaveEnabled = Globals.prefs.getBoolean(JabRefPreferences.LOCAL_AUTO_SAVE); StringBuilder tabTitle = new StringBuilder(); StringBuilder toolTipText = new StringBuilder(); @@ -355,7 +351,7 @@ public void refreshWindowAndTabTitles() { tabTitle.append(fileName); windowTitle.append(fileName); toolTipText.append(databasePath.toAbsolutePath().toString()); - if (panel.isModified() && !isAutosaveEnabled) { + if (libraryTab.isModified() && !isAutosaveEnabled) { tabTitle.append('*'); windowTitle.append('*'); } @@ -372,7 +368,7 @@ public void refreshWindowAndTabTitles() { addModeInfo(toolTipText, bibDatabaseContext); addModeInfo(windowTitle, bibDatabaseContext); - if (panel.isModified() && !isAutosaveEnabled) { + if (libraryTab.isModified() && !isAutosaveEnabled) { addChangedInformation(toolTipText, fileName); } @@ -474,7 +470,7 @@ private void tearDownJabRef(List filenames) { prefs.remove(JabRefPreferences.LAST_EDITED); } else { prefs.putStringList(JabRefPreferences.LAST_EDITED, filenames); - Path focusedDatabase = getCurrentBasePanel().getBibDatabaseContext().getDatabasePath().orElse(null); + Path focusedDatabase = getCurrentLibraryTab().getBibDatabaseContext().getDatabasePath().orElse(null); new LastFocusedTabPreferences(prefs).setLastFocusedTab(focusedDatabase); } } @@ -514,12 +510,12 @@ public boolean quit() { // Then ask if the user really wants to close, if the library has not been saved since last save. List filenames = new ArrayList<>(); for (int i = 0; i < tabbedPane.getTabs().size(); i++) { - BasePanel panel = getBasePanelAt(i); - final BibDatabaseContext context = panel.getBibDatabaseContext(); + LibraryTab libraryTab = getLibraryTabAt(i); + final BibDatabaseContext context = libraryTab.getBibDatabaseContext(); - if (panel.isModified() && (context.getLocation() == DatabaseLocation.LOCAL)) { + if (libraryTab.isModified() && (context.getLocation() == DatabaseLocation.LOCAL)) { tabbedPane.getSelectionModel().select(i); - if (!confirmClose(panel)) { + if (!confirmClose(libraryTab)) { return false; } } else if (context.getLocation() == DatabaseLocation.SHARED) { @@ -533,7 +529,7 @@ public boolean quit() { } WaitForSaveFinishedDialog waitForSaveFinishedDialog = new WaitForSaveFinishedDialog(dialogService); - waitForSaveFinishedDialog.showAndWait(getBasePanelList()); + waitForSaveFinishedDialog.showAndWait(getLibraryTabs()); // Good bye! tearDownJabRef(filenames); @@ -666,16 +662,16 @@ private Node createToolbar() { * * @param i Index of base */ - public BasePanel getBasePanelAt(int i) { - return (BasePanel) tabbedPane.getTabs().get(i).getContent(); + public LibraryTab getLibraryTabAt(int i) { + return (LibraryTab) tabbedPane.getTabs().get(i); } /** * Returns a list of all BasePanels in this frame. */ - public List getBasePanelList() { + public List getLibraryTabs() { return tabbedPane.getTabs().stream() - .map(tab -> (BasePanel) tab.getContent()) + .map(tab -> (LibraryTab) tab) .collect(Collectors.toList()); } @@ -683,8 +679,8 @@ public void showBasePanelAt(int i) { tabbedPane.getSelectionModel().select(i); } - public void showBasePanel(BasePanel bp) { - tabbedPane.getSelectionModel().select(getTab(bp)); + public void showLibraryTab(LibraryTab libraryTab) { + tabbedPane.getSelectionModel().select(libraryTab); } public void init() { @@ -708,13 +704,15 @@ public void init() { // Bind global state stateManager.activeDatabaseProperty().bind( EasyBind.map(tabbedPane.getSelectionModel().selectedItemProperty(), - tab -> Optional.ofNullable(tab).map(JabRefFrame::getBasePanel).map(BasePanel::getBibDatabaseContext))); + selectedTab -> Optional.ofNullable(selectedTab) + .map(tab -> (LibraryTab) tab) + .map(LibraryTab::getBibDatabaseContext))); // Subscribe to the search EasyBind.subscribe(stateManager.activeSearchQueryProperty(), query -> { - if (getCurrentBasePanel() != null) { - getCurrentBasePanel().setCurrentSearchQuery(query); + if (getCurrentLibraryTab() != null) { + getCurrentLibraryTab().setCurrentSearchQuery(query); } }); @@ -732,30 +730,29 @@ public void init() { return; } - BasePanel newBasePanel = getBasePanel(tab); - if (newBasePanel != null) { - // Poor-mans binding to global state - stateManager.setSelectedEntries(newBasePanel.getSelectedEntries()); + LibraryTab newLibraryTab = (LibraryTab) tab; - // Update active search query when switching between databases - stateManager.activeSearchQueryProperty().set(newBasePanel.getCurrentSearchQuery()); + // Poor-mans binding to global state + stateManager.setSelectedEntries(newLibraryTab.getSelectedEntries()); - // groupSidePane.getToggleCommand().setSelected(sidePaneManager.isComponentVisible(GroupSidePane.class)); - // previewToggle.setSelected(Globals.prefs.getPreviewPreferences().isPreviewPanelEnabled()); - // generalFetcher.getToggleCommand().setSelected(sidePaneManager.isComponentVisible(WebSearchPane.class)); - // openOfficePanel.getToggleCommand().setSelected(sidePaneManager.isComponentVisible(OpenOfficeSidePanel.class)); + // Update active search query when switching between databases + stateManager.activeSearchQueryProperty().set(newLibraryTab.getCurrentSearchQuery()); - // We need to refresh the window title only - // There is currently no optimized method to set the title only (because that lead to code duplication) - // Thus, we refresh everything - refreshWindowAndTabTitles(); + // groupSidePane.getToggleCommand().setSelected(sidePaneManager.isComponentVisible(GroupSidePane.class)); + // previewToggle.setSelected(Globals.prefs.getPreviewPreferences().isPreviewPanelEnabled()); + // generalFetcher.getToggleCommand().setSelected(sidePaneManager.isComponentVisible(WebSearchPane.class)); + // openOfficePanel.getToggleCommand().setSelected(sidePaneManager.isComponentVisible(OpenOfficeSidePanel.class)); - // Update search autocompleter with information for the correct database: - newBasePanel.updateSearchManager(); + // We need to refresh the window title only + // There is currently no optimized method to set the title only (because that lead to code duplication) + // Thus, we refresh everything + refreshWindowAndTabTitles(); - newBasePanel.getUndoManager().postUndoRedoEvent(); - newBasePanel.getMainTable().requestFocus(); - } + // Update search autocompleter with information for the correct database: + newLibraryTab.updateSearchManager(); + + newLibraryTab.getUndoManager().postUndoRedoEvent(); + newLibraryTab.getMainTable().requestFocus(); }); initShowTrackingNotification(); } @@ -763,11 +760,11 @@ public void init() { /** * Returns the currently viewed BasePanel. */ - public BasePanel getCurrentBasePanel() { + public LibraryTab getCurrentLibraryTab() { if ((tabbedPane == null) || (tabbedPane.getSelectionModel().getSelectedItem() == null)) { return null; } - return getBasePanel(tabbedPane.getSelectionModel().getSelectedItem()); + return (LibraryTab) tabbedPane.getSelectionModel().getSelectedItem(); } /** @@ -777,15 +774,6 @@ public int getBasePanelCount() { return tabbedPane.getTabs().size(); } - private Tab getTab(BasePanel comp) { - for (Tab tab : tabbedPane.getTabs()) { - if (tab.getContent() == comp) { - return tab; - } - } - return null; - } - /** * @deprecated do not operate on tabs but on BibDatabaseContexts */ @@ -1100,21 +1088,23 @@ hide it and clip it to a square of (width x width) each time width is updated. public void addParserResult(ParserResult parserResult, boolean focusPanel) { if (parserResult.toOpenTab()) { // Add the entries to the open tab. - BasePanel panel = getCurrentBasePanel(); - if (panel == null) { + LibraryTab libraryTab = getCurrentLibraryTab(); + if (libraryTab == null) { // There is no open tab to add to, so we create a new tab: addTab(parserResult.getDatabaseContext(), focusPanel); } else { - addImportedEntries(panel, parserResult); + addImportedEntries(libraryTab, parserResult); } } else { // only add tab if DB is not already open - Optional panel = getBasePanelList().stream() - .filter(p -> p.getBibDatabaseContext().getDatabasePath().equals(parserResult.getPath())) - .findFirst(); - - if (panel.isPresent()) { - tabbedPane.getSelectionModel().select(getTab(panel.get())); + Optional libraryTab = getLibraryTabs().stream() + .filter(p -> p.getBibDatabaseContext() + .getDatabasePath() + .equals(parserResult.getPath())) + .findFirst(); + + if (libraryTab.isPresent()) { + tabbedPane.getSelectionModel().select(libraryTab.get()); } else { addTab(parserResult.getDatabaseContext(), focusPanel); } @@ -1122,33 +1112,26 @@ public void addParserResult(ParserResult parserResult, boolean focusPanel) { } /** - * This method causes all open BasePanels to set up their tables anew. When called from PrefsDialog3, this updates - * to the new settings. - */ + * This method causes all open LibraryTabs to set up their tables anew. When called from PreferencesDialogViewModel, + * this updates to the new settings. + * We need to notify all tabs about the changes to avoid problems when changing the column set. + * */ public void setupAllTables() { - // This action can be invoked without an open database, so - // we have to check if we have one before trying to invoke - // methods to execute changes in the preferences. - - // We want to notify all tabs about the changes to - // avoid problems when changing the column set. - for (int i = 0; i < tabbedPane.getTabs().size(); i++) { - BasePanel bf = getBasePanelAt(i); - - // Update tables: - if (bf.getDatabase() != null) { - DefaultTaskExecutor.runInJavaFXThread(bf::setupMainPanel); + tabbedPane.getTabs().forEach(tab -> { + LibraryTab libraryTab = (LibraryTab) tab; + if (libraryTab.getDatabase() != null) { + DefaultTaskExecutor.runInJavaFXThread(libraryTab::setupMainPanel); } - } + }); } private List collectDatabaseFilePaths() { List dbPaths = new ArrayList<>(getBasePanelCount()); - for (BasePanel basePanel : getBasePanelList()) { + for (LibraryTab libraryTab : getLibraryTabs()) { // db file exists - if (basePanel.getBibDatabaseContext().getDatabasePath().isPresent()) { - dbPaths.add(basePanel.getBibDatabaseContext().getDatabasePath().get().toAbsolutePath().toString()); + if (libraryTab.getBibDatabaseContext().getDatabasePath().isPresent()) { + dbPaths.add(libraryTab.getBibDatabaseContext().getDatabasePath().get().toAbsolutePath().toString()); } else { dbPaths.add(""); } @@ -1177,49 +1160,50 @@ private ContextMenu createTabContextMenu(KeyBindingRepository keyBindingReposito return contextMenu; } - public void addTab(BasePanel basePanel, boolean raisePanel) { + public void addTab(LibraryTab libraryTab, boolean raisePanel) { // "" is passed as title, because it is updated below at "refreshWindowAndTabTitles()" - Tab newTab = new Tab("", basePanel); - tabbedPane.getTabs().add(newTab); - newTab.setOnCloseRequest(event -> { - closeTab((BasePanel) newTab.getContent()); + + tabbedPane.getTabs().add(libraryTab); + + libraryTab.setOnCloseRequest(event -> { + closeTab(libraryTab); event.consume(); }); - newTab.setContextMenu(createTabContextMenu(Globals.getKeyPrefs())); + libraryTab.setContextMenu(createTabContextMenu(Globals.getKeyPrefs())); refreshWindowAndTabTitles(); if (raisePanel) { - tabbedPane.getSelectionModel().select(newTab); + tabbedPane.getSelectionModel().select(libraryTab); } - basePanel.getUndoManager().registerListener(new UndoRedoEventManager()); + libraryTab.getUndoManager().registerListener(new UndoRedoEventManager()); - BibDatabaseContext context = basePanel.getBibDatabaseContext(); + BibDatabaseContext context = libraryTab.getBibDatabaseContext(); if (readyForAutosave(context)) { AutosaveManager autosaver = AutosaveManager.start(context); - autosaver.registerListener(new AutosaveUiManager(basePanel)); + autosaver.registerListener(new AutosaveUiManager(libraryTab)); } BackupManager.start(context, Globals.entryTypesManager, prefs); - trackOpenNewDatabase(basePanel); + trackOpenNewDatabase(libraryTab); } - private void trackOpenNewDatabase(BasePanel basePanel) { + private void trackOpenNewDatabase(LibraryTab libraryTab) { Map properties = new HashMap<>(); Map measurements = new HashMap<>(); - measurements.put("NumberOfEntries", (double) basePanel.getBibDatabaseContext().getDatabase().getEntryCount()); + measurements.put("NumberOfEntries", (double) libraryTab.getBibDatabaseContext().getDatabase().getEntryCount()); Globals.getTelemetryClient().ifPresent(client -> client.trackEvent("OpenNewDatabase", properties, measurements)); } - public BasePanel addTab(BibDatabaseContext databaseContext, boolean raisePanel) { + public LibraryTab addTab(BibDatabaseContext databaseContext, boolean raisePanel) { Objects.requireNonNull(databaseContext); - BasePanel bp = new BasePanel(this, BasePanelPreferences.from(Globals.prefs), databaseContext, ExternalFileTypes.getInstance()); + LibraryTab bp = new LibraryTab(this, BasePanelPreferences.from(Globals.prefs), databaseContext, ExternalFileTypes.getInstance()); addTab(bp, raisePanel); return bp; } @@ -1237,7 +1221,7 @@ private boolean readyForAutosave(BibDatabaseContext context) { * @param panel The BasePanel to add to. * @param parserResult The entries to add. */ - private void addImportedEntries(final BasePanel panel, final ParserResult parserResult) { + private void addImportedEntries(final LibraryTab panel, final ParserResult parserResult) { BackgroundTask task = BackgroundTask.wrap(() -> parserResult); ImportCleanup cleanup = new ImportCleanup(panel.getBibDatabaseContext().getMode()); cleanup.doPostCleanup(parserResult.getDatabase().getEntries()); @@ -1255,12 +1239,12 @@ public FileHistoryMenu getFileHistory() { * * @return true if the user choose to close the database */ - private boolean confirmClose(BasePanel panel) { - String filename = panel.getBibDatabaseContext() - .getDatabasePath() - .map(Path::toAbsolutePath) - .map(Path::toString) - .orElse(Localization.lang("untitled")); + private boolean confirmClose(LibraryTab libraryTab) { + String filename = libraryTab.getBibDatabaseContext() + .getDatabasePath() + .map(Path::toAbsolutePath) + .map(Path::toString) + .orElse(Localization.lang("untitled")); ButtonType saveChanges = new ButtonType(Localization.lang("Save changes"), ButtonBar.ButtonData.YES); ButtonType discardChanges = new ButtonType(Localization.lang("Discard changes"), ButtonBar.ButtonData.NO); @@ -1274,7 +1258,7 @@ private boolean confirmClose(BasePanel panel) { if (response.isPresent() && response.get().equals(saveChanges)) { // The user wants to save. try { - SaveDatabaseAction saveAction = new SaveDatabaseAction(panel, Globals.prefs, Globals.entryTypesManager); + SaveDatabaseAction saveAction = new SaveDatabaseAction(libraryTab, Globals.prefs, Globals.entryTypesManager); if (saveAction.save()) { return true; } @@ -1290,17 +1274,17 @@ private boolean confirmClose(BasePanel panel) { return response.isEmpty() || !response.get().equals(cancel); } - private void closeTab(BasePanel panel) { + private void closeTab(LibraryTab libraryTab) { // empty tab without database - if (panel == null) { + if (libraryTab == null) { return; } - final BibDatabaseContext context = panel.getBibDatabaseContext(); + final BibDatabaseContext context = libraryTab.getBibDatabaseContext(); - if (panel.isModified() && (context.getLocation() == DatabaseLocation.LOCAL)) { - if (confirmClose(panel)) { - removeTab(panel); + if (libraryTab.isModified() && (context.getLocation() == DatabaseLocation.LOCAL)) { + if (confirmClose(libraryTab)) { + removeTab(libraryTab); } else { return; } @@ -1308,24 +1292,24 @@ private void closeTab(BasePanel panel) { context.convertToLocalDatabase(); context.getDBMSSynchronizer().closeSharedDatabase(); context.clearDBMSSynchronizer(); - removeTab(panel); + removeTab(libraryTab); } else { - removeTab(panel); + removeTab(libraryTab); } AutosaveManager.shutdown(context); BackupManager.shutdown(context); } - private void removeTab(BasePanel panel) { + private void removeTab(LibraryTab libraryTab) { DefaultTaskExecutor.runInJavaFXThread(() -> { - panel.cleanUp(); - tabbedPane.getTabs().remove(getTab(panel)); + libraryTab.cleanUp(); + tabbedPane.getTabs().remove(libraryTab); this.refreshWindowAndTabTitles(); }); } public void closeCurrentTab() { - removeTab(getCurrentBasePanel()); + removeTab(getCurrentLibraryTab()); } public OpenDatabaseAction getOpenDatabaseAction() { @@ -1367,7 +1351,7 @@ private class CloseDatabaseAction extends SimpleCommand { @Override public void execute() { - closeTab(getCurrentBasePanel()); + closeTab(getCurrentLibraryTab()); } } @@ -1379,11 +1363,11 @@ public CloseOthersDatabaseAction() { @Override public void execute() { - BasePanel currentBasePanel = getCurrentBasePanel(); + LibraryTab currentLibraryTab = getCurrentLibraryTab(); for (Tab tab : tabbedPane.getTabs()) { - BasePanel basePanel = getBasePanel(tab); - if (basePanel != currentBasePanel) { - closeTab(basePanel); + LibraryTab libraryTab = (LibraryTab) tab; + if (libraryTab != currentLibraryTab) { + closeTab(libraryTab); } } } @@ -1394,8 +1378,7 @@ private class CloseAllDatabaseAction extends SimpleCommand { @Override public void execute() { for (Tab tab : tabbedPane.getTabs()) { - BasePanel basePanel = getBasePanel(tab); - closeTab(basePanel); + closeTab((LibraryTab) tab); } } } @@ -1419,7 +1402,7 @@ private class UndoRedoEventManager { @Subscribe public void listen(UndoRedoEvent event) { updateTexts(event); - JabRefFrame.this.getCurrentBasePanel().updateEntryEditorIfShowing(); + JabRefFrame.this.getCurrentLibraryTab().updateEntryEditorIfShowing(); } @Subscribe diff --git a/src/main/java/org/jabref/gui/JabRefGUI.java b/src/main/java/org/jabref/gui/JabRefGUI.java index c107fd46004..f9c9d646282 100644 --- a/src/main/java/org/jabref/gui/JabRefGUI.java +++ b/src/main/java/org/jabref/gui/JabRefGUI.java @@ -195,9 +195,9 @@ private void openDatabases() { for (int i = 0; (i < bibDatabases.size()) && (i < mainFrame.getBasePanelCount()); i++) { ParserResult pr = bibDatabases.get(i); - BasePanel panel = mainFrame.getBasePanelAt(i); + LibraryTab libraryTab = mainFrame.getLibraryTabAt(i); - OpenDatabaseAction.performPostOpenActions(panel, pr); + OpenDatabaseAction.performPostOpenActions(libraryTab, pr); } LOGGER.debug("Finished adding panels"); @@ -215,17 +215,17 @@ private void saveWindowState(Stage mainStage) { /** * outprints the Data from the Screen (only in debug mode) * - * @param mainStage + * @param mainStage JabRefs stage */ private void debugLogWindowState(Stage mainStage) { if (LOGGER.isDebugEnabled()) { StringBuilder debugLogString = new StringBuilder(); debugLogString.append("SCREEN DATA:"); - debugLogString.append("mainStage.WINDOW_MAXIMISED: " + mainStage.isMaximized() + "\n"); - debugLogString.append("mainStage.POS_X: " + mainStage.getX() + "\n"); - debugLogString.append("mainStage.POS_Y: " + mainStage.getY() + "\n"); - debugLogString.append("mainStage.SIZE_X: " + mainStage.getWidth() + "\n"); - debugLogString.append("mainStages.SIZE_Y: " + mainStage.getHeight() + "\n"); + debugLogString.append("mainStage.WINDOW_MAXIMISED: ").append(mainStage.isMaximized()).append("\n"); + debugLogString.append("mainStage.POS_X: ").append(mainStage.getX()).append("\n"); + debugLogString.append("mainStage.POS_Y: ").append(mainStage.getY()).append("\n"); + debugLogString.append("mainStage.SIZE_X: ").append(mainStage.getWidth()).append("\n"); + debugLogString.append("mainStages.SIZE_Y: ").append(mainStage.getHeight()).append("\n"); LOGGER.debug(debugLogString.toString()); } } diff --git a/src/main/java/org/jabref/gui/BasePanel.java b/src/main/java/org/jabref/gui/LibraryTab.java similarity index 98% rename from src/main/java/org/jabref/gui/BasePanel.java rename to src/main/java/org/jabref/gui/LibraryTab.java index cc77cc61d79..94a0dca7ee7 100644 --- a/src/main/java/org/jabref/gui/BasePanel.java +++ b/src/main/java/org/jabref/gui/LibraryTab.java @@ -10,7 +10,7 @@ import javafx.geometry.Orientation; import javafx.scene.Node; import javafx.scene.control.SplitPane; -import javafx.scene.layout.StackPane; +import javafx.scene.control.Tab; import org.jabref.gui.autocompleter.AutoCompletePreferences; import org.jabref.gui.autocompleter.PersonNameSuggestionProvider; @@ -52,9 +52,9 @@ import org.slf4j.Logger; import org.slf4j.LoggerFactory; -public class BasePanel extends StackPane { +public class LibraryTab extends Tab { - private static final Logger LOGGER = LoggerFactory.getLogger(BasePanel.class); + private static final Logger LOGGER = LoggerFactory.getLogger(LibraryTab.class); private final BibDatabaseContext bibDatabaseContext; private final MainTableDataModel tableModel; @@ -82,12 +82,12 @@ public class BasePanel extends StackPane { // Used to track whether the base has changed since last save. private BibEntry showing; private SuggestionProviders suggestionProviders; - @SuppressWarnings({"FieldCanBeLocal", "unused"}) private Subscription dividerPositionSubscription; + @SuppressWarnings({"FieldCanBeLocal"}) private Subscription dividerPositionSubscription; // the query the user searches when this BasePanel is active private Optional currentSearchQuery = Optional.empty(); private Optional changeMonitor = Optional.empty(); - public BasePanel(JabRefFrame frame, BasePanelPreferences preferences, BibDatabaseContext bibDatabaseContext, ExternalFileTypes externalFileTypes) { + public LibraryTab(JabRefFrame frame, BasePanelPreferences preferences, BibDatabaseContext bibDatabaseContext, ExternalFileTypes externalFileTypes) { this.preferences = Objects.requireNonNull(preferences); this.frame = Objects.requireNonNull(frame); this.bibDatabaseContext = Objects.requireNonNull(bibDatabaseContext); @@ -296,7 +296,7 @@ public void setupMainPanel() { this.baseChanged = true; } changePane = null; - getChildren().add(splitPane); + this.setContent(splitPane); } } @@ -565,7 +565,7 @@ public void resetChangeMonitorAndChangePane() { changePane = new DatabaseChangePane(splitPane, bibDatabaseContext, changeMonitor.get()); - this.getChildren().setAll(changePane); + this.setContent(changePane); } public void copy() { diff --git a/src/main/java/org/jabref/gui/WaitForSaveFinishedDialog.java b/src/main/java/org/jabref/gui/WaitForSaveFinishedDialog.java index 954d3fe47b0..43f784669de 100644 --- a/src/main/java/org/jabref/gui/WaitForSaveFinishedDialog.java +++ b/src/main/java/org/jabref/gui/WaitForSaveFinishedDialog.java @@ -17,12 +17,12 @@ public WaitForSaveFinishedDialog(DialogService dialogService) { this.dialogService = dialogService; } - public void showAndWait(List basePanels) { - if (basePanels.stream().anyMatch(BasePanel::isSaving)) { - Task waitForSaveFinished = new Task() { + public void showAndWait(List LibraryTabs) { + if (LibraryTabs.stream().anyMatch(LibraryTab::isSaving)) { + Task waitForSaveFinished = new Task<>() { @Override protected Void call() throws Exception { - while (basePanels.stream().anyMatch(BasePanel::isSaving)) { + while (LibraryTabs.stream().anyMatch(LibraryTab::isSaving)) { if (isCancelled()) { return null; } else { diff --git a/src/main/java/org/jabref/gui/auximport/FromAuxDialog.java b/src/main/java/org/jabref/gui/auximport/FromAuxDialog.java index 518b09efc2b..5626bc8b60e 100644 --- a/src/main/java/org/jabref/gui/auximport/FromAuxDialog.java +++ b/src/main/java/org/jabref/gui/auximport/FromAuxDialog.java @@ -11,9 +11,9 @@ import javafx.scene.control.TextArea; import javafx.scene.control.TextField; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; import org.jabref.gui.JabRefFrame; +import org.jabref.gui.LibraryTab; import org.jabref.gui.util.BaseDialog; import org.jabref.gui.util.FileDialogConfiguration; import org.jabref.logic.auxparser.AuxParser; @@ -32,7 +32,7 @@ */ public class FromAuxDialog extends BaseDialog { - private final BasePanel basePanel; + private final LibraryTab libraryTab; @FXML private ButtonType generateButtonType; private final Button generateButton; @FXML private TextField auxFileField; @@ -44,7 +44,7 @@ public class FromAuxDialog extends BaseDialog { @Inject private DialogService dialogService; public FromAuxDialog(JabRefFrame frame) { - basePanel = frame.getCurrentBasePanel(); + libraryTab = frame.getCurrentLibraryTab(); this.setTitle(Localization.lang("AUX file import")); ViewLoader.view(this) @@ -67,7 +67,7 @@ public FromAuxDialog(JabRefFrame frame) { private void parseActionPerformed() { notFoundList.getItems().clear(); statusInfos.setText(""); - BibDatabase refBase = basePanel.getDatabase(); + BibDatabase refBase = libraryTab.getDatabase(); String auxName = auxFileField.getText(); if ((auxName != null) && (refBase != null) && !auxName.isEmpty()) { diff --git a/src/main/java/org/jabref/gui/citationkeypattern/CitationKeyPatternAction.java b/src/main/java/org/jabref/gui/citationkeypattern/CitationKeyPatternAction.java index 74f20a3b7b4..983e9103e00 100644 --- a/src/main/java/org/jabref/gui/citationkeypattern/CitationKeyPatternAction.java +++ b/src/main/java/org/jabref/gui/citationkeypattern/CitationKeyPatternAction.java @@ -18,6 +18,6 @@ public CitationKeyPatternAction(JabRefFrame frame, StateManager stateManager) { @Override public void execute() { - new CitationKeyPatternDialog(frame.getCurrentBasePanel()).showAndWait(); + new CitationKeyPatternDialog(frame.getCurrentLibraryTab()).showAndWait(); } } diff --git a/src/main/java/org/jabref/gui/citationkeypattern/CitationKeyPatternDialog.java b/src/main/java/org/jabref/gui/citationkeypattern/CitationKeyPatternDialog.java index 4b33b9de97b..d92f35c7b35 100644 --- a/src/main/java/org/jabref/gui/citationkeypattern/CitationKeyPatternDialog.java +++ b/src/main/java/org/jabref/gui/citationkeypattern/CitationKeyPatternDialog.java @@ -2,8 +2,8 @@ import javafx.scene.control.ButtonType; -import org.jabref.gui.BasePanel; import org.jabref.gui.Globals; +import org.jabref.gui.LibraryTab; import org.jabref.gui.util.BaseDialog; import org.jabref.logic.citationkeypattern.AbstractCitationKeyPattern; import org.jabref.logic.l10n.Localization; @@ -12,13 +12,13 @@ public class CitationKeyPatternDialog extends BaseDialog { private final MetaData metaData; - private final BasePanel panel; + private final LibraryTab libraryTab; private final CitationKeyPatternPanel citationKeyPatternPanel; - public CitationKeyPatternDialog(BasePanel panel) { - this.citationKeyPatternPanel = new CitationKeyPatternPanel(panel); - this.panel = panel; - this.metaData = panel.getBibDatabaseContext().getMetaData(); + public CitationKeyPatternDialog(LibraryTab libraryTab) { + this.citationKeyPatternPanel = new CitationKeyPatternPanel(libraryTab.getBibDatabaseContext()); + this.libraryTab = libraryTab; + this.metaData = libraryTab.getBibDatabaseContext().getMetaData(); AbstractCitationKeyPattern keyPattern = metaData.getCiteKeyPattern(Globals.prefs.getGlobalCitationKeyPattern()); citationKeyPatternPanel.setValues(keyPattern); init(); @@ -34,7 +34,7 @@ private void init() { this.setResultConverter(button -> { if (button == ButtonType.APPLY) { metaData.setCiteKeyPattern(citationKeyPatternPanel.getKeyPatternAsDatabaseKeyPattern()); - panel.markNonUndoableBaseChanged(); + libraryTab.markNonUndoableBaseChanged(); } return null; diff --git a/src/main/java/org/jabref/gui/citationkeypattern/CitationKeyPatternPanel.java b/src/main/java/org/jabref/gui/citationkeypattern/CitationKeyPatternPanel.java index 56f98b88e26..9f1115d8c52 100644 --- a/src/main/java/org/jabref/gui/citationkeypattern/CitationKeyPatternPanel.java +++ b/src/main/java/org/jabref/gui/citationkeypattern/CitationKeyPatternPanel.java @@ -10,7 +10,6 @@ import javafx.scene.layout.GridPane; import javafx.scene.layout.Pane; -import org.jabref.gui.BasePanel; import org.jabref.gui.Globals; import org.jabref.gui.actions.ActionFactory; import org.jabref.gui.actions.StandardActions; @@ -19,6 +18,7 @@ import org.jabref.logic.citationkeypattern.DatabaseCitationKeyPattern; import org.jabref.logic.help.HelpFile; import org.jabref.logic.l10n.Localization; +import org.jabref.model.database.BibDatabaseContext; import org.jabref.model.database.BibDatabaseMode; import org.jabref.model.entry.BibEntryType; import org.jabref.model.entry.types.EntryType; @@ -31,11 +31,11 @@ public class CitationKeyPatternPanel extends Pane { // one field for each type private final Map textFields = new HashMap<>(); - private final BasePanel panel; + private final BibDatabaseContext databaseContext; private final GridPane gridPane = new GridPane(); - public CitationKeyPatternPanel(BasePanel panel) { - this.panel = panel; + public CitationKeyPatternPanel(BibDatabaseContext databaseContext) { + this.databaseContext = databaseContext; gridPane.setHgap(10); gridPane.setVgap(5); buildGUI(); @@ -50,7 +50,12 @@ private static void setValue(TextField tf, EntryType fieldName, AbstractCitation } private void buildGUI() { - BibDatabaseMode mode; + BibDatabaseMode mode = databaseContext.getMode(); + + // The following got irrelevant - global settings for CitationKeyPattern are handled by + // commonfxcontrols/CitationKeyPatternPanel.java + // ToDo: this one should be abandoned + /* // check mode of currently used DB if (panel != null) { mode = panel.getBibDatabaseContext().getMode(); @@ -58,6 +63,7 @@ private void buildGUI() { // use preferences value if no DB is open mode = Globals.prefs.getDefaultBibDatabaseMode(); } + */ int rowIndex = 1; int columnIndex = 0; diff --git a/src/main/java/org/jabref/gui/citationkeypattern/GenerateCitationKeyAction.java b/src/main/java/org/jabref/gui/citationkeypattern/GenerateCitationKeyAction.java index 4173db5cc65..0cf54e3ada9 100644 --- a/src/main/java/org/jabref/gui/citationkeypattern/GenerateCitationKeyAction.java +++ b/src/main/java/org/jabref/gui/citationkeypattern/GenerateCitationKeyAction.java @@ -101,7 +101,7 @@ private void generateKeys() { frame.getUndoManager().addEdit(compound); } - frame.getCurrentBasePanel().markBaseChanged(); + frame.getCurrentLibraryTab().markBaseChanged(); dialogService.notify(formatOutputMessage(Localization.lang("Generated citation key for"), entries.size())); }); } diff --git a/src/main/java/org/jabref/gui/cleanup/CleanupAction.java b/src/main/java/org/jabref/gui/cleanup/CleanupAction.java index 1fa40af1f84..50e7e703c0f 100644 --- a/src/main/java/org/jabref/gui/cleanup/CleanupAction.java +++ b/src/main/java/org/jabref/gui/cleanup/CleanupAction.java @@ -108,8 +108,8 @@ private void showResults() { } if (modifiedEntriesCount > 0) { - frame.getCurrentBasePanel().updateEntryEditorIfShowing(); - frame.getCurrentBasePanel().markBaseChanged(); + frame.getCurrentLibraryTab().updateEntryEditorIfShowing(); + frame.getCurrentLibraryTab().markBaseChanged(); } if (modifiedEntriesCount == 0) { diff --git a/src/main/java/org/jabref/gui/contentselector/ContentSelectorDialogView.java b/src/main/java/org/jabref/gui/contentselector/ContentSelectorDialogView.java index 766258c0b60..62832cb51ad 100644 --- a/src/main/java/org/jabref/gui/contentselector/ContentSelectorDialogView.java +++ b/src/main/java/org/jabref/gui/contentselector/ContentSelectorDialogView.java @@ -12,8 +12,8 @@ import javafx.scene.control.ListView; import javafx.scene.control.SelectionModel; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; +import org.jabref.gui.LibraryTab; import org.jabref.gui.util.BaseDialog; import org.jabref.gui.util.ControlHelper; import org.jabref.logic.l10n.Localization; @@ -41,14 +41,14 @@ public class ContentSelectorDialogView extends BaseDialog { @Inject private DialogService dialogService; - private final BasePanel basePanel; + private final LibraryTab libraryTab; private ContentSelectorDialogViewModel viewModel; - public ContentSelectorDialogView(BasePanel basePanel) { + public ContentSelectorDialogView(LibraryTab libraryTab) { this.setTitle(Localization.lang("Manage content selectors")); this.getDialogPane().setPrefSize(375, 475); - this.basePanel = basePanel; + this.libraryTab = libraryTab; ViewLoader.view(this) .load() @@ -59,7 +59,7 @@ public ContentSelectorDialogView(BasePanel basePanel) { @FXML public void initialize() { - viewModel = new ContentSelectorDialogViewModel(basePanel, dialogService); + viewModel = new ContentSelectorDialogViewModel(libraryTab, dialogService); initFieldNameComponents(); initKeywordsComponents(); diff --git a/src/main/java/org/jabref/gui/contentselector/ContentSelectorDialogViewModel.java b/src/main/java/org/jabref/gui/contentselector/ContentSelectorDialogViewModel.java index 7d10d5841e2..d83a4de4469 100644 --- a/src/main/java/org/jabref/gui/contentselector/ContentSelectorDialogViewModel.java +++ b/src/main/java/org/jabref/gui/contentselector/ContentSelectorDialogViewModel.java @@ -20,8 +20,8 @@ import javafx.collections.FXCollections; import org.jabref.gui.AbstractViewModel; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; +import org.jabref.gui.LibraryTab; import org.jabref.logic.l10n.Localization; import org.jabref.model.entry.field.Field; import org.jabref.model.entry.field.FieldFactory; @@ -33,7 +33,7 @@ class ContentSelectorDialogViewModel extends AbstractViewModel { private static final List DEFAULT_FIELD_NAMES = Arrays.asList(StandardField.AUTHOR, StandardField.JOURNAL, StandardField.KEYWORDS, StandardField.PUBLISHER); - private final BasePanel basePanel; + private final LibraryTab libraryTab; private final MetaData metaData; private final DialogService dialogService; private final Map> fieldKeywordsMap = new HashMap<>(); @@ -43,9 +43,9 @@ class ContentSelectorDialogViewModel extends AbstractViewModel { private ObjectProperty selectedField = new SimpleObjectProperty<>(); private StringProperty selectedKeyword = new SimpleStringProperty(); - ContentSelectorDialogViewModel(BasePanel basePanel, DialogService dialogService) { - this.basePanel = basePanel; - this.metaData = basePanel.getBibDatabaseContext().getMetaData(); + ContentSelectorDialogViewModel(LibraryTab libraryTab, DialogService dialogService) { + this.libraryTab = libraryTab; + this.metaData = libraryTab.getBibDatabaseContext().getMetaData(); this.dialogService = dialogService; populateFieldNameKeywordsMapWithExistingValues(); populateFieldNamesListWithValues(); @@ -177,8 +177,8 @@ void saveChanges() { List fieldNamesToRemove = filterFieldsToRemove(); fieldNamesToRemove.forEach(metaData::clearContentSelectors); - basePanel.setupMainPanel(); - basePanel.markNonUndoableBaseChanged(); + libraryTab.setupMainPanel(); + libraryTab.markNonUndoableBaseChanged(); } private List filterFieldsToRemove() { diff --git a/src/main/java/org/jabref/gui/contentselector/ManageContentSelectorAction.java b/src/main/java/org/jabref/gui/contentselector/ManageContentSelectorAction.java index 555afe1dc20..e91c22b6e19 100644 --- a/src/main/java/org/jabref/gui/contentselector/ManageContentSelectorAction.java +++ b/src/main/java/org/jabref/gui/contentselector/ManageContentSelectorAction.java @@ -1,7 +1,7 @@ package org.jabref.gui.contentselector; -import org.jabref.gui.BasePanel; import org.jabref.gui.JabRefFrame; +import org.jabref.gui.LibraryTab; import org.jabref.gui.StateManager; import org.jabref.gui.actions.SimpleCommand; @@ -19,7 +19,7 @@ public ManageContentSelectorAction(JabRefFrame jabRefFrame, StateManager stateMa @Override public void execute() { - BasePanel basePanel = jabRefFrame.getCurrentBasePanel(); - new ContentSelectorDialogView(basePanel).showAndWait(); + LibraryTab libraryTab = jabRefFrame.getCurrentLibraryTab(); + new ContentSelectorDialogView(libraryTab).showAndWait(); } } diff --git a/src/main/java/org/jabref/gui/dialogs/AutosaveUiManager.java b/src/main/java/org/jabref/gui/dialogs/AutosaveUiManager.java index 660995a0795..7aee99be695 100644 --- a/src/main/java/org/jabref/gui/dialogs/AutosaveUiManager.java +++ b/src/main/java/org/jabref/gui/dialogs/AutosaveUiManager.java @@ -1,7 +1,7 @@ package org.jabref.gui.dialogs; -import org.jabref.gui.BasePanel; import org.jabref.gui.Globals; +import org.jabref.gui.LibraryTab; import org.jabref.gui.exporter.SaveDatabaseAction; import org.jabref.model.database.event.AutosaveEvent; @@ -11,21 +11,21 @@ /** * This class has an abstract UI role as it listens for an {@link AutosaveEvent} and saves the bib file associated with - * the given {@link BasePanel}. + * the given {@link LibraryTab}. */ public class AutosaveUiManager { private static final Logger LOGGER = LoggerFactory.getLogger(AutosaveUiManager.class); - private final BasePanel panel; + private final LibraryTab libraryTab; - public AutosaveUiManager(BasePanel panel) { - this.panel = panel; + public AutosaveUiManager(LibraryTab libraryTab) { + this.libraryTab = libraryTab; } @Subscribe - public void listen(@SuppressWarnings("unused") AutosaveEvent event) { + public void listen(AutosaveEvent event) { try { - new SaveDatabaseAction(panel, Globals.prefs, Globals.entryTypesManager).save(SaveDatabaseAction.SaveDatabaseMode.SILENT); + new SaveDatabaseAction(libraryTab, Globals.prefs, Globals.entryTypesManager).save(SaveDatabaseAction.SaveDatabaseMode.SILENT); } catch (Throwable e) { LOGGER.error("Problem occurred while saving.", e); } diff --git a/src/main/java/org/jabref/gui/duplicationFinder/DuplicateSearch.java b/src/main/java/org/jabref/gui/duplicationFinder/DuplicateSearch.java index b0bdb122ea1..230c3165e4d 100644 --- a/src/main/java/org/jabref/gui/duplicationFinder/DuplicateSearch.java +++ b/src/main/java/org/jabref/gui/duplicationFinder/DuplicateSearch.java @@ -11,11 +11,11 @@ import java.util.concurrent.atomic.AtomicBoolean; import java.util.concurrent.atomic.AtomicInteger; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; import org.jabref.gui.Globals; import org.jabref.gui.JabRefExecutorService; import org.jabref.gui.JabRefFrame; +import org.jabref.gui.LibraryTab; import org.jabref.gui.StateManager; import org.jabref.gui.actions.SimpleCommand; import org.jabref.gui.duplicationFinder.DuplicateResolverDialog.DuplicateResolverResult; @@ -131,7 +131,7 @@ private DuplicateSearchResult verifyDuplicates() { } private void askResolveStrategy(DuplicateSearchResult result, BibEntry first, BibEntry second, DuplicateResolverType resolverType) { - DuplicateResolverDialog dialog = new DuplicateResolverDialog(first, second, resolverType, frame.getCurrentBasePanel().getBibDatabaseContext(), stateManager); + DuplicateResolverDialog dialog = new DuplicateResolverDialog(first, second, resolverType, frame.getCurrentLibraryTab().getBibDatabaseContext(), stateManager); DuplicateResolverResult resolverResult = dialog.showAndWait().orElse(DuplicateResolverResult.BREAK); @@ -156,25 +156,25 @@ private void handleDuplicates(DuplicateSearchResult result) { return; } - BasePanel panel = frame.getCurrentBasePanel(); + LibraryTab libraryTab = frame.getCurrentLibraryTab(); final NamedCompound compoundEdit = new NamedCompound(Localization.lang("duplicate removal")); // Now, do the actual removal: if (!result.getToRemove().isEmpty()) { - compoundEdit.addEdit(new UndoableRemoveEntries(panel.getDatabase(), result.getToRemove())); - panel.getDatabase().removeEntries(result.getToRemove()); - panel.markBaseChanged(); + compoundEdit.addEdit(new UndoableRemoveEntries(libraryTab.getDatabase(), result.getToRemove())); + libraryTab.getDatabase().removeEntries(result.getToRemove()); + libraryTab.markBaseChanged(); } // and adding merged entries: if (!result.getToAdd().isEmpty()) { - compoundEdit.addEdit(new UndoableInsertEntries(panel.getDatabase(), result.getToAdd())); - panel.getDatabase().insertEntries(result.getToAdd()); - panel.markBaseChanged(); + compoundEdit.addEdit(new UndoableInsertEntries(libraryTab.getDatabase(), result.getToAdd())); + libraryTab.getDatabase().insertEntries(result.getToAdd()); + libraryTab.markBaseChanged(); } dialogService.notify(Localization.lang("Duplicates found") + ": " + duplicateCount.get() + ' ' + Localization.lang("pairs processed") + ": " + result.getDuplicateCount()); compoundEdit.end(); - panel.getUndoManager().addEdit(compoundEdit); + libraryTab.getUndoManager().addEdit(compoundEdit); } /** diff --git a/src/main/java/org/jabref/gui/edit/EditAction.java b/src/main/java/org/jabref/gui/edit/EditAction.java index 643cc37d9ec..5cdebd07b14 100644 --- a/src/main/java/org/jabref/gui/edit/EditAction.java +++ b/src/main/java/org/jabref/gui/edit/EditAction.java @@ -62,12 +62,12 @@ public void execute() { LOGGER.debug("Else: {}", focusOwner.getClass().getSimpleName()); // Not sure what is selected -> copy/paste/cut selected entries - // ToDo: Should be handled by BibDatabaseContext instead of BasePanel + // ToDo: Should be handled by BibDatabaseContext instead of LibraryTab switch (action) { - case COPY -> frame.getCurrentBasePanel().copy(); - case CUT -> frame.getCurrentBasePanel().cut(); - case PASTE -> frame.getCurrentBasePanel().paste(); - case DELETE_ENTRY -> frame.getCurrentBasePanel().delete(false); + case COPY -> frame.getCurrentLibraryTab().copy(); + case CUT -> frame.getCurrentLibraryTab().cut(); + case PASTE -> frame.getCurrentLibraryTab().paste(); + case DELETE_ENTRY -> frame.getCurrentLibraryTab().delete(false); default -> throw new IllegalStateException("Only cut/copy/paste supported but got " + action); } } diff --git a/src/main/java/org/jabref/gui/edit/ReplaceStringAction.java b/src/main/java/org/jabref/gui/edit/ReplaceStringAction.java index 33b016ce9e7..7b8b9d4a288 100644 --- a/src/main/java/org/jabref/gui/edit/ReplaceStringAction.java +++ b/src/main/java/org/jabref/gui/edit/ReplaceStringAction.java @@ -16,7 +16,7 @@ public ReplaceStringAction(JabRefFrame frame, StateManager stateManager) { @Override public void execute() { - ReplaceStringView dialog = new ReplaceStringView(frame.getCurrentBasePanel()); + ReplaceStringView dialog = new ReplaceStringView(frame.getCurrentLibraryTab()); dialog.showAndWait(); } } diff --git a/src/main/java/org/jabref/gui/edit/ReplaceStringView.java b/src/main/java/org/jabref/gui/edit/ReplaceStringView.java index deb4c15c3d9..a931406c99c 100644 --- a/src/main/java/org/jabref/gui/edit/ReplaceStringView.java +++ b/src/main/java/org/jabref/gui/edit/ReplaceStringView.java @@ -6,7 +6,7 @@ import javafx.scene.control.RadioButton; import javafx.scene.control.TextField; -import org.jabref.gui.BasePanel; +import org.jabref.gui.LibraryTab; import org.jabref.gui.util.BaseDialog; import org.jabref.gui.util.ControlHelper; import org.jabref.gui.util.IconValidationDecorator; @@ -28,10 +28,10 @@ public class ReplaceStringView extends BaseDialog { private final ControlsFxVisualizer visualizer = new ControlsFxVisualizer(); - public ReplaceStringView(BasePanel basePanel) { + public ReplaceStringView(LibraryTab libraryTab) { this.setTitle(Localization.lang("Replace String")); - viewModel = new ReplaceStringViewModel(basePanel); + viewModel = new ReplaceStringViewModel(libraryTab); ViewLoader.view(this) .load() diff --git a/src/main/java/org/jabref/gui/edit/ReplaceStringViewModel.java b/src/main/java/org/jabref/gui/edit/ReplaceStringViewModel.java index a7a534c9603..04db4bf9147 100644 --- a/src/main/java/org/jabref/gui/edit/ReplaceStringViewModel.java +++ b/src/main/java/org/jabref/gui/edit/ReplaceStringViewModel.java @@ -9,7 +9,7 @@ import javafx.beans.property.StringProperty; import org.jabref.gui.AbstractViewModel; -import org.jabref.gui.BasePanel; +import org.jabref.gui.LibraryTab; import org.jabref.gui.undo.NamedCompound; import org.jabref.gui.undo.UndoableFieldChange; import org.jabref.logic.l10n.Localization; @@ -22,7 +22,7 @@ public class ReplaceStringViewModel extends AbstractViewModel { private String findString; private String replaceString; private Set fields; - private BasePanel panel; + private LibraryTab panel; private StringProperty findStringProperty = new SimpleStringProperty(); private StringProperty replaceStringProperty = new SimpleStringProperty(); @@ -30,9 +30,9 @@ public class ReplaceStringViewModel extends AbstractViewModel { private BooleanProperty allFieldReplaceProperty = new SimpleBooleanProperty(); private BooleanProperty selectOnlyProperty = new SimpleBooleanProperty(); - public ReplaceStringViewModel(BasePanel basePanel) { - Objects.requireNonNull(basePanel); - this.panel = basePanel; + public ReplaceStringViewModel(LibraryTab libraryTab) { + Objects.requireNonNull(libraryTab); + this.panel = libraryTab; } public int replace() { diff --git a/src/main/java/org/jabref/gui/entryeditor/EntryEditor.java b/src/main/java/org/jabref/gui/entryeditor/EntryEditor.java index 068e9ecd41d..7f05300ff00 100644 --- a/src/main/java/org/jabref/gui/entryeditor/EntryEditor.java +++ b/src/main/java/org/jabref/gui/entryeditor/EntryEditor.java @@ -25,9 +25,9 @@ import javafx.scene.input.TransferMode; import javafx.scene.layout.BorderPane; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; import org.jabref.gui.Globals; +import org.jabref.gui.LibraryTab; import org.jabref.gui.StateManager; import org.jabref.gui.citationkeypattern.GenerateCitationKeySingleAction; import org.jabref.gui.entryeditor.fileannotationtab.FileAnnotationTab; @@ -69,7 +69,7 @@ public class EntryEditor extends BorderPane { private static final Logger LOGGER = LoggerFactory.getLogger(EntryEditor.class); - private final BasePanel panel; + private final LibraryTab libraryTab; private final BibDatabaseContext databaseContext; private final EntryEditorPreferences entryEditorPreferences; private final ExternalFilesEntryLinker fileLinker; @@ -100,9 +100,9 @@ public class EntryEditor extends BorderPane { @Inject private CountingUndoManager undoManager; private final List entryEditorTabs = new LinkedList<>(); - public EntryEditor(BasePanel panel, ExternalFileTypes externalFileTypes) { - this.panel = panel; - this.databaseContext = panel.getBibDatabaseContext(); + public EntryEditor(LibraryTab libraryTab, ExternalFileTypes externalFileTypes) { + this.libraryTab = libraryTab; + this.databaseContext = libraryTab.getBibDatabaseContext(); ViewLoader.view(this) .root(this) @@ -137,18 +137,18 @@ public EntryEditor(BasePanel panel, ExternalFileTypes externalFileTypes) { if (event.getDragboard().hasContent(DataFormat.FILES)) { List files = event.getDragboard().getFiles().stream().map(File::toPath).collect(Collectors.toList()); switch (event.getTransferMode()) { - case COPY: + case COPY -> { LOGGER.debug("Mode COPY"); fileLinker.copyFilesToFileDirAndAddToEntry(entry, files); - break; - case MOVE: + } + case MOVE -> { LOGGER.debug("Mode MOVE"); fileLinker.moveFilesToFileDirAndAddToEntry(entry, files); - break; - case LINK: + } + case LINK -> { LOGGER.debug("Mode LINK"); fileLinker.addFilesToEntry(entry, files); - break; + } } success = true; } @@ -177,11 +177,11 @@ private void setupKeyBindings() { event.consume(); break; case ENTRY_EDITOR_NEXT_ENTRY: - panel.selectNextEntry(); + libraryTab.selectNextEntry(); event.consume(); break; case ENTRY_EDITOR_PREVIOUS_ENTRY: - panel.selectPreviousEntry(); + libraryTab.selectPreviousEntry(); event.consume(); break; case HELP: @@ -202,12 +202,12 @@ private void setupKeyBindings() { @FXML public void close() { - panel.entryEditorClosing(); + libraryTab.entryEditorClosing(); } @FXML private void deleteEntry() { - panel.delete(entry); + libraryTab.delete(entry); } @FXML @@ -219,12 +219,12 @@ void generateCiteKeyButton() { @FXML private void navigateToPreviousEntry() { - panel.selectPreviousEntry(); + libraryTab.selectPreviousEntry(); } @FXML private void navigateToNextEntry() { - panel.selectNextEntry(); + libraryTab.selectNextEntry(); } private List createTabs() { @@ -232,24 +232,24 @@ private List createTabs() { entryEditorTabs.add(new PreviewTab(databaseContext, dialogService, Globals.prefs, ExternalFileTypes.getInstance())); // Required fields - entryEditorTabs.add(new RequiredFieldsTab(databaseContext, panel.getSuggestionProviders(), undoManager, dialogService, Globals.prefs, Globals.entryTypesManager, ExternalFileTypes.getInstance(), Globals.TASK_EXECUTOR, Globals.journalAbbreviationRepository)); + entryEditorTabs.add(new RequiredFieldsTab(databaseContext, libraryTab.getSuggestionProviders(), undoManager, dialogService, Globals.prefs, Globals.entryTypesManager, ExternalFileTypes.getInstance(), Globals.TASK_EXECUTOR, Globals.journalAbbreviationRepository)); // Optional fields - entryEditorTabs.add(new OptionalFieldsTab(databaseContext, panel.getSuggestionProviders(), undoManager, dialogService, Globals.prefs, Globals.entryTypesManager, ExternalFileTypes.getInstance(), Globals.TASK_EXECUTOR, Globals.journalAbbreviationRepository)); - entryEditorTabs.add(new OptionalFields2Tab(databaseContext, panel.getSuggestionProviders(), undoManager, dialogService, Globals.prefs, Globals.entryTypesManager, ExternalFileTypes.getInstance(), Globals.TASK_EXECUTOR, Globals.journalAbbreviationRepository)); - entryEditorTabs.add(new DeprecatedFieldsTab(databaseContext, panel.getSuggestionProviders(), undoManager, dialogService, Globals.prefs, Globals.entryTypesManager, ExternalFileTypes.getInstance(), Globals.TASK_EXECUTOR, Globals.journalAbbreviationRepository)); + entryEditorTabs.add(new OptionalFieldsTab(databaseContext, libraryTab.getSuggestionProviders(), undoManager, dialogService, Globals.prefs, Globals.entryTypesManager, ExternalFileTypes.getInstance(), Globals.TASK_EXECUTOR, Globals.journalAbbreviationRepository)); + entryEditorTabs.add(new OptionalFields2Tab(databaseContext, libraryTab.getSuggestionProviders(), undoManager, dialogService, Globals.prefs, Globals.entryTypesManager, ExternalFileTypes.getInstance(), Globals.TASK_EXECUTOR, Globals.journalAbbreviationRepository)); + entryEditorTabs.add(new DeprecatedFieldsTab(databaseContext, libraryTab.getSuggestionProviders(), undoManager, dialogService, Globals.prefs, Globals.entryTypesManager, ExternalFileTypes.getInstance(), Globals.TASK_EXECUTOR, Globals.journalAbbreviationRepository)); // Other fields - entryEditorTabs.add(new OtherFieldsTab(databaseContext, panel.getSuggestionProviders(), undoManager, dialogService, Globals.prefs, Globals.entryTypesManager, ExternalFileTypes.getInstance(), Globals.TASK_EXECUTOR, Globals.journalAbbreviationRepository)); + entryEditorTabs.add(new OtherFieldsTab(databaseContext, libraryTab.getSuggestionProviders(), undoManager, dialogService, Globals.prefs, Globals.entryTypesManager, ExternalFileTypes.getInstance(), Globals.TASK_EXECUTOR, Globals.journalAbbreviationRepository)); // General fields from preferences for (Map.Entry> tab : entryEditorPreferences.getEntryEditorTabList().entrySet()) { - entryEditorTabs.add(new UserDefinedFieldsTab(tab.getKey(), tab.getValue(), databaseContext, panel.getSuggestionProviders(), undoManager, dialogService, Globals.prefs, Globals.entryTypesManager, ExternalFileTypes.getInstance(), Globals.TASK_EXECUTOR, Globals.journalAbbreviationRepository)); + entryEditorTabs.add(new UserDefinedFieldsTab(tab.getKey(), tab.getValue(), databaseContext, libraryTab.getSuggestionProviders(), undoManager, dialogService, Globals.prefs, Globals.entryTypesManager, ExternalFileTypes.getInstance(), Globals.TASK_EXECUTOR, Globals.journalAbbreviationRepository)); } // Special tabs entryEditorTabs.add(new MathSciNetTab()); - entryEditorTabs.add(new FileAnnotationTab(panel.getAnnotationCache())); + entryEditorTabs.add(new FileAnnotationTab(libraryTab.getAnnotationCache())); entryEditorTabs.add(new RelatedArticlesTab(this, entryEditorPreferences, dialogService)); // Source tab @@ -361,7 +361,7 @@ private void setupToolBar() { } private void fetchAndMerge(EntryBasedFetcher fetcher) { - new FetchAndMergeEntry(panel, taskExecutor).fetchAndMerge(entry, fetcher); + new FetchAndMergeEntry(libraryTab, taskExecutor).fetchAndMerge(entry, fetcher); } public void setFocusToField(Field field) { diff --git a/src/main/java/org/jabref/gui/entryeditor/OpenEntryEditorAction.java b/src/main/java/org/jabref/gui/entryeditor/OpenEntryEditorAction.java index e6e759880e7..4fe0a8101b4 100644 --- a/src/main/java/org/jabref/gui/entryeditor/OpenEntryEditorAction.java +++ b/src/main/java/org/jabref/gui/entryeditor/OpenEntryEditorAction.java @@ -19,7 +19,7 @@ public OpenEntryEditorAction(JabRefFrame frame, StateManager stateManager) { public void execute() { if (!stateManager.getSelectedEntries().isEmpty()) { - frame.getCurrentBasePanel().showAndEdit(stateManager.getSelectedEntries().get(0)); + frame.getCurrentLibraryTab().showAndEdit(stateManager.getSelectedEntries().get(0)); } } } diff --git a/src/main/java/org/jabref/gui/entryeditor/PreviewSwitchAction.java b/src/main/java/org/jabref/gui/entryeditor/PreviewSwitchAction.java index 03247c4fdd0..366adcc70f8 100644 --- a/src/main/java/org/jabref/gui/entryeditor/PreviewSwitchAction.java +++ b/src/main/java/org/jabref/gui/entryeditor/PreviewSwitchAction.java @@ -23,9 +23,9 @@ public PreviewSwitchAction(Direction direction, JabRefFrame frame, StateManager @Override public void execute() { if (direction == Direction.NEXT) { - frame.getCurrentBasePanel().getEntryEditor().nextPreviewStyle(); + frame.getCurrentLibraryTab().getEntryEditor().nextPreviewStyle(); } else { - frame.getCurrentBasePanel().getEntryEditor().previousPreviewStyle(); + frame.getCurrentLibraryTab().getEntryEditor().previousPreviewStyle(); } } } diff --git a/src/main/java/org/jabref/gui/exporter/ExportCommand.java b/src/main/java/org/jabref/gui/exporter/ExportCommand.java index 70f4e5adca0..ef726e448fb 100644 --- a/src/main/java/org/jabref/gui/exporter/ExportCommand.java +++ b/src/main/java/org/jabref/gui/exporter/ExportCommand.java @@ -82,16 +82,16 @@ private void export(Path file, FileChooser.ExtensionFilter selectedExtensionFilt List entries; if (selectedOnly) { // Selected entries - entries = frame.getCurrentBasePanel().getSelectedEntries(); + entries = frame.getCurrentLibraryTab().getSelectedEntries(); } else { // All entries - entries = frame.getCurrentBasePanel().getDatabase().getEntries(); + entries = frame.getCurrentLibraryTab().getDatabase().getEntries(); } // Set the global variable for this database's file directory before exporting, // so formatters can resolve linked files correctly. // (This is an ugly hack!) - Globals.prefs.fileDirForDatabase = frame.getCurrentBasePanel() + Globals.prefs.fileDirForDatabase = frame.getCurrentLibraryTab() .getBibDatabaseContext() .getFileDirectories(Globals.prefs.getFilePreferences()); @@ -103,9 +103,9 @@ private void export(Path file, FileChooser.ExtensionFilter selectedExtensionFilt final List finEntries = entries; BackgroundTask .wrap(() -> { - format.export(frame.getCurrentBasePanel().getBibDatabaseContext(), + format.export(frame.getCurrentLibraryTab().getBibDatabaseContext(), file, - frame.getCurrentBasePanel() + frame.getCurrentLibraryTab() .getBibDatabaseContext() .getMetaData() .getEncoding() diff --git a/src/main/java/org/jabref/gui/exporter/ExportToClipboardAction.java b/src/main/java/org/jabref/gui/exporter/ExportToClipboardAction.java index cd950e1ad2a..b5750b815e5 100644 --- a/src/main/java/org/jabref/gui/exporter/ExportToClipboardAction.java +++ b/src/main/java/org/jabref/gui/exporter/ExportToClipboardAction.java @@ -13,11 +13,11 @@ import javafx.scene.input.ClipboardContent; -import org.jabref.gui.BasePanel; import org.jabref.gui.ClipBoardManager; import org.jabref.gui.DialogService; import org.jabref.gui.Globals; import org.jabref.gui.JabRefFrame; +import org.jabref.gui.LibraryTab; import org.jabref.gui.actions.SimpleCommand; import org.jabref.gui.util.BackgroundTask; import org.jabref.gui.util.TaskExecutor; @@ -42,7 +42,7 @@ public class ExportToClipboardAction extends SimpleCommand { private JabRefFrame frame; private final DialogService dialogService; - private BasePanel panel; + private LibraryTab panel; private final List entries = new ArrayList<>(); private final ExporterFactory exporterFactory; private final ClipBoardManager clipBoardManager; @@ -56,7 +56,7 @@ public ExportToClipboardAction(JabRefFrame frame, DialogService dialogService, E this.taskExecutor = taskExecutor; } - public ExportToClipboardAction(BasePanel panel, DialogService dialogService, ExporterFactory exporterFactory, ClipBoardManager clipBoardManager, TaskExecutor taskExecutor) { + public ExportToClipboardAction(LibraryTab panel, DialogService dialogService, ExporterFactory exporterFactory, ClipBoardManager clipBoardManager, TaskExecutor taskExecutor) { this.panel = panel; this.dialogService = dialogService; this.exporterFactory = exporterFactory; @@ -67,7 +67,7 @@ public ExportToClipboardAction(BasePanel panel, DialogService dialogService, Exp @Override public void execute() { if (panel == null) { - panel = frame.getCurrentBasePanel(); + panel = frame.getCurrentLibraryTab(); } if (panel.getSelectedEntries().isEmpty()) { diff --git a/src/main/java/org/jabref/gui/exporter/SaveAction.java b/src/main/java/org/jabref/gui/exporter/SaveAction.java index 2a80a25148d..c070159311d 100644 --- a/src/main/java/org/jabref/gui/exporter/SaveAction.java +++ b/src/main/java/org/jabref/gui/exporter/SaveAction.java @@ -30,7 +30,7 @@ public SaveAction(SaveMethod saveMethod, JabRefFrame frame, StateManager stateMa @Override public void execute() { SaveDatabaseAction saveDatabaseAction = new SaveDatabaseAction( - frame.getCurrentBasePanel(), + frame.getCurrentLibraryTab(), Globals.prefs, Globals.entryTypesManager); diff --git a/src/main/java/org/jabref/gui/exporter/SaveAllAction.java b/src/main/java/org/jabref/gui/exporter/SaveAllAction.java index 4c2c1dd69a3..dd115d79ec8 100644 --- a/src/main/java/org/jabref/gui/exporter/SaveAllAction.java +++ b/src/main/java/org/jabref/gui/exporter/SaveAllAction.java @@ -1,9 +1,9 @@ package org.jabref.gui.exporter; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; import org.jabref.gui.Globals; import org.jabref.gui.JabRefFrame; +import org.jabref.gui.LibraryTab; import org.jabref.gui.actions.SimpleCommand; import org.jabref.logic.l10n.Localization; @@ -21,8 +21,8 @@ public SaveAllAction(JabRefFrame frame) { public void execute() { dialogService.notify(Localization.lang("Saving all libraries...")); - for (BasePanel panel : frame.getBasePanelList()) { - SaveDatabaseAction saveDatabaseAction = new SaveDatabaseAction(panel, Globals.prefs, Globals.entryTypesManager); + for (LibraryTab libraryTab : frame.getLibraryTabs()) { + SaveDatabaseAction saveDatabaseAction = new SaveDatabaseAction(libraryTab, Globals.prefs, Globals.entryTypesManager); boolean saveResult = saveDatabaseAction.save(); if (!saveResult) { dialogService.notify(Localization.lang("Could not save file.")); diff --git a/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java b/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java index ea4d1d8a150..6164ed5ef5a 100644 --- a/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java +++ b/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java @@ -14,9 +14,9 @@ import javafx.scene.layout.VBox; import javafx.scene.text.Text; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; import org.jabref.gui.JabRefFrame; +import org.jabref.gui.LibraryTab; import org.jabref.gui.dialogs.AutosaveUiManager; import org.jabref.gui.util.BackgroundTask; import org.jabref.gui.util.FileDialogConfiguration; @@ -49,7 +49,7 @@ public class SaveDatabaseAction { private static final Logger LOGGER = LoggerFactory.getLogger(SaveDatabaseAction.class); - private final BasePanel panel; + private final LibraryTab panel; private final JabRefFrame frame; private final DialogService dialogService; private final JabRefPreferences preferences; @@ -59,9 +59,9 @@ public enum SaveDatabaseMode { SILENT, NORMAL } - public SaveDatabaseAction(BasePanel panel, JabRefPreferences preferences, BibEntryTypesManager entryTypesManager) { - this.panel = panel; - this.frame = panel.frame(); + public SaveDatabaseAction(LibraryTab libraryTab, JabRefPreferences preferences, BibEntryTypesManager entryTypesManager) { + this.panel = libraryTab; + this.frame = libraryTab.frame(); this.dialogService = frame.getDialogService(); this.preferences = preferences; this.entryTypesManager = entryTypesManager; @@ -168,7 +168,7 @@ private boolean save(BibDatabaseContext bibDatabaseContext, SaveDatabaseMode mod Optional databasePath = bibDatabaseContext.getDatabasePath(); if (databasePath.isEmpty()) { Optional savePath = askForSavePath(); - if (!savePath.isPresent()) { + if (savePath.isEmpty()) { return false; } return saveAs(savePath.get(), mode); diff --git a/src/main/java/org/jabref/gui/fieldeditors/IdentifierEditorViewModel.java b/src/main/java/org/jabref/gui/fieldeditors/IdentifierEditorViewModel.java index 7c18e322bfd..65659729cd0 100644 --- a/src/main/java/org/jabref/gui/fieldeditors/IdentifierEditorViewModel.java +++ b/src/main/java/org/jabref/gui/fieldeditors/IdentifierEditorViewModel.java @@ -44,7 +44,7 @@ public IdentifierEditorViewModel(Field field, SuggestionProvider suggestionPr ); validIdentifierIsNotPresent.bind( - EasyBind.map(identifier, parsedIdentifier -> !parsedIdentifier.isPresent()) + EasyBind.map(identifier, parsedIdentifier -> parsedIdentifier.isEmpty()) ); idFetcherAvailable.setValue(WebFetchers.getIdFetcherForField(field).isPresent()); @@ -87,7 +87,7 @@ public BooleanProperty identifierLookupInProgressProperty() { } public void fetchInformationByIdentifier(BibEntry entry) { - new FetchAndMergeEntry(JabRefGUI.getMainFrame().getCurrentBasePanel(), taskExecutor).fetchAndMerge(entry, field); + new FetchAndMergeEntry(JabRefGUI.getMainFrame().getCurrentLibraryTab(), taskExecutor).fetchAndMerge(entry, field); } public void lookupIdentifier(BibEntry entry) { diff --git a/src/main/java/org/jabref/gui/importer/ImportAction.java b/src/main/java/org/jabref/gui/importer/ImportAction.java index 8dae27690a6..52ea32b30e4 100644 --- a/src/main/java/org/jabref/gui/importer/ImportAction.java +++ b/src/main/java/org/jabref/gui/importer/ImportAction.java @@ -8,10 +8,10 @@ import java.util.Optional; import java.util.stream.Collectors; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; import org.jabref.gui.Globals; import org.jabref.gui.JabRefFrame; +import org.jabref.gui.LibraryTab; import org.jabref.gui.util.BackgroundTask; import org.jabref.gui.util.DefaultTaskExecutor; import org.jabref.gui.util.TaskExecutor; @@ -29,6 +29,7 @@ import org.slf4j.LoggerFactory; public class ImportAction { +// FixMe: Command pattern is broken, should extend SimpleCommand private static final Logger LOGGER = LoggerFactory.getLogger(ImportAction.class); @@ -84,9 +85,9 @@ public void automatedImport(List filenames) { }) .executeWith(taskExecutor); } else { - final BasePanel panel = frame.getCurrentBasePanel(); + final LibraryTab libraryTab = frame.getCurrentLibraryTab(); - ImportEntriesDialog dialog = new ImportEntriesDialog(panel.getBibDatabaseContext(), task); + ImportEntriesDialog dialog = new ImportEntriesDialog(libraryTab.getBibDatabaseContext(), task); dialog.setTitle(Localization.lang("Import")); dialog.showAndWait(); } @@ -97,7 +98,7 @@ private List doImport(List files) List imports = new ArrayList<>(); for (Path filename : files) { try { - if (!importer.isPresent()) { + if (importer.isEmpty()) { // Unknown format: DefaultTaskExecutor.runInJavaFXThread(() -> frame.getDialogService().notify(Localization.lang("Importing in unknown format") + "...")); // This import method never throws an IOException: diff --git a/src/main/java/org/jabref/gui/importer/ImportEntriesViewModel.java b/src/main/java/org/jabref/gui/importer/ImportEntriesViewModel.java index 7b2bdd92be2..ddd581b2da7 100644 --- a/src/main/java/org/jabref/gui/importer/ImportEntriesViewModel.java +++ b/src/main/java/org/jabref/gui/importer/ImportEntriesViewModel.java @@ -155,7 +155,7 @@ public void importEntries(List entriesToImport, boolean shouldDownload parserResult.getFile().map(File::getName).orElse("unknown"), parserResult.getDatabase().getEntries()); - JabRefGUI.getMainFrame().getCurrentBasePanel().markBaseChanged(); + JabRefGUI.getMainFrame().getCurrentLibraryTab().markBaseChanged(); } private void buildImportHandlerThenImportEntries(List entriesToImport) { diff --git a/src/main/java/org/jabref/gui/importer/NewEntryAction.java b/src/main/java/org/jabref/gui/importer/NewEntryAction.java index 6221b335413..7869393367e 100644 --- a/src/main/java/org/jabref/gui/importer/NewEntryAction.java +++ b/src/main/java/org/jabref/gui/importer/NewEntryAction.java @@ -54,16 +54,16 @@ public void execute() { } if (type.isPresent()) { - jabRefFrame.getCurrentBasePanel().insertEntry(new BibEntry(type.get())); + jabRefFrame.getCurrentLibraryTab().insertEntry(new BibEntry(type.get())); } else { - EntryTypeView typeChoiceDialog = new EntryTypeView(jabRefFrame.getCurrentBasePanel(), dialogService, preferences); + EntryTypeView typeChoiceDialog = new EntryTypeView(jabRefFrame.getCurrentLibraryTab(), dialogService, preferences); EntryType selectedType = typeChoiceDialog.showAndWait().orElse(null); if (selectedType == null) { return; } trackNewEntry(selectedType); - jabRefFrame.getCurrentBasePanel().insertEntry(new BibEntry(selectedType)); + jabRefFrame.getCurrentLibraryTab().insertEntry(new BibEntry(selectedType)); } } diff --git a/src/main/java/org/jabref/gui/importer/actions/CheckForNewEntryTypesAction.java b/src/main/java/org/jabref/gui/importer/actions/CheckForNewEntryTypesAction.java index 86c50d19051..1da9f8d60de 100644 --- a/src/main/java/org/jabref/gui/importer/actions/CheckForNewEntryTypesAction.java +++ b/src/main/java/org/jabref/gui/importer/actions/CheckForNewEntryTypesAction.java @@ -3,8 +3,8 @@ import java.util.List; import java.util.stream.Collectors; -import org.jabref.gui.BasePanel; import org.jabref.gui.Globals; +import org.jabref.gui.LibraryTab; import org.jabref.gui.importer.ImportCustomEntryTypesDialog; import org.jabref.logic.importer.ParserResult; import org.jabref.model.database.BibDatabaseMode; @@ -22,7 +22,7 @@ public boolean isActionNecessary(ParserResult parserResult) { } @Override - public void performAction(BasePanel panel, ParserResult parserResult) { + public void performAction(LibraryTab libraryTab, ParserResult parserResult) { BibDatabaseMode mode = getBibDatabaseModeFromParserResult(parserResult); ImportCustomEntryTypesDialog importBibEntryTypesDialog = new ImportCustomEntryTypesDialog(mode, getListOfUnknownAndUnequalCustomizations(parserResult)); diff --git a/src/main/java/org/jabref/gui/importer/actions/GUIPostOpenAction.java b/src/main/java/org/jabref/gui/importer/actions/GUIPostOpenAction.java index a8815ebc048..acdbd8726a7 100644 --- a/src/main/java/org/jabref/gui/importer/actions/GUIPostOpenAction.java +++ b/src/main/java/org/jabref/gui/importer/actions/GUIPostOpenAction.java @@ -1,6 +1,6 @@ package org.jabref.gui.importer.actions; -import org.jabref.gui.BasePanel; +import org.jabref.gui.LibraryTab; import org.jabref.logic.importer.ParserResult; /** @@ -33,5 +33,5 @@ public interface GUIPostOpenAction { * @param panel The BasePanel where the database is shown. * @param pr The result of the BIB parse operation. */ - void performAction(BasePanel panel, ParserResult pr); + void performAction(LibraryTab panel, ParserResult pr); } diff --git a/src/main/java/org/jabref/gui/importer/actions/MergeReviewIntoCommentAction.java b/src/main/java/org/jabref/gui/importer/actions/MergeReviewIntoCommentAction.java index 3196f1c46aa..a8bb0a453f1 100644 --- a/src/main/java/org/jabref/gui/importer/actions/MergeReviewIntoCommentAction.java +++ b/src/main/java/org/jabref/gui/importer/actions/MergeReviewIntoCommentAction.java @@ -2,7 +2,7 @@ import java.util.List; -import org.jabref.gui.BasePanel; +import org.jabref.gui.LibraryTab; import org.jabref.logic.importer.ParserResult; import org.jabref.migrations.MergeReviewIntoCommentMigration; import org.jabref.model.entry.BibEntry; @@ -15,12 +15,12 @@ public boolean isActionNecessary(ParserResult parserResult) { } @Override - public void performAction(BasePanel basePanel, ParserResult parserResult) { + public void performAction(LibraryTab libraryTab, ParserResult parserResult) { MergeReviewIntoCommentMigration migration = new MergeReviewIntoCommentMigration(); migration.performMigration(parserResult); List conflicts = MergeReviewIntoCommentMigration.collectConflicts(parserResult); - if (!conflicts.isEmpty() && new MergeReviewIntoCommentConfirmationDialog(basePanel.frame().getDialogService()).askUserForMerge(conflicts)) { + if (!conflicts.isEmpty() && new MergeReviewIntoCommentConfirmationDialog(libraryTab.frame().getDialogService()).askUserForMerge(conflicts)) { migration.performConflictingMigration(parserResult); } } diff --git a/src/main/java/org/jabref/gui/importer/actions/OpenDatabaseAction.java b/src/main/java/org/jabref/gui/importer/actions/OpenDatabaseAction.java index 80d6f8fc158..4e9a682f061 100644 --- a/src/main/java/org/jabref/gui/importer/actions/OpenDatabaseAction.java +++ b/src/main/java/org/jabref/gui/importer/actions/OpenDatabaseAction.java @@ -11,11 +11,11 @@ import java.util.Objects; import java.util.Optional; -import org.jabref.gui.BasePanel; import org.jabref.gui.BasePanelPreferences; import org.jabref.gui.DialogService; import org.jabref.gui.Globals; import org.jabref.gui.JabRefFrame; +import org.jabref.gui.LibraryTab; import org.jabref.gui.actions.SimpleCommand; import org.jabref.gui.dialogs.BackupUIManager; import org.jabref.gui.externalfiletype.ExternalFileTypes; @@ -60,14 +60,14 @@ public OpenDatabaseAction(JabRefFrame frame) { /** * Go through the list of post open actions, and perform those that need to be performed. * - * @param panel The BasePanel where the database is shown. + * @param libraryTab The BasePanel where the database is shown. * @param result The result of the BIB file parse operation. */ - public static void performPostOpenActions(BasePanel panel, ParserResult result) { + public static void performPostOpenActions(LibraryTab libraryTab, ParserResult result) { for (GUIPostOpenAction action : OpenDatabaseAction.POST_OPEN_ACTIONS) { if (action.isActionNecessary(result)) { - action.performAction(panel, result); - panel.frame().showBasePanel(panel); + action.performAction(libraryTab, result); + libraryTab.frame().showLibraryTab(libraryTab); } } } @@ -91,7 +91,7 @@ private Path getInitialDirectory() { if (frame.getBasePanelCount() == 0) { return Globals.prefs.getWorkingDir(); } else { - Optional databasePath = frame.getCurrentBasePanel().getBibDatabaseContext().getDatabasePath(); + Optional databasePath = frame.getCurrentLibraryTab().getBibDatabaseContext().getDatabasePath(); return databasePath.map(Path::getParent).orElse(Globals.prefs.getWorkingDir()); } } @@ -111,7 +111,7 @@ public void openFile(Path file, boolean raisePanel) { * @param filesToOpen the filesToOpen, may be null or not existing */ public void openFiles(List filesToOpen, boolean raisePanel) { - BasePanel toRaise = null; + LibraryTab toRaise = null; int initialCount = filesToOpen.size(); int removed = 0; @@ -119,17 +119,17 @@ public void openFiles(List filesToOpen, boolean raisePanel) { for (Iterator iterator = filesToOpen.iterator(); iterator.hasNext(); ) { Path file = iterator.next(); for (int i = 0; i < frame.getTabbedPane().getTabs().size(); i++) { - BasePanel basePanel = frame.getBasePanelAt(i); - if ((basePanel.getBibDatabaseContext().getDatabasePath().isPresent()) - && basePanel.getBibDatabaseContext().getDatabasePath().get().equals(file)) { + LibraryTab libraryTab = frame.getLibraryTabAt(i); + if ((libraryTab.getBibDatabaseContext().getDatabasePath().isPresent()) + && libraryTab.getBibDatabaseContext().getDatabasePath().get().equals(file)) { iterator.remove(); removed++; // See if we removed the final one. If so, we must perhaps - // raise the BasePanel in question: + // raise the LibraryTab in question: if (removed == initialCount) { - toRaise = basePanel; + toRaise = libraryTab; } - // no more bps to check, we found a matching one + // no more LibraryTabs to check, we found a matching one break; } } @@ -151,7 +151,7 @@ public void openFiles(List filesToOpen, boolean raisePanel) { } else if (toRaise != null) { // If no files are remaining to open, this could mean that a file was // already open. If so, we may have to raise the correct tab: - frame.showBasePanel(toRaise); + frame.showLibraryTab(toRaise); } } @@ -164,8 +164,8 @@ private void openTheFile(Path file, boolean raisePanel) { BackgroundTask.wrap(() -> loadDatabase(file)) .onSuccess(result -> { - BasePanel panel = addNewDatabase(result, file, raisePanel); - OpenDatabaseAction.performPostOpenActions(panel, result); + LibraryTab libraryTab = addNewDatabase(result, file, raisePanel); + OpenDatabaseAction.performPostOpenActions(libraryTab, result); }) .onFailure(ex -> dialogService.showErrorDialogAndWait(Localization.lang("Connection error"), ex.getMessage() + "\n\n" + Localization.lang("A local copy will be opened."))) @@ -202,13 +202,13 @@ private ParserResult loadDatabase(Path file) throws Exception { return result; } - private BasePanel addNewDatabase(ParserResult result, final Path file, boolean raisePanel) { + private LibraryTab addNewDatabase(ParserResult result, final Path file, boolean raisePanel) { if (result.hasWarnings()) { ParserResultWarningDialog.showParserResultWarningDialog(result, frame); } - BasePanel basePanel = new BasePanel(frame, BasePanelPreferences.from(Globals.prefs), result.getDatabaseContext(), ExternalFileTypes.getInstance()); - frame.addTab(basePanel, raisePanel); - return basePanel; + LibraryTab libraryTab = new LibraryTab(frame, BasePanelPreferences.from(Globals.prefs), result.getDatabaseContext(), ExternalFileTypes.getInstance()); + frame.addTab(libraryTab, raisePanel); + return libraryTab; } } diff --git a/src/main/java/org/jabref/gui/importer/fetcher/WebSearchPaneViewModel.java b/src/main/java/org/jabref/gui/importer/fetcher/WebSearchPaneViewModel.java index a51aeb51fca..773289143f5 100644 --- a/src/main/java/org/jabref/gui/importer/fetcher/WebSearchPaneViewModel.java +++ b/src/main/java/org/jabref/gui/importer/fetcher/WebSearchPaneViewModel.java @@ -101,7 +101,7 @@ public void search() { return; } - if (frame.getCurrentBasePanel() == null) { + if (frame.getCurrentLibraryTab() == null) { dialogService.notify(Localization.lang("Please open or start a new library before searching")); return; } @@ -120,7 +120,7 @@ public void search() { } task.onFailure(dialogService::showErrorDialogAndWait); - ImportEntriesDialog dialog = new ImportEntriesDialog(frame.getCurrentBasePanel().getBibDatabaseContext(), task); + ImportEntriesDialog dialog = new ImportEntriesDialog(frame.getCurrentLibraryTab().getBibDatabaseContext(), task); dialog.setTitle(activeFetcher.getName()); dialog.showAndWait(); } diff --git a/src/main/java/org/jabref/gui/integrity/IntegrityCheckAction.java b/src/main/java/org/jabref/gui/integrity/IntegrityCheckAction.java index d74fd516063..c08c1a61505 100644 --- a/src/main/java/org/jabref/gui/integrity/IntegrityCheckAction.java +++ b/src/main/java/org/jabref/gui/integrity/IntegrityCheckAction.java @@ -72,7 +72,7 @@ protected List call() { if (messages.isEmpty()) { dialogService.notify(Localization.lang("No problems found.")); } else { - Dialog dialog = new IntegrityCheckDialog(messages, frame.getCurrentBasePanel()); + Dialog dialog = new IntegrityCheckDialog(messages, frame.getCurrentLibraryTab()); dialog.showAndWait(); } }); diff --git a/src/main/java/org/jabref/gui/integrity/IntegrityCheckDialog.java b/src/main/java/org/jabref/gui/integrity/IntegrityCheckDialog.java index 26de42d4bf3..7f190ebf036 100644 --- a/src/main/java/org/jabref/gui/integrity/IntegrityCheckDialog.java +++ b/src/main/java/org/jabref/gui/integrity/IntegrityCheckDialog.java @@ -12,7 +12,7 @@ import javafx.scene.input.MouseButton; import javafx.stage.Modality; -import org.jabref.gui.BasePanel; +import org.jabref.gui.LibraryTab; import org.jabref.gui.util.BaseDialog; import org.jabref.logic.integrity.IntegrityMessage; import org.jabref.logic.l10n.Localization; @@ -23,7 +23,7 @@ public class IntegrityCheckDialog extends BaseDialog { private final List messages; - private final BasePanel basePanel; + private final LibraryTab libraryTab; @FXML private TableView messagesTable; @FXML private TableColumn keyColumn; @FXML private TableColumn fieldColumn; @@ -34,9 +34,9 @@ public class IntegrityCheckDialog extends BaseDialog { private IntegrityCheckDialogViewModel viewModel; private TableFilter tableFilter; - public IntegrityCheckDialog(List messages, BasePanel basePanel) { + public IntegrityCheckDialog(List messages, LibraryTab libraryTab) { this.messages = messages; - this.basePanel = basePanel; + this.libraryTab = libraryTab; this.setTitle(Localization.lang("Check integrity")); this.initModality(Modality.NONE); @@ -48,7 +48,7 @@ public IntegrityCheckDialog(List messages, BasePanel basePanel private void onSelectionChanged(ListChangeListener.Change change) { if (change.next()) { change.getAddedSubList().stream().findFirst().ifPresent(message -> - basePanel.editEntryAndFocusField(message.getEntry(), message.getField())); + libraryTab.editEntryAndFocusField(message.getEntry(), message.getField())); } } diff --git a/src/main/java/org/jabref/gui/journals/AbbreviateAction.java b/src/main/java/org/jabref/gui/journals/AbbreviateAction.java index 6fd9421e2ac..81c5ea15322 100644 --- a/src/main/java/org/jabref/gui/journals/AbbreviateAction.java +++ b/src/main/java/org/jabref/gui/journals/AbbreviateAction.java @@ -50,18 +50,10 @@ public AbbreviateAction(StandardActions action, this.stateManager = stateManager; switch (action) { - case ABBREVIATE_DEFAULT: - abbreviationType = AbbreviationType.DEFAULT; - break; - case ABBREVIATE_MEDLINE: - abbreviationType = AbbreviationType.MEDLINE; - break; - case ABBREVIATE_SHORTEST_UNIQUE: - abbreviationType = AbbreviationType.SHORTEST_UNIQUE; - break; - default: - LOGGER.debug("Unknown action: " + action.name()); - break; + case ABBREVIATE_DEFAULT -> abbreviationType = AbbreviationType.DEFAULT; + case ABBREVIATE_MEDLINE -> abbreviationType = AbbreviationType.MEDLINE; + case ABBREVIATE_SHORTEST_UNIQUE -> abbreviationType = AbbreviationType.SHORTEST_UNIQUE; + default -> LOGGER.debug("Unknown action: " + action.name()); } this.executable.bind(ActionHelper.needsEntriesSelected(stateManager)); @@ -120,7 +112,7 @@ private String abbreviate(BibDatabaseContext databaseContext, List ent if (count > 0) { ce.end(); frame.getUndoManager().addEdit(ce); - frame.getCurrentBasePanel().markBaseChanged(); + frame.getCurrentLibraryTab().markBaseChanged(); return Localization.lang("Abbreviated %0 journal names.", String.valueOf(count)); } return Localization.lang("No journal names could be abbreviated."); @@ -136,7 +128,7 @@ private String unabbreviate(BibDatabaseContext databaseContext, List e if (count > 0) { ce.end(); frame.getUndoManager().addEdit(ce); - frame.getCurrentBasePanel().markBaseChanged(); + frame.getCurrentLibraryTab().markBaseChanged(); return Localization.lang("Unabbreviated %0 journal names.", String.valueOf(count)); } return Localization.lang("No journal names could be unabbreviated."); diff --git a/src/main/java/org/jabref/gui/libraryproperties/LibraryPropertiesAction.java b/src/main/java/org/jabref/gui/libraryproperties/LibraryPropertiesAction.java index e5a1960cd9f..ea8729837ee 100644 --- a/src/main/java/org/jabref/gui/libraryproperties/LibraryPropertiesAction.java +++ b/src/main/java/org/jabref/gui/libraryproperties/LibraryPropertiesAction.java @@ -17,7 +17,7 @@ public LibraryPropertiesAction(JabRefFrame frame, StateManager stateManager) { @Override public void execute() { - LibraryPropertiesDialogView propertiesDialog = new LibraryPropertiesDialogView(frame.getCurrentBasePanel()); + LibraryPropertiesDialogView propertiesDialog = new LibraryPropertiesDialogView(frame.getCurrentLibraryTab()); propertiesDialog.showAndWait(); } } diff --git a/src/main/java/org/jabref/gui/libraryproperties/LibraryPropertiesDialogView.java b/src/main/java/org/jabref/gui/libraryproperties/LibraryPropertiesDialogView.java index cada1936c9b..0a58302ae75 100644 --- a/src/main/java/org/jabref/gui/libraryproperties/LibraryPropertiesDialogView.java +++ b/src/main/java/org/jabref/gui/libraryproperties/LibraryPropertiesDialogView.java @@ -11,8 +11,8 @@ import javafx.scene.control.ComboBox; import javafx.scene.control.TextField; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; +import org.jabref.gui.LibraryTab; import org.jabref.gui.commonfxcontrols.FieldFormatterCleanupsPanel; import org.jabref.gui.commonfxcontrols.SaveOrderConfigPanel; import org.jabref.gui.util.BaseDialog; @@ -38,11 +38,11 @@ public class LibraryPropertiesDialogView extends BaseDialog { @Inject private PreferencesService preferencesService; @Inject private DialogService dialogService; - private final BasePanel panel; + private final LibraryTab libraryTab; private LibraryPropertiesDialogViewModel viewModel; - public LibraryPropertiesDialogView(BasePanel panel) { - this.panel = panel; + public LibraryPropertiesDialogView(LibraryTab libraryTab) { + this.libraryTab = libraryTab; ViewLoader.view(this) .load() @@ -60,7 +60,7 @@ public LibraryPropertiesDialogView(BasePanel panel) { @FXML private void initialize() { - viewModel = new LibraryPropertiesDialogViewModel(panel.getBibDatabaseContext(), dialogService, preferencesService); + viewModel = new LibraryPropertiesDialogViewModel(libraryTab.getBibDatabaseContext(), dialogService, preferencesService); encoding.disableProperty().bind(viewModel.encodingDisableProperty()); encoding.itemsProperty().bind(viewModel.encodingsProperty()); diff --git a/src/main/java/org/jabref/gui/linkedfile/AttachFileAction.java b/src/main/java/org/jabref/gui/linkedfile/AttachFileAction.java index 8892e6cc450..534de7c529f 100644 --- a/src/main/java/org/jabref/gui/linkedfile/AttachFileAction.java +++ b/src/main/java/org/jabref/gui/linkedfile/AttachFileAction.java @@ -3,8 +3,8 @@ import java.nio.file.Path; import java.util.Optional; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; +import org.jabref.gui.LibraryTab; import org.jabref.gui.StateManager; import org.jabref.gui.actions.ActionHelper; import org.jabref.gui.actions.SimpleCommand; @@ -21,13 +21,16 @@ public class AttachFileAction extends SimpleCommand { - private final BasePanel panel; + private final LibraryTab libraryTab; private final StateManager stateManager; private final DialogService dialogService; private final PreferencesService preferencesService; - public AttachFileAction(BasePanel panel, DialogService dialogService, StateManager stateManager, PreferencesService preferencesService) { - this.panel = panel; + public AttachFileAction(LibraryTab libraryTab, + DialogService dialogService, + StateManager stateManager, + PreferencesService preferencesService) { + this.libraryTab = libraryTab; this.stateManager = stateManager; this.dialogService = dialogService; this.preferencesService = preferencesService; @@ -70,8 +73,8 @@ public void execute() { Optional fieldChange = entry.addFile(editedLinkedFile); fieldChange.ifPresent(change -> { UndoableFieldChange ce = new UndoableFieldChange(change); - panel.getUndoManager().addEdit(ce); - panel.markBaseChanged(); + libraryTab.getUndoManager().addEdit(ce); + libraryTab.markBaseChanged(); }); }); }); diff --git a/src/main/java/org/jabref/gui/maintable/MainTable.java b/src/main/java/org/jabref/gui/maintable/MainTable.java index d13ccf54285..cf5c8cd2b2a 100644 --- a/src/main/java/org/jabref/gui/maintable/MainTable.java +++ b/src/main/java/org/jabref/gui/maintable/MainTable.java @@ -24,10 +24,10 @@ import javafx.scene.input.MouseEvent; import javafx.scene.input.TransferMode; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; import org.jabref.gui.DragAndDropDataFormats; import org.jabref.gui.Globals; +import org.jabref.gui.LibraryTab; import org.jabref.gui.StateManager; import org.jabref.gui.actions.StandardActions; import org.jabref.gui.edit.EditAction; @@ -57,7 +57,7 @@ public class MainTable extends TableView { private static final Logger LOGGER = LoggerFactory.getLogger(MainTable.class); - private final BasePanel panel; + private final LibraryTab libraryTab; private final DialogService dialogService; private final BibDatabaseContext database; private final MainTableDataModel model; @@ -69,7 +69,7 @@ public class MainTable extends TableView { private String columnSearchTerm; public MainTable(MainTableDataModel model, - BasePanel panel, + LibraryTab libraryTab, BibDatabaseContext database, PreferencesService preferencesService, DialogService dialogService, @@ -78,11 +78,11 @@ public MainTable(MainTableDataModel model, KeyBindingRepository keyBindingRepository) { super(); - this.panel = panel; + this.libraryTab = libraryTab; this.dialogService = dialogService; this.database = Objects.requireNonNull(database); this.model = model; - UndoManager undoManager = panel.getUndoManager(); + UndoManager undoManager = libraryTab.getUndoManager(); MainTablePreferences mainTablePreferences = preferencesService.getMainTablePreferences(); importHandler = new ImportHandler( @@ -95,18 +95,22 @@ public MainTable(MainTableDataModel model, localDragboard = stateManager.getLocalDragboard(); this.getColumns().addAll( - new MainTableColumnFactory(database, preferencesService, externalFileTypes, panel.getUndoManager(), dialogService) - .createColumns()); + new MainTableColumnFactory( + database, + preferencesService, + externalFileTypes, + libraryTab.getUndoManager(), + dialogService).createColumns()); new ViewModelTableRowFactory() .withOnMouseClickedEvent((entry, event) -> { if (event.getClickCount() == 2) { - panel.showAndEdit(entry.getEntry()); + libraryTab.showAndEdit(entry.getEntry()); } }) .withContextMenu(entry -> RightClickMenu.create(entry, keyBindingRepository, - panel, + libraryTab, dialogService, stateManager, preferencesService, @@ -223,7 +227,7 @@ public void copy() { if (!selectedEntries.isEmpty()) { try { Globals.clipboardManager.setContent(selectedEntries); - dialogService.notify(panel.formatOutputMessage(Localization.lang("Copied"), selectedEntries.size())); + dialogService.notify(libraryTab.formatOutputMessage(Localization.lang("Copied"), selectedEntries.size())); } catch (IOException e) { LOGGER.error("Error while copying selected entries to clipboard", e); } @@ -232,7 +236,7 @@ public void copy() { public void cut() { copy(); - panel.delete(true); + libraryTab.delete(true); } private void setupKeyBindings(KeyBindingRepository keyBindings) { @@ -240,7 +244,7 @@ private void setupKeyBindings(KeyBindingRepository keyBindings) { if (event.getCode() == KeyCode.ENTER) { getSelectedEntries().stream() .findFirst() - .ifPresent(panel::showAndEdit); + .ifPresent(libraryTab::showAndEdit); event.consume(); return; } @@ -258,16 +262,16 @@ private void setupKeyBindings(KeyBindingRepository keyBindings) { break; case PASTE: if (!OS.OS_X) { - new EditAction(StandardActions.PASTE, panel.frame(), Globals.stateManager).execute(); + new EditAction(StandardActions.PASTE, libraryTab.frame(), Globals.stateManager).execute(); } event.consume(); break; case COPY: - new EditAction(StandardActions.COPY, panel.frame(), Globals.stateManager).execute(); + new EditAction(StandardActions.COPY, libraryTab.frame(), Globals.stateManager).execute(); event.consume(); break; case CUT: - new EditAction(StandardActions.CUT, panel.frame(), Globals.stateManager).execute(); + new EditAction(StandardActions.CUT, libraryTab.frame(), Globals.stateManager).execute(); event.consume(); break; default: @@ -294,7 +298,7 @@ public void paste(BibDatabaseMode bibDatabaseMode) { List entriesToAdd = Globals.clipboardManager.extractData(); ImportCleanup cleanup = new ImportCleanup(bibDatabaseMode); cleanup.doPostCleanup(entriesToAdd); - panel.insertEntries(entriesToAdd); + libraryTab.insertEntries(entriesToAdd); if (!entriesToAdd.isEmpty()) { this.requestFocus(); } diff --git a/src/main/java/org/jabref/gui/maintable/RightClickMenu.java b/src/main/java/org/jabref/gui/maintable/RightClickMenu.java index f7f46026857..6305baeaea7 100644 --- a/src/main/java/org/jabref/gui/maintable/RightClickMenu.java +++ b/src/main/java/org/jabref/gui/maintable/RightClickMenu.java @@ -4,10 +4,10 @@ import javafx.scene.control.Menu; import javafx.scene.control.SeparatorMenuItem; -import org.jabref.gui.BasePanel; import org.jabref.gui.ClipBoardManager; import org.jabref.gui.DialogService; import org.jabref.gui.Globals; +import org.jabref.gui.LibraryTab; import org.jabref.gui.SendAsEMailAction; import org.jabref.gui.StateManager; import org.jabref.gui.actions.ActionFactory; @@ -33,7 +33,7 @@ public class RightClickMenu { public static ContextMenu create(BibEntryTableViewModel entry, KeyBindingRepository keyBindingRepository, - BasePanel panel, + LibraryTab libraryTab, DialogService dialogService, StateManager stateManager, PreferencesService preferencesService, @@ -41,11 +41,11 @@ public static ContextMenu create(BibEntryTableViewModel entry, ContextMenu contextMenu = new ContextMenu(); ActionFactory factory = new ActionFactory(keyBindingRepository); - contextMenu.getItems().add(factory.createMenuItem(StandardActions.COPY, new EditAction(StandardActions.COPY, panel.frame(), stateManager))); - contextMenu.getItems().add(createCopySubMenu(panel, factory, dialogService, stateManager, preferencesService, clipBoardManager)); - contextMenu.getItems().add(factory.createMenuItem(StandardActions.PASTE, new EditAction(StandardActions.PASTE, panel.frame(), stateManager))); - contextMenu.getItems().add(factory.createMenuItem(StandardActions.CUT, new EditAction(StandardActions.CUT, panel.frame(), stateManager))); - contextMenu.getItems().add(factory.createMenuItem(StandardActions.DELETE_ENTRY, new EditAction(StandardActions.DELETE_ENTRY, panel.frame(), stateManager))); + contextMenu.getItems().add(factory.createMenuItem(StandardActions.COPY, new EditAction(StandardActions.COPY, libraryTab.frame(), stateManager))); + contextMenu.getItems().add(createCopySubMenu(libraryTab, factory, dialogService, stateManager, preferencesService, clipBoardManager)); + contextMenu.getItems().add(factory.createMenuItem(StandardActions.PASTE, new EditAction(StandardActions.PASTE, libraryTab.frame(), stateManager))); + contextMenu.getItems().add(factory.createMenuItem(StandardActions.CUT, new EditAction(StandardActions.CUT, libraryTab.frame(), stateManager))); + contextMenu.getItems().add(factory.createMenuItem(StandardActions.DELETE_ENTRY, new EditAction(StandardActions.DELETE_ENTRY, libraryTab.frame(), stateManager))); contextMenu.getItems().add(new SeparatorMenuItem()); @@ -54,12 +54,12 @@ public static ContextMenu create(BibEntryTableViewModel entry, contextMenu.getItems().add(new SeparatorMenuItem()); if (preferencesService.getSpecialFieldsPreferences().isSpecialFieldsEnabled()) { - contextMenu.getItems().add(SpecialFieldMenuItemFactory.createSpecialFieldMenu(SpecialField.RANKING, factory, panel.frame(), dialogService, stateManager)); - contextMenu.getItems().add(SpecialFieldMenuItemFactory.getSpecialFieldSingleItem(SpecialField.RELEVANCE, factory, panel.frame(), dialogService, stateManager)); - contextMenu.getItems().add(SpecialFieldMenuItemFactory.getSpecialFieldSingleItem(SpecialField.QUALITY, factory, panel.frame(), dialogService, stateManager)); - contextMenu.getItems().add(SpecialFieldMenuItemFactory.getSpecialFieldSingleItem(SpecialField.PRINTED, factory, panel.frame(), dialogService, stateManager)); - contextMenu.getItems().add(SpecialFieldMenuItemFactory.createSpecialFieldMenu(SpecialField.PRIORITY, factory, panel.frame(), dialogService, stateManager)); - contextMenu.getItems().add(SpecialFieldMenuItemFactory.createSpecialFieldMenu(SpecialField.READ_STATUS, factory, panel.frame(), dialogService, stateManager)); + contextMenu.getItems().add(SpecialFieldMenuItemFactory.createSpecialFieldMenu(SpecialField.RANKING, factory, libraryTab.frame(), dialogService, stateManager)); + contextMenu.getItems().add(SpecialFieldMenuItemFactory.getSpecialFieldSingleItem(SpecialField.RELEVANCE, factory, libraryTab.frame(), dialogService, stateManager)); + contextMenu.getItems().add(SpecialFieldMenuItemFactory.getSpecialFieldSingleItem(SpecialField.QUALITY, factory, libraryTab.frame(), dialogService, stateManager)); + contextMenu.getItems().add(SpecialFieldMenuItemFactory.getSpecialFieldSingleItem(SpecialField.PRINTED, factory, libraryTab.frame(), dialogService, stateManager)); + contextMenu.getItems().add(SpecialFieldMenuItemFactory.createSpecialFieldMenu(SpecialField.PRIORITY, factory, libraryTab.frame(), dialogService, stateManager)); + contextMenu.getItems().add(SpecialFieldMenuItemFactory.createSpecialFieldMenu(SpecialField.READ_STATUS, factory, libraryTab.frame(), dialogService, stateManager)); } contextMenu.getItems().add(new SeparatorMenuItem()); @@ -71,16 +71,16 @@ public static ContextMenu create(BibEntryTableViewModel entry, contextMenu.getItems().add(new SeparatorMenuItem()); - contextMenu.getItems().add(new ChangeEntryTypeMenu().getChangeEntryTypeMenu(entry.getEntry(), panel.getBibDatabaseContext(), panel.getUndoManager())); - contextMenu.getItems().add(factory.createMenuItem(StandardActions.MERGE_WITH_FETCHED_ENTRY, new MergeWithFetchedEntryAction(panel, dialogService, stateManager))); - contextMenu.getItems().add(factory.createMenuItem(StandardActions.ATTACH_FILE, new AttachFileAction(panel, dialogService, stateManager, preferencesService))); + contextMenu.getItems().add(new ChangeEntryTypeMenu().getChangeEntryTypeMenu(entry.getEntry(), libraryTab.getBibDatabaseContext(), libraryTab.getUndoManager())); + contextMenu.getItems().add(factory.createMenuItem(StandardActions.MERGE_WITH_FETCHED_ENTRY, new MergeWithFetchedEntryAction(libraryTab, dialogService, stateManager))); + contextMenu.getItems().add(factory.createMenuItem(StandardActions.ATTACH_FILE, new AttachFileAction(libraryTab, dialogService, stateManager, preferencesService))); // ToDo: Refactor BasePanel, see ahead. - contextMenu.getItems().add(factory.createMenuItem(StandardActions.MERGE_ENTRIES, new MergeEntriesAction(panel.frame(), dialogService, stateManager))); + contextMenu.getItems().add(factory.createMenuItem(StandardActions.MERGE_ENTRIES, new MergeEntriesAction(libraryTab.frame(), dialogService, stateManager))); return contextMenu; } - private static Menu createCopySubMenu(BasePanel panel, + private static Menu createCopySubMenu(LibraryTab libraryTab, ActionFactory factory, DialogService dialogService, StateManager stateManager, @@ -108,7 +108,7 @@ private static Menu createCopySubMenu(BasePanel panel, copySpecialMenu.getItems().add(factory.createMenuItem(StandardActions.COPY_CITATION_PREVIEW, new CopyCitationAction(CitationStyleOutputFormat.HTML, dialogService, stateManager, clipBoardManager, previewPreferences))); } - copySpecialMenu.getItems().add(factory.createMenuItem(StandardActions.EXPORT_TO_CLIPBOARD, new ExportToClipboardAction(panel, dialogService, Globals.exportFactory, clipBoardManager, Globals.TASK_EXECUTOR))); + copySpecialMenu.getItems().add(factory.createMenuItem(StandardActions.EXPORT_TO_CLIPBOARD, new ExportToClipboardAction(libraryTab, dialogService, Globals.exportFactory, clipBoardManager, Globals.TASK_EXECUTOR))); return copySpecialMenu; } } diff --git a/src/main/java/org/jabref/gui/mergeentries/FetchAndMergeEntry.java b/src/main/java/org/jabref/gui/mergeentries/FetchAndMergeEntry.java index 643f3bde53c..a64c0232111 100644 --- a/src/main/java/org/jabref/gui/mergeentries/FetchAndMergeEntry.java +++ b/src/main/java/org/jabref/gui/mergeentries/FetchAndMergeEntry.java @@ -8,9 +8,9 @@ import java.util.Set; import java.util.TreeSet; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; import org.jabref.gui.Globals; +import org.jabref.gui.LibraryTab; import org.jabref.gui.undo.NamedCompound; import org.jabref.gui.undo.UndoableChangeType; import org.jabref.gui.undo.UndoableFieldChange; @@ -39,13 +39,13 @@ public class FetchAndMergeEntry { // A list of all field which are supported public static List SUPPORTED_FIELDS = Arrays.asList(StandardField.DOI, StandardField.EPRINT, StandardField.ISBN); private static final Logger LOGGER = LoggerFactory.getLogger(FetchAndMergeEntry.class); - private final BasePanel panel; + private final LibraryTab libraryTab; private final DialogService dialogService; private final TaskExecutor taskExecutor; - public FetchAndMergeEntry(BasePanel panel, TaskExecutor taskExecutor) { - this.dialogService = panel.frame().getDialogService(); - this.panel = panel; + public FetchAndMergeEntry(LibraryTab libraryTab, TaskExecutor taskExecutor) { + this.dialogService = libraryTab.frame().getDialogService(); + this.libraryTab = libraryTab; this.taskExecutor = taskExecutor; } @@ -65,7 +65,7 @@ public void fetchAndMerge(BibEntry entry, List fields) { if (fetcher.isPresent()) { BackgroundTask.wrap(() -> fetcher.get().performSearchById(fieldContent.get())) .onSuccess(fetchedEntry -> { - ImportCleanup cleanup = new ImportCleanup(panel.getBibDatabaseContext().getMode()); + ImportCleanup cleanup = new ImportCleanup(libraryTab.getBibDatabaseContext().getMode()); cleanup.doPostCleanup(entry); String type = field.getDisplayName(); if (fetchedEntry.isPresent()) { @@ -116,7 +116,7 @@ private void showMergeDialog(BibEntry originalEntry, BibEntry fetchedEntry, WebF for (Field field : jointFields) { Optional originalString = originalEntry.getField(field); Optional mergedString = mergedEntry.get().getField(field); - if (!originalString.isPresent() || !originalString.equals(mergedString)) { + if (originalString.isEmpty() || !originalString.equals(mergedString)) { originalEntry.setField(field, mergedString.get()); // mergedString always present ce.addEdit(new UndoableFieldChange(originalEntry, field, originalString.orElse(null), mergedString.get())); @@ -136,7 +136,7 @@ private void showMergeDialog(BibEntry originalEntry, BibEntry fetchedEntry, WebF if (edited) { ce.end(); - panel.getUndoManager().addEdit(ce); + libraryTab.getUndoManager().addEdit(ce); dialogService.notify(Localization.lang("Updated entry with info from %0", fetcher.getName())); } else { dialogService.notify(Localization.lang("No information added")); @@ -150,7 +150,7 @@ public void fetchAndMerge(BibEntry entry, EntryBasedFetcher fetcher) { BackgroundTask.wrap(() -> fetcher.performSearch(entry).stream().findFirst()) .onSuccess(fetchedEntry -> { if (fetchedEntry.isPresent()) { - ImportCleanup cleanup = new ImportCleanup(panel.getBibDatabaseContext().getMode()); + ImportCleanup cleanup = new ImportCleanup(libraryTab.getBibDatabaseContext().getMode()); cleanup.doPostCleanup(fetchedEntry.get()); showMergeDialog(entry, fetchedEntry.get(), fetcher); } else { diff --git a/src/main/java/org/jabref/gui/mergeentries/MergeEntriesAction.java b/src/main/java/org/jabref/gui/mergeentries/MergeEntriesAction.java index ec1ba539807..0b1991cdff6 100644 --- a/src/main/java/org/jabref/gui/mergeentries/MergeEntriesAction.java +++ b/src/main/java/org/jabref/gui/mergeentries/MergeEntriesAction.java @@ -59,7 +59,7 @@ public void execute() { // ToDo: BibDatabase::insertEntry does not contain logic to mark the BasePanel as changed and to mark // entries with a timestamp, only BasePanel::insertEntry does. Workaround for the moment is to get the // BasePanel from the constructor injected JabRefFrame. Should be refactored and extracted! - frame.getCurrentBasePanel().insertEntry(mergedEntry.get()); + frame.getCurrentLibraryTab().insertEntry(mergedEntry.get()); // Create a new entry and add it to the undo stack // Remove the other two entries and add them to the undo stack (which is not working...) diff --git a/src/main/java/org/jabref/gui/mergeentries/MergeWithFetchedEntryAction.java b/src/main/java/org/jabref/gui/mergeentries/MergeWithFetchedEntryAction.java index 5ebfb67676e..11aeaac50e0 100644 --- a/src/main/java/org/jabref/gui/mergeentries/MergeWithFetchedEntryAction.java +++ b/src/main/java/org/jabref/gui/mergeentries/MergeWithFetchedEntryAction.java @@ -1,8 +1,8 @@ package org.jabref.gui.mergeentries; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; import org.jabref.gui.Globals; +import org.jabref.gui.LibraryTab; import org.jabref.gui.StateManager; import org.jabref.gui.actions.ActionHelper; import org.jabref.gui.actions.SimpleCommand; @@ -13,12 +13,12 @@ public class MergeWithFetchedEntryAction extends SimpleCommand { - private final BasePanel basePanel; + private final LibraryTab libraryTab; private final DialogService dialogService; private final StateManager stateManager; - public MergeWithFetchedEntryAction(BasePanel basePanel, DialogService dialogService, StateManager stateManager) { - this.basePanel = basePanel; + public MergeWithFetchedEntryAction(LibraryTab libraryTab, DialogService dialogService, StateManager stateManager) { + this.libraryTab = libraryTab; this.dialogService = dialogService; this.stateManager = stateManager; @@ -35,6 +35,6 @@ public void execute() { } BibEntry originalEntry = stateManager.getSelectedEntries().get(0); - new FetchAndMergeEntry(basePanel, Globals.TASK_EXECUTOR).fetchAndMerge(originalEntry); + new FetchAndMergeEntry(libraryTab, Globals.TASK_EXECUTOR).fetchAndMerge(originalEntry); } } diff --git a/src/main/java/org/jabref/gui/openoffice/OpenOfficePanel.java b/src/main/java/org/jabref/gui/openoffice/OpenOfficePanel.java index 41adef02303..393bc1a3fe1 100644 --- a/src/main/java/org/jabref/gui/openoffice/OpenOfficePanel.java +++ b/src/main/java/org/jabref/gui/openoffice/OpenOfficePanel.java @@ -28,10 +28,10 @@ import javafx.scene.layout.Priority; import javafx.scene.layout.VBox; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; import org.jabref.gui.Globals; import org.jabref.gui.JabRefFrame; +import org.jabref.gui.LibraryTab; import org.jabref.gui.actions.ActionFactory; import org.jabref.gui.actions.StandardActions; import org.jabref.gui.help.HelpAction; @@ -317,11 +317,11 @@ private void exportEntries() { private List getBaseList() { List databases = new ArrayList<>(); if (ooPrefs.getUseAllDatabases()) { - for (BasePanel basePanel : frame.getBasePanelList()) { - databases.add(basePanel.getDatabase()); + for (LibraryTab libraryTab : frame.getLibraryTabs()) { + databases.add(libraryTab.getDatabase()); } } else { - databases.add(frame.getCurrentBasePanel().getDatabase()); + databases.add(frame.getCurrentLibraryTab().getDatabase()); } return databases; @@ -337,7 +337,7 @@ private void connectAutomatically() { Task taskConnectIfInstalled = new Task<>() { @Override - protected Void call() throws Exception { + protected Void call() { updateProgress(ProgressBar.INDETERMINATE_PROGRESS, ProgressBar.INDETERMINATE_PROGRESS); boolean installed = officeInstallation.isInstalled(); @@ -469,10 +469,10 @@ private void pushEntries(boolean inParenthesisIn, boolean withText, boolean addP } } - BasePanel panel = frame.getCurrentBasePanel(); - if (panel != null) { - final BibDatabase database = panel.getDatabase(); - List entries = panel.getSelectedEntries(); + LibraryTab libraryTab = frame.getCurrentLibraryTab(); + if (libraryTab != null) { + final BibDatabase database = libraryTab.getDatabase(); + List entries = libraryTab.getSelectedEntries(); if (!entries.isEmpty() && checkThatEntriesHaveKeys(entries)) { try { @@ -514,7 +514,7 @@ private boolean checkThatEntriesHaveKeys(List entries) { // Check if there are empty keys boolean emptyKeys = false; for (BibEntry entry : entries) { - if (!entry.getCitationKey().isPresent()) { + if (entry.getCitationKey().isEmpty()) { // Found one, no need to look further for now emptyKeys = true; break; @@ -532,22 +532,22 @@ private boolean checkThatEntriesHaveKeys(List entries) { Localization.lang("Generate keys"), Localization.lang("Cancel")); - BasePanel panel = frame.getCurrentBasePanel(); - if (citePressed && (panel != null)) { + LibraryTab libraryTab = frame.getCurrentLibraryTab(); + if (citePressed && (libraryTab != null)) { // Generate keys CitationKeyPatternPreferences prefs = jabRefPreferences.getCitationKeyPatternPreferences(); NamedCompound undoCompound = new NamedCompound(Localization.lang("Cite")); for (BibEntry entry : entries) { - if (!entry.getCitationKey().isPresent()) { + if (entry.getCitationKey().isEmpty()) { // Generate key - new CitationKeyGenerator(panel.getBibDatabaseContext(), prefs) + new CitationKeyGenerator(libraryTab.getBibDatabaseContext(), prefs) .generateAndSetKey(entry) .ifPresent(change -> undoCompound.addEdit(new UndoableKeyChange(change))); } } undoCompound.end(); // Add all undos - panel.getUndoManager().addEdit(undoCompound); + libraryTab.getUndoManager().addEdit(undoCompound); // Now every entry has a key return true; } else { diff --git a/src/main/java/org/jabref/gui/preferences/PreferencesDialogViewModel.java b/src/main/java/org/jabref/gui/preferences/PreferencesDialogViewModel.java index 0d02d553374..a02a2bcd5d2 100644 --- a/src/main/java/org/jabref/gui/preferences/PreferencesDialogViewModel.java +++ b/src/main/java/org/jabref/gui/preferences/PreferencesDialogViewModel.java @@ -150,7 +150,7 @@ private void updateAfterPreferenceChanges() { PushToApplicationsManager manager = frame.getPushToApplicationsManager(); manager.updateApplicationAction(manager.getApplicationByName(externalApplicationsPreferences.getPushToApplicationName())); - frame.getBasePanelList().forEach(panel -> panel.getMainTable().getTableModel().refresh()); + frame.getLibraryTabs().forEach(panel -> panel.getMainTable().getTableModel().refresh()); } /** diff --git a/src/main/java/org/jabref/gui/preferences/PreviewTabViewModel.java b/src/main/java/org/jabref/gui/preferences/PreviewTabViewModel.java index 78956920079..87479ec4d1c 100644 --- a/src/main/java/org/jabref/gui/preferences/PreviewTabViewModel.java +++ b/src/main/java/org/jabref/gui/preferences/PreviewTabViewModel.java @@ -23,10 +23,10 @@ import javafx.scene.input.Dragboard; import javafx.scene.input.TransferMode; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; import org.jabref.gui.DragAndDropDataFormats; import org.jabref.gui.JabRefGUI; +import org.jabref.gui.LibraryTab; import org.jabref.gui.StateManager; import org.jabref.gui.util.BackgroundTask; import org.jabref.gui.util.CustomLocalDragboard; @@ -216,9 +216,9 @@ public void storeSettings() { preferences.storePreviewPreferences(newPreviewPreferences); - for (BasePanel basePanel : JabRefGUI.getMainFrame().getBasePanelList()) { + for (LibraryTab libraryTab : JabRefGUI.getMainFrame().getLibraryTabs()) { // TODO: Find a better way to update preview - basePanel.closeBottomPane(); + libraryTab.closeBottomPane(); // basePanel.getPreviewPanel().updateLayout(preferences.getPreviewPreferences()); } } diff --git a/src/main/java/org/jabref/gui/search/GlobalSearchBar.java b/src/main/java/org/jabref/gui/search/GlobalSearchBar.java index 6e674d584b4..9cc91baeee2 100644 --- a/src/main/java/org/jabref/gui/search/GlobalSearchBar.java +++ b/src/main/java/org/jabref/gui/search/GlobalSearchBar.java @@ -113,7 +113,7 @@ public GlobalSearchBar(JabRefFrame frame, StateManager stateManager, Preferences if (keyBinding.get().equals(KeyBinding.CLOSE)) { // Clear search and select first entry, if available searchField.setText(""); - frame.getCurrentBasePanel().getMainTable().getSelectionModel().selectFirst(); + frame.getCurrentLibraryTab().getMainTable().getSelectionModel().selectFirst(); event.consume(); } } diff --git a/src/main/java/org/jabref/gui/shared/SharedDatabaseLoginDialogViewModel.java b/src/main/java/org/jabref/gui/shared/SharedDatabaseLoginDialogViewModel.java index 845732f020a..18ffe5c365f 100644 --- a/src/main/java/org/jabref/gui/shared/SharedDatabaseLoginDialogViewModel.java +++ b/src/main/java/org/jabref/gui/shared/SharedDatabaseLoginDialogViewModel.java @@ -20,10 +20,10 @@ import javafx.scene.control.ButtonType; import org.jabref.gui.AbstractViewModel; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; import org.jabref.gui.Globals; import org.jabref.gui.JabRefFrame; +import org.jabref.gui.LibraryTab; import org.jabref.gui.exporter.SaveDatabaseAction; import org.jabref.gui.help.HelpAction; import org.jabref.gui.util.FileDialogConfiguration; @@ -87,9 +87,7 @@ public SharedDatabaseLoginDialogViewModel(JabRefFrame frame, DialogService dialo this.frame = frame; this.dialogService = dialogService; - EasyBind.subscribe(selectedDBMSType, selected -> { - port.setValue(Integer.toString(selected.getDefaultPort())); - }); + EasyBind.subscribe(selectedDBMSType, selected -> port.setValue(Integer.toString(selected.getDefaultPort()))); Predicate notEmpty = input -> (input != null) && !input.trim().isEmpty(); Predicate fileExists = input -> Files.exists(Path.of(input)); @@ -124,8 +122,7 @@ public boolean openDatabase() { .createDBMSConnectionProperties(); setupKeyStore(); - boolean connected = openSharedDatabase(connectionProperties); - return connected; + return openSharedDatabase(connectionProperties); } private void setupKeyStore() { @@ -161,12 +158,12 @@ private boolean openSharedDatabase(DBMSConnectionProperties connectionProperties try { SharedDatabaseUIManager manager = new SharedDatabaseUIManager(frame); - BasePanel panel = manager.openNewSharedDatabaseTab(connectionProperties); + LibraryTab libraryTab = manager.openNewSharedDatabaseTab(connectionProperties); setPreferences(); if (!folder.getValue().isEmpty()) { try { - new SaveDatabaseAction(panel, Globals.prefs, Globals.entryTypesManager).saveAs(Path.of(folder.getValue())); + new SaveDatabaseAction(libraryTab, Globals.prefs, Globals.entryTypesManager).saveAs(Path.of(folder.getValue())); } catch (Throwable e) { LOGGER.error("Error while saving the database", e); } @@ -255,7 +252,7 @@ private void applyPreferences() { } private boolean isSharedDatabaseAlreadyPresent(DBMSConnectionProperties connectionProperties) { - List panels = frame.getBasePanelList(); + List panels = frame.getLibraryTabs(); return panels.parallelStream().anyMatch(panel -> { BibDatabaseContext context = panel.getBibDatabaseContext(); @@ -271,9 +268,7 @@ public void showSaveDbToFileDialog() { .withInitialDirectory(Globals.prefs.get(JabRefPreferences.WORKING_DIRECTORY)) .build(); Optional exportPath = dialogService.showFileSaveDialog(fileDialogConfiguration); - exportPath.ifPresent(path -> { - folder.setValue(path.toString()); - }); + exportPath.ifPresent(path -> folder.setValue(path.toString())); } public void showOpenKeystoreFileDialog() { @@ -284,9 +279,7 @@ public void showOpenKeystoreFileDialog() { .withInitialDirectory(Globals.prefs.get(JabRefPreferences.WORKING_DIRECTORY)) .build(); Optional keystorePath = dialogService.showFileOpenDialog(fileDialogConfiguration); - keystorePath.ifPresent(path -> { - keystore.setValue(path.toString()); - }); + keystorePath.ifPresent(path -> keystore.setValue(path.toString())); } public StringProperty databaseproperty() { diff --git a/src/main/java/org/jabref/gui/shared/SharedDatabaseUIManager.java b/src/main/java/org/jabref/gui/shared/SharedDatabaseUIManager.java index 50486fca561..1127ddd1479 100644 --- a/src/main/java/org/jabref/gui/shared/SharedDatabaseUIManager.java +++ b/src/main/java/org/jabref/gui/shared/SharedDatabaseUIManager.java @@ -9,10 +9,10 @@ import javafx.scene.control.ButtonBar.ButtonData; import javafx.scene.control.ButtonType; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; import org.jabref.gui.Globals; import org.jabref.gui.JabRefFrame; +import org.jabref.gui.LibraryTab; import org.jabref.gui.entryeditor.EntryEditor; import org.jabref.gui.exporter.SaveDatabaseAction; import org.jabref.gui.mergeentries.MergeEntriesDialog; @@ -115,10 +115,10 @@ public void listen(UpdateRefusedEvent updateRefusedEvent) { @Subscribe public void listen(SharedEntriesNotPresentEvent event) { - BasePanel panel = jabRefFrame.getCurrentBasePanel(); - EntryEditor entryEditor = panel.getEntryEditor(); + LibraryTab libraryTab = jabRefFrame.getCurrentLibraryTab(); + EntryEditor entryEditor = libraryTab.getEntryEditor(); - panel.getUndoManager().addEdit(new UndoableRemoveEntries(panel.getDatabase(), event.getBibEntries())); + libraryTab.getUndoManager().addEdit(new UndoableRemoveEntries(libraryTab.getDatabase(), event.getBibEntries())); if (Objects.nonNull(entryEditor) && (event.getBibEntries().contains(entryEditor.getEntry()))) { @@ -126,7 +126,7 @@ public void listen(SharedEntriesNotPresentEvent event) { Localization.lang("The entry you currently work on has been deleted on the shared side.") + "\n" + Localization.lang("You can restore the entry using the \"Undo\" operation.")); - panel.closeBottomPane(); + libraryTab.closeBottomPane(); } } @@ -136,7 +136,7 @@ public void listen(SharedEntriesNotPresentEvent event) { * @param dbmsConnectionProperties Connection data * @return BasePanel which also used by {@link SaveDatabaseAction} */ - public BasePanel openNewSharedDatabaseTab(DBMSConnectionProperties dbmsConnectionProperties) + public LibraryTab openNewSharedDatabaseTab(DBMSConnectionProperties dbmsConnectionProperties) throws SQLException, DatabaseNotSupportedException, InvalidDBMSConnectionPropertiesException { BibDatabaseContext bibDatabaseContext = new BibDatabaseContext(); diff --git a/src/main/java/org/jabref/gui/specialfields/SpecialFieldAction.java b/src/main/java/org/jabref/gui/specialfields/SpecialFieldAction.java index 40f6567342e..4701b93a58d 100644 --- a/src/main/java/org/jabref/gui/specialfields/SpecialFieldAction.java +++ b/src/main/java/org/jabref/gui/specialfields/SpecialFieldAction.java @@ -76,9 +76,9 @@ public void execute() { } ce.end(); if (ce.hasEdits()) { - frame.getCurrentBasePanel().getUndoManager().addEdit(ce); - frame.getCurrentBasePanel().markBaseChanged(); - frame.getCurrentBasePanel().updateEntryEditorIfShowing(); + frame.getCurrentLibraryTab().getUndoManager().addEdit(ce); + frame.getCurrentLibraryTab().markBaseChanged(); + frame.getCurrentLibraryTab().updateEntryEditorIfShowing(); String outText; if (nullFieldIfValueIsTheSame || value == null) { outText = getTextDone(specialField, Integer.toString(bes.size())); diff --git a/src/main/java/org/jabref/gui/undo/UndoRedoAction.java b/src/main/java/org/jabref/gui/undo/UndoRedoAction.java index eb2e7e7cf50..9515bda0654 100644 --- a/src/main/java/org/jabref/gui/undo/UndoRedoAction.java +++ b/src/main/java/org/jabref/gui/undo/UndoRedoAction.java @@ -3,9 +3,9 @@ import javax.swing.undo.CannotRedoException; import javax.swing.undo.CannotUndoException; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; import org.jabref.gui.JabRefFrame; +import org.jabref.gui.LibraryTab; import org.jabref.gui.StateManager; import org.jabref.gui.actions.ActionHelper; import org.jabref.gui.actions.SimpleCommand; @@ -35,26 +35,26 @@ public UndoRedoAction(StandardActions action, JabRefFrame frame, DialogService d @Override public void execute() { - BasePanel panel = frame.getCurrentBasePanel(); + LibraryTab libraryTab = frame.getCurrentLibraryTab(); if (action == StandardActions.UNDO) { try { - panel.getUndoManager().undo(); - panel.markBaseChanged(); + libraryTab.getUndoManager().undo(); + libraryTab.markBaseChanged(); dialogService.notify(Localization.lang("Undo")); } catch (CannotUndoException ex) { dialogService.notify(Localization.lang("Nothing to undo") + '.'); } - frame.getCurrentBasePanel().markChangedOrUnChanged(); + frame.getCurrentLibraryTab().markChangedOrUnChanged(); } else if (action == StandardActions.REDO) { try { - panel.getUndoManager().redo(); - panel.markBaseChanged(); + libraryTab.getUndoManager().redo(); + libraryTab.markBaseChanged(); dialogService.notify(Localization.lang("Redo")); } catch (CannotRedoException ex) { dialogService.notify(Localization.lang("Nothing to redo") + '.'); } - panel.markChangedOrUnChanged(); + libraryTab.markChangedOrUnChanged(); } else { LOGGER.debug("No undo/redo action: " + action.name()); } diff --git a/src/test/java/org/jabref/gui/exporter/SaveDatabaseActionTest.java b/src/test/java/org/jabref/gui/exporter/SaveDatabaseActionTest.java index 5ee07e4d58e..d6a4e5af45d 100644 --- a/src/test/java/org/jabref/gui/exporter/SaveDatabaseActionTest.java +++ b/src/test/java/org/jabref/gui/exporter/SaveDatabaseActionTest.java @@ -10,9 +10,9 @@ import java.util.Optional; import java.util.stream.Collectors; -import org.jabref.gui.BasePanel; import org.jabref.gui.DialogService; import org.jabref.gui.JabRefFrame; +import org.jabref.gui.LibraryTab; import org.jabref.gui.undo.CountingUndoManager; import org.jabref.gui.util.FileDialogConfiguration; import org.jabref.logic.bibtex.FieldContentFormatterPreferences; @@ -48,18 +48,18 @@ class SaveDatabaseActionTest { private Path file = Path.of(TEST_BIBTEX_LIBRARY_LOCATION); private DialogService dialogService = mock(DialogService.class); private JabRefPreferences preferences = mock(JabRefPreferences.class); - private BasePanel basePanel = mock(BasePanel.class); + private LibraryTab libraryTab = mock(LibraryTab.class); private JabRefFrame jabRefFrame = mock(JabRefFrame.class); private BibDatabaseContext dbContext = spy(BibDatabaseContext.class); private SaveDatabaseAction saveDatabaseAction; @BeforeEach public void setUp() { - when(basePanel.frame()).thenReturn(jabRefFrame); - when(basePanel.getBibDatabaseContext()).thenReturn(dbContext); + when(libraryTab.frame()).thenReturn(jabRefFrame); + when(libraryTab.getBibDatabaseContext()).thenReturn(dbContext); when(jabRefFrame.getDialogService()).thenReturn(dialogService); - saveDatabaseAction = spy(new SaveDatabaseAction(basePanel, preferences, mock(BibEntryTypesManager.class))); + saveDatabaseAction = spy(new SaveDatabaseAction(libraryTab, preferences, mock(BibEntryTypesManager.class))); } @Test @@ -106,7 +106,7 @@ private SaveDatabaseAction createSaveDatabaseActionForBibDatabase(BibDatabase da SavePreferences savePreferences = mock(SavePreferences.class); // In case a "thenReturn" is modified, the whole mock has to be recreated dbContext = mock(BibDatabaseContext.class); - basePanel = mock(BasePanel.class); + libraryTab = mock(LibraryTab.class); MetaData metaData = mock(MetaData.class); when(savePreferences.withEncoding(any(Charset.class))).thenReturn(savePreferences); when(savePreferences.withSaveType(any(SavePreferences.DatabaseSaveType.class))).thenReturn(savePreferences); @@ -125,11 +125,11 @@ private SaveDatabaseAction createSaveDatabaseActionForBibDatabase(BibDatabase da when(preferences.getDefaultEncoding()).thenReturn(StandardCharsets.UTF_8); when(preferences.getFieldContentParserPreferences()).thenReturn(mock(FieldContentFormatterPreferences.class)); when(preferences.getSavePreferences()).thenReturn(savePreferences); - when(basePanel.frame()).thenReturn(jabRefFrame); - when(basePanel.getBibDatabaseContext()).thenReturn(dbContext); - when(basePanel.getUndoManager()).thenReturn(mock(CountingUndoManager.class)); - when(basePanel.getBibDatabaseContext()).thenReturn(dbContext); - saveDatabaseAction = new SaveDatabaseAction(basePanel, preferences, mock(BibEntryTypesManager.class)); + when(libraryTab.frame()).thenReturn(jabRefFrame); + when(libraryTab.getBibDatabaseContext()).thenReturn(dbContext); + when(libraryTab.getUndoManager()).thenReturn(mock(CountingUndoManager.class)); + when(libraryTab.getBibDatabaseContext()).thenReturn(dbContext); + saveDatabaseAction = new SaveDatabaseAction(libraryTab, preferences, mock(BibEntryTypesManager.class)); return saveDatabaseAction; } From f923a487fcf7da323e7a31b0e501ac58f4097541 Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Tue, 13 Oct 2020 08:14:36 +0200 Subject: [PATCH 05/20] Move title logic to LibraryTab --- src/main/java/org/jabref/gui/JabRefFrame.java | 152 ++--------------- src/main/java/org/jabref/gui/LibraryTab.java | 161 +++++++++++++++--- .../gui/exporter/SaveDatabaseAction.java | 4 +- .../gui/shared/SharedDatabaseUIManager.java | 2 +- 4 files changed, 163 insertions(+), 156 deletions(-) diff --git a/src/main/java/org/jabref/gui/JabRefFrame.java b/src/main/java/org/jabref/gui/JabRefFrame.java index 25f9e030e25..b0211176e8b 100644 --- a/src/main/java/org/jabref/gui/JabRefFrame.java +++ b/src/main/java/org/jabref/gui/JabRefFrame.java @@ -1,6 +1,5 @@ package org.jabref.gui; -import java.io.File; import java.io.IOException; import java.nio.file.Path; import java.util.ArrayList; @@ -133,7 +132,6 @@ import org.jabref.logic.undo.UndoChangeEvent; import org.jabref.logic.undo.UndoRedoEvent; import org.jabref.logic.util.OS; -import org.jabref.logic.util.io.FileUtil; import org.jabref.model.database.BibDatabaseContext; import org.jabref.model.entry.field.SpecialField; import org.jabref.model.entry.types.StandardEntryType; @@ -187,6 +185,20 @@ public JabRefFrame(Stage mainStage) { } } }); + + Platform.runLater(() -> { + EasyBind.subscribe(tabbedPane.getSelectionModel().selectedItemProperty(), tab -> { + if (tab != null) { + LibraryTab libraryTab = (LibraryTab) tab; + StringBuilder windowTitle = new StringBuilder(libraryTab.nameProperty().get()); + windowTitle.append(" \u2013 "); + windowTitle.append(FRAME_TITLE); + mainStage.setTitle(windowTitle.toString()); + } else { + mainStage.setTitle(FRAME_TITLE); + } + }); + }); } private void initDragAndDrop() { @@ -308,129 +320,6 @@ private Void showTrackingNotification() { return null; } - /** - * Determines the titles of all tabs - and the window title. - * - * We aim for following in a tab: - * - * filename (datbase-mode) – path-fragment – JabRef - * - * path-fragment is only shown if filename is not (globally) unique - * - * Example: - * - * jabref-authors.bib (BibLaTeX) – testbib – JabRef - * - * For the JabRef window, it should be - * - * full-path (database-mode) – JabRef - * - * Example: - * - * C:\git-repositories\jabref\src\test\resources\testbib\jabref-authors.bib (BibLaTeX) – JabRef - */ - public void refreshWindowAndTabTitles() { - DefaultTaskExecutor.runInJavaFXThread(() -> { - int selectedTabIndex = tabbedPane.getSelectionModel().getSelectedIndex(); - boolean isAutosaveEnabled = Globals.prefs.getBoolean(JabRefPreferences.LOCAL_AUTO_SAVE); - - List uniquePathParts = getUniquePathParts(); - for (int i = 0; i < getBasePanelCount(); i++) { - LibraryTab libraryTab = getLibraryTabAt(i); - BibDatabaseContext bibDatabaseContext = libraryTab.getBibDatabaseContext(); - DatabaseLocation databaseLocation = bibDatabaseContext.getLocation(); - Optional file = bibDatabaseContext.getDatabasePath(); - - StringBuilder tabTitle = new StringBuilder(); - StringBuilder toolTipText = new StringBuilder(); - StringBuilder windowTitle = new StringBuilder(); - - if (file.isPresent()) { - Path databasePath = file.get(); - String fileName = databasePath.getFileName().toString(); - tabTitle.append(fileName); - windowTitle.append(fileName); - toolTipText.append(databasePath.toAbsolutePath().toString()); - if (libraryTab.isModified() && !isAutosaveEnabled) { - tabTitle.append('*'); - windowTitle.append('*'); - } - - if (databaseLocation == DatabaseLocation.SHARED) { - tabTitle.append(" \u2013 "); - addSharedDbInformation(tabTitle, bibDatabaseContext); - toolTipText.append(' '); - addSharedDbInformation(toolTipText, bibDatabaseContext); - windowTitle.append(" \u2013 "); - addSharedDbInformation(windowTitle, bibDatabaseContext); - } - - addModeInfo(toolTipText, bibDatabaseContext); - addModeInfo(windowTitle, bibDatabaseContext); - - if (libraryTab.isModified() && !isAutosaveEnabled) { - addChangedInformation(toolTipText, fileName); - } - - String uniquePath = uniquePathParts.get(i); - if (!uniquePath.equals(fileName) && uniquePath.contains(File.separator)) { - // remove filename - uniquePath = uniquePath.substring(0, uniquePath.lastIndexOf(File.separator)); - tabTitle.append(" \u2013 ").append(uniquePath); - windowTitle.append(" \u2013 ").append(uniquePath); - } - } else { - if (databaseLocation == DatabaseLocation.LOCAL) { - tabTitle.append(Localization.lang("untitled")); - windowTitle.append(Localization.lang("untitled")); - if (bibDatabaseContext.getDatabase().hasEntries()) { - // if the database is not empty and no file is assigned, - // the database came from an import and has to be treated somehow - // -> mark as changed - tabTitle.append('*'); - windowTitle.append('*'); - } - } else { - addSharedDbInformation(tabTitle, bibDatabaseContext); - addSharedDbInformation(toolTipText, bibDatabaseContext); - } - addModeInfo(toolTipText, bibDatabaseContext); - addModeInfo(windowTitle, bibDatabaseContext); - if (databaseLocation == DatabaseLocation.LOCAL && bibDatabaseContext.getDatabase().hasEntries()) { - addChangedInformation(toolTipText, Localization.lang("untitled")); - } - } - - tabbedPane.getTabs().get(i).setText(tabTitle.toString()); - tabbedPane.getTabs().get(i).setTooltip(new Tooltip(toolTipText.toString())); - - if (i == selectedTabIndex) { - windowTitle.append(" \u2013 "); - windowTitle.append(FRAME_TITLE); - mainStage.setTitle(windowTitle.toString()); - } - } - }); - } - - private void addChangedInformation(StringBuilder text, String fileName) { - text.append(". "); - text.append(Localization.lang("Library '%0' has changed.", fileName)); - } - - private void addModeInfo(StringBuilder text, BibDatabaseContext bibDatabaseContext) { - String mode = bibDatabaseContext.getMode().getFormattedName(); - String modeInfo = String.format(" (%s)", Localization.lang("%0 mode", mode)); - text.append(modeInfo); - } - - private void addSharedDbInformation(StringBuilder text, BibDatabaseContext bibDatabaseContext) { - text.append(bibDatabaseContext.getDBMSSynchronizer().getDBName()); - text.append(" ["); - text.append(Localization.lang("shared")); - text.append("]"); - } - /** * The MacAdapter calls this method when a "BIB" file has been double-clicked from the Finder. */ @@ -746,7 +635,7 @@ public void init() { // We need to refresh the window title only // There is currently no optimized method to set the title only (because that lead to code duplication) // Thus, we refresh everything - refreshWindowAndTabTitles(); + // refreshWindowAndTabTitles(); // Update search autocompleter with information for the correct database: newLibraryTab.updateSearchManager(); @@ -1125,7 +1014,7 @@ public void setupAllTables() { }); } - private List collectDatabaseFilePaths() { + public List collectDatabaseFilePaths() { List dbPaths = new ArrayList<>(getBasePanelCount()); for (LibraryTab libraryTab : getLibraryTabs()) { @@ -1139,11 +1028,6 @@ private List collectDatabaseFilePaths() { return dbPaths; } - private List getUniquePathParts() { - List dbPaths = collectDatabaseFilePaths(); - return FileUtil.uniquePathSubstrings(dbPaths); - } - private ContextMenu createTabContextMenu(KeyBindingRepository keyBindingRepository) { ContextMenu contextMenu = new ContextMenu(); ActionFactory factory = new ActionFactory(keyBindingRepository); @@ -1172,7 +1056,7 @@ public void addTab(LibraryTab libraryTab, boolean raisePanel) { libraryTab.setContextMenu(createTabContextMenu(Globals.getKeyPrefs())); - refreshWindowAndTabTitles(); + // refreshWindowAndTabTitles(); if (raisePanel) { tabbedPane.getSelectionModel().select(libraryTab); @@ -1304,7 +1188,7 @@ private void removeTab(LibraryTab libraryTab) { DefaultTaskExecutor.runInJavaFXThread(() -> { libraryTab.cleanUp(); tabbedPane.getTabs().remove(libraryTab); - this.refreshWindowAndTabTitles(); + // this.refreshWindowAndTabTitles(); }); } diff --git a/src/main/java/org/jabref/gui/LibraryTab.java b/src/main/java/org/jabref/gui/LibraryTab.java index 94a0dca7ee7..83f47c2b6d3 100644 --- a/src/main/java/org/jabref/gui/LibraryTab.java +++ b/src/main/java/org/jabref/gui/LibraryTab.java @@ -7,10 +7,15 @@ import java.util.Optional; import javafx.application.Platform; +import javafx.beans.property.BooleanProperty; +import javafx.beans.property.SimpleBooleanProperty; +import javafx.beans.property.SimpleStringProperty; +import javafx.beans.property.StringProperty; import javafx.geometry.Orientation; import javafx.scene.Node; import javafx.scene.control.SplitPane; import javafx.scene.control.Tab; +import javafx.scene.control.Tooltip; import org.jabref.gui.autocompleter.AutoCompletePreferences; import org.jabref.gui.autocompleter.PersonNameSuggestionProvider; @@ -32,7 +37,9 @@ import org.jabref.logic.l10n.Localization; import org.jabref.logic.pdf.FileAnnotationCache; import org.jabref.logic.search.SearchQuery; +import org.jabref.logic.shared.DatabaseLocation; import org.jabref.logic.util.UpdateField; +import org.jabref.logic.util.io.FileUtil; import org.jabref.model.FieldChange; import org.jabref.model.database.BibDatabase; import org.jabref.model.database.BibDatabaseContext; @@ -77,9 +84,12 @@ public class LibraryTab extends Tab { private DatabaseChangePane changePane; private boolean saving; private PersonNameSuggestionProvider searchAutoCompleter; - private boolean baseChanged; - private boolean nonUndoableChange; + + private BooleanProperty baseChanged = new SimpleBooleanProperty(false); + private BooleanProperty nonUndoableChange = new SimpleBooleanProperty(false); // Used to track whether the base has changed since last save. + + private StringProperty nameProperty = new SimpleStringProperty(); private BibEntry showing; private SuggestionProviders suggestionProviders; @SuppressWarnings({"FieldCanBeLocal"}) private Subscription dividerPositionSubscription; @@ -118,11 +128,124 @@ public LibraryTab(JabRefFrame frame, BasePanelPreferences preferences, BibDataba this.getDatabase().registerListener(new UpdateTimestampListener(Globals.prefs)); this.entryEditor = new EntryEditor(this, externalFileTypes); + + EasyBind.subscribe(baseChanged, this::refreshTabTitle); + } + + /** + * Determines the title of the tab + * + * We aim for following in a tab: + * + * filename (datbase-mode) – path-fragment – JabRef + * + * path-fragment is only shown if filename is not (globally) unique + * + * Example: + * + * jabref-authors.bib (BibLaTeX) – testbib – JabRef + * + * For the JabRef window, it should be + * + * full-path (database-mode) – JabRef + * + * Example: + * + * C:\git-repositories\jabref\src\test\resources\testbib\jabref-authors.bib (BibLaTeX) – JabRef + */ + private void refreshTabTitle(boolean isChanged) { + boolean isAutosaveEnabled = Globals.prefs.getBoolean(JabRefPreferences.LOCAL_AUTO_SAVE); + + DatabaseLocation databaseLocation = bibDatabaseContext.getLocation(); + Optional file = bibDatabaseContext.getDatabasePath(); + + StringBuilder tabTitle = new StringBuilder(); + StringBuilder toolTipText = new StringBuilder(); + StringBuilder tabName = new StringBuilder(); + + if (file.isPresent()) { + Path databasePath = file.get(); + String fileName = databasePath.getFileName().toString(); + tabTitle.append(fileName); + tabName.append(fileName); + toolTipText.append(databasePath.toAbsolutePath().toString()); + if (isChanged && !isAutosaveEnabled) { + tabTitle.append('*'); + } + + if (databaseLocation == DatabaseLocation.SHARED) { + tabTitle.append(" \u2013 "); + addSharedDbInformation(tabTitle, bibDatabaseContext); + toolTipText.append(' '); + addSharedDbInformation(toolTipText, bibDatabaseContext); + tabName.append(" \u2013 "); + addSharedDbInformation(tabName, bibDatabaseContext); + } + + addModeInfo(toolTipText, bibDatabaseContext); + addModeInfo(tabName, bibDatabaseContext); + + if (isChanged && !isAutosaveEnabled) { + addChangedInformation(toolTipText, fileName); + } + + List uniquePathParts = FileUtil.uniquePathSubstrings(frame.collectDatabaseFilePaths()); + + // String uniquePath = uniquePathParts.get(i); + /* if (!uniquePath.equals(fileName) && uniquePath.contains(File.separator)) { + // remove filename + uniquePath = uniquePath.substring(0, uniquePath.lastIndexOf(File.separator)); + tabTitle.append(" \u2013 ").append(uniquePath); + tabName.append(" \u2013 ").append(uniquePath); + } */ + } else { + if (databaseLocation == DatabaseLocation.LOCAL) { + tabTitle.append(Localization.lang("untitled")); + tabName.append(Localization.lang("untitled")); + if (bibDatabaseContext.getDatabase().hasEntries()) { + // if the database is not empty and no file is assigned, + // the database came from an import and has to be treated somehow + // -> mark as changed + tabTitle.append('*'); + tabName.append('*'); + } + } else { + addSharedDbInformation(tabTitle, bibDatabaseContext); + addSharedDbInformation(toolTipText, bibDatabaseContext); + } + addModeInfo(toolTipText, bibDatabaseContext); + addModeInfo(tabName, bibDatabaseContext); + if (databaseLocation == DatabaseLocation.LOCAL && bibDatabaseContext.getDatabase().hasEntries()) { + addChangedInformation(toolTipText, Localization.lang("untitled")); + } + } + + textProperty().setValue(tabTitle.toString()); + nameProperty.setValue(tabName.toString()); + setTooltip(new Tooltip(toolTipText.toString())); + } + + private static void addChangedInformation(StringBuilder text, String fileName) { + text.append(". "); + text.append(Localization.lang("Library '%0' has changed.", fileName)); + } + + private static void addModeInfo(StringBuilder text, BibDatabaseContext bibDatabaseContext) { + String mode = bibDatabaseContext.getMode().getFormattedName(); + String modeInfo = String.format(" (%s)", Localization.lang("%0 mode", mode)); + text.append(modeInfo); + } + + private static void addSharedDbInformation(StringBuilder text, BibDatabaseContext bibDatabaseContext) { + text.append(bibDatabaseContext.getDBMSSynchronizer().getDBName()); + text.append(" ["); + text.append(Localization.lang("shared")); + text.append("]"); } @Subscribe public void listen(BibDatabaseContextChangedEvent event) { - this.markBaseChanged(); + this.baseChanged.setValue(true); } /** @@ -133,7 +256,7 @@ public SuggestionProviders getSuggestionProviders() { } public boolean isModified() { - return baseChanged; + return baseChanged.getValue(); } public BasePanelMode getMode() { @@ -176,7 +299,7 @@ private void delete(boolean cut, List entries) { bibDatabaseContext.getDatabase().removeEntries(entries); ensureNotShowingBottomPanel(entries); - markBaseChanged(); + this.baseChanged.setValue(true); dialogService.notify(formatOutputMessage(cut ? Localization.lang("Cut") : Localization.lang("Deleted"), entries.size())); // prevent the main table from loosing focus @@ -227,7 +350,7 @@ public void insertEntries(final List entries) { // Create an UndoableInsertEntries object. getUndoManager().addEdit(new UndoableInsertEntries(bibDatabaseContext.getDatabase(), entries)); - markBaseChanged(); // The database just changed. + this.baseChanged.setValue(true); // The database just changed. if (Globals.prefs.getBoolean(JabRefPreferences.AUTO_OPEN_FORM)) { showAndEdit(entries.get(0)); } @@ -293,7 +416,7 @@ public void setupMainPanel() { // if the database is not empty and no file is assigned, // the database came from an import and has to be treated somehow // -> mark as changed - this.baseChanged = true; + this.baseChanged.setValue(true); } changePane = null; this.setContent(splitPane); @@ -425,24 +548,20 @@ public void updateEntryEditorIfShowing() { * Put an asterisk behind the filename to indicate the database has changed. */ public void markBaseChanged() { - baseChanged = true; - frame.refreshWindowAndTabTitles(); + this.baseChanged.setValue(true); } public void markNonUndoableBaseChanged() { - nonUndoableChange = true; - markBaseChanged(); + this.nonUndoableChange.setValue(true); + this.baseChanged.setValue(true); } public synchronized void markChangedOrUnChanged() { if (getUndoManager().hasChanged()) { - if (!baseChanged) { - markBaseChanged(); - } - } else if (baseChanged && !nonUndoableChange) { - baseChanged = false; + this.baseChanged.setValue(true); + } else if (baseChanged.getValue() && !nonUndoableChange.getValue()) { + this.baseChanged.setValue(false); } - frame.refreshWindowAndTabTitles(); } public BibDatabase getDatabase() { @@ -509,11 +628,11 @@ public SidePaneManager getSidePaneManager() { } public void setNonUndoableChange(boolean nonUndoableChange) { - this.nonUndoableChange = nonUndoableChange; + this.nonUndoableChange.setValue(nonUndoableChange); } public void setBaseChanged(boolean baseChanged) { - this.baseChanged = baseChanged; + this.baseChanged.setValue(baseChanged); } public boolean isSaving() { @@ -580,6 +699,10 @@ public void cut() { mainTable.cut(); } + public StringProperty nameProperty() { + return nameProperty; + } + private class GroupTreeListener { @Subscribe diff --git a/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java b/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java index 6164ed5ef5a..970011bcfd6 100644 --- a/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java +++ b/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java @@ -129,7 +129,7 @@ boolean saveAs(Path file, SaveDatabaseMode mode) { // we managed to successfully save the file // thus, we can store the store the path into the context context.setDatabasePath(file); - frame.refreshWindowAndTabTitles(); + // frame.refreshWindowAndTabTitles(); // Reinstall AutosaveManager and BackupManager for the new file name panel.resetChangeMonitorAndChangePane(); @@ -200,7 +200,7 @@ private boolean save(Path targetPath, SaveDatabaseMode mode) { panel.setNonUndoableChange(false); panel.setBaseChanged(false); - frame.refreshWindowAndTabTitles(); + // frame.refreshWindowAndTabTitles(); } return success; } catch (SaveException ex) { diff --git a/src/main/java/org/jabref/gui/shared/SharedDatabaseUIManager.java b/src/main/java/org/jabref/gui/shared/SharedDatabaseUIManager.java index 1127ddd1479..a089aadf723 100644 --- a/src/main/java/org/jabref/gui/shared/SharedDatabaseUIManager.java +++ b/src/main/java/org/jabref/gui/shared/SharedDatabaseUIManager.java @@ -66,7 +66,7 @@ public void listen(ConnectionLostEvent connectionLostEvent) { new SharedDatabaseLoginDialogView(jabRefFrame).showAndWait(); } else if (answer.get().equals(workOffline)) { connectionLostEvent.getBibDatabaseContext().convertToLocalDatabase(); - jabRefFrame.refreshWindowAndTabTitles(); + // jabRefFrame.refreshWindowAndTabTitles(); jabRefFrame.getDialogService().notify(Localization.lang("Working offline.")); } } else { From ed3fc40cf464dc6c506a40616ec7307fd68c174e Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Fri, 16 Oct 2020 15:39:58 +0200 Subject: [PATCH 06/20] Refactored property methods and removed unused code --- src/main/java/org/jabref/gui/LibraryTab.java | 71 +++++++++---------- .../gui/exporter/SaveDatabaseAction.java | 4 +- 2 files changed, 34 insertions(+), 41 deletions(-) diff --git a/src/main/java/org/jabref/gui/LibraryTab.java b/src/main/java/org/jabref/gui/LibraryTab.java index 83f47c2b6d3..4b5a3992bce 100644 --- a/src/main/java/org/jabref/gui/LibraryTab.java +++ b/src/main/java/org/jabref/gui/LibraryTab.java @@ -85,8 +85,8 @@ public class LibraryTab extends Tab { private boolean saving; private PersonNameSuggestionProvider searchAutoCompleter; - private BooleanProperty baseChanged = new SimpleBooleanProperty(false); - private BooleanProperty nonUndoableChange = new SimpleBooleanProperty(false); + private BooleanProperty changedProperty = new SimpleBooleanProperty(false); + private BooleanProperty nonUndoableChangeProperty = new SimpleBooleanProperty(false); // Used to track whether the base has changed since last save. private StringProperty nameProperty = new SimpleStringProperty(); @@ -129,7 +129,7 @@ public LibraryTab(JabRefFrame frame, BasePanelPreferences preferences, BibDataba this.entryEditor = new EntryEditor(this, externalFileTypes); - EasyBind.subscribe(baseChanged, this::refreshTabTitle); + EasyBind.subscribe(changedProperty, this::refreshTabTitle); } /** @@ -245,7 +245,7 @@ private static void addSharedDbInformation(StringBuilder text, BibDatabaseContex @Subscribe public void listen(BibDatabaseContextChangedEvent event) { - this.baseChanged.setValue(true); + this.changedProperty.setValue(true); } /** @@ -255,9 +255,7 @@ public SuggestionProviders getSuggestionProviders() { return suggestionProviders; } - public boolean isModified() { - return baseChanged.getValue(); - } + public BasePanelMode getMode() { return mode; @@ -299,7 +297,7 @@ private void delete(boolean cut, List entries) { bibDatabaseContext.getDatabase().removeEntries(entries); ensureNotShowingBottomPanel(entries); - this.baseChanged.setValue(true); + this.changedProperty.setValue(true); dialogService.notify(formatOutputMessage(cut ? Localization.lang("Cut") : Localization.lang("Deleted"), entries.size())); // prevent the main table from loosing focus @@ -350,7 +348,7 @@ public void insertEntries(final List entries) { // Create an UndoableInsertEntries object. getUndoManager().addEdit(new UndoableInsertEntries(bibDatabaseContext.getDatabase(), entries)); - this.baseChanged.setValue(true); // The database just changed. + this.changedProperty.setValue(true); // The database just changed. if (Globals.prefs.getBoolean(JabRefPreferences.AUTO_OPEN_FORM)) { showAndEdit(entries.get(0)); } @@ -416,7 +414,7 @@ public void setupMainPanel() { // if the database is not empty and no file is assigned, // the database came from an import and has to be treated somehow // -> mark as changed - this.baseChanged.setValue(true); + this.changedProperty.setValue(true); } changePane = null; this.setContent(splitPane); @@ -498,16 +496,6 @@ public void clearAndSelect(final BibEntry bibEntry) { mainTable.clearAndSelect(bibEntry); } - /** - * Select and open entry editor for first entry in main table. - */ - private void clearAndSelectFirst() { - mainTable.clearAndSelectFirst(); - if (!mainTable.getSelectedEntries().isEmpty()) { - showAndEdit(mainTable.getSelectedEntries().get(0)); - } - } - public void selectPreviousEntry() { mainTable.getSelectionModel().clearAndSelect(mainTable.getSelectionModel().getSelectedIndex() - 1); } @@ -547,20 +535,12 @@ public void updateEntryEditorIfShowing() { /** * Put an asterisk behind the filename to indicate the database has changed. */ - public void markBaseChanged() { - this.baseChanged.setValue(true); - } - - public void markNonUndoableBaseChanged() { - this.nonUndoableChange.setValue(true); - this.baseChanged.setValue(true); - } public synchronized void markChangedOrUnChanged() { if (getUndoManager().hasChanged()) { - this.baseChanged.setValue(true); - } else if (baseChanged.getValue() && !nonUndoableChange.getValue()) { - this.baseChanged.setValue(false); + this.changedProperty.setValue(true); + } else if (changedProperty.getValue() && !nonUndoableChangeProperty.getValue()) { + this.changedProperty.setValue(false); } } @@ -627,14 +607,6 @@ public SidePaneManager getSidePaneManager() { return sidePaneManager; } - public void setNonUndoableChange(boolean nonUndoableChange) { - this.nonUndoableChange.setValue(nonUndoableChange); - } - - public void setBaseChanged(boolean baseChanged) { - this.baseChanged.setValue(baseChanged); - } - public boolean isSaving() { return saving; } @@ -703,6 +675,27 @@ public StringProperty nameProperty() { return nameProperty; } + public BooleanProperty changedProperty() { + return changedProperty; + } + + public boolean isModified() { + return changedProperty.getValue(); + } + + public void markBaseChanged() { + this.changedProperty.setValue(true); + } + + public BooleanProperty nonUndoableChangeProperty() { + return nonUndoableChangeProperty; + } + + public void markNonUndoableBaseChanged() { + this.nonUndoableChangeProperty.setValue(true); + this.changedProperty.setValue(true); + } + private class GroupTreeListener { @Subscribe diff --git a/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java b/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java index 970011bcfd6..759f8f9ecd5 100644 --- a/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java +++ b/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java @@ -197,8 +197,8 @@ private boolean save(Path targetPath, SaveDatabaseMode mode) { if (success) { panel.getUndoManager().markUnchanged(); // After a successful save the following statement marks that the base is unchanged since last save - panel.setNonUndoableChange(false); - panel.setBaseChanged(false); + panel.nonUndoableChangeProperty().setValue(false); + panel.changedProperty().setValue(false); // frame.refreshWindowAndTabTitles(); } From 9d78f281f48b9c3548787a4a02ef16d574773904 Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Fri, 16 Oct 2020 16:34:41 +0200 Subject: [PATCH 07/20] Removed BasePanelPreferences.java --- .../org/jabref/gui/BasePanelPreferences.java | 79 ------------------- src/main/java/org/jabref/gui/JabRefFrame.java | 6 +- src/main/java/org/jabref/gui/LibraryTab.java | 36 ++++----- .../java/org/jabref/gui/StateManager.java | 4 +- .../entryeditor/EntryEditorPreferences.java | 14 +++- .../importer/actions/OpenDatabaseAction.java | 3 +- .../preferences/EntryEditorTabViewModel.java | 15 ++-- .../jabref/preferences/JabRefPreferences.java | 4 +- 8 files changed, 42 insertions(+), 119 deletions(-) delete mode 100644 src/main/java/org/jabref/gui/BasePanelPreferences.java diff --git a/src/main/java/org/jabref/gui/BasePanelPreferences.java b/src/main/java/org/jabref/gui/BasePanelPreferences.java deleted file mode 100644 index bc95224afa6..00000000000 --- a/src/main/java/org/jabref/gui/BasePanelPreferences.java +++ /dev/null @@ -1,79 +0,0 @@ -package org.jabref.gui; - -import javafx.beans.property.DoubleProperty; -import javafx.beans.property.SimpleDoubleProperty; - -import org.jabref.gui.autocompleter.AutoCompletePreferences; -import org.jabref.gui.entryeditor.EntryEditorPreferences; -import org.jabref.gui.keyboard.KeyBindingRepository; -import org.jabref.gui.maintable.MainTablePreferences; -import org.jabref.preferences.JabRefPreferences; -import org.jabref.preferences.PreviewPreferences; - -import com.tobiasdiez.easybind.EasyBind; - -public class BasePanelPreferences { - private final MainTablePreferences tablePreferences; - private AutoCompletePreferences autoCompletePreferences; - private final EntryEditorPreferences entryEditorPreferences; - private final KeyBindingRepository keyBindings; - private final PreviewPreferences previewPreferences; - private final DoubleProperty entryEditorDividerPosition = new SimpleDoubleProperty(); - - public BasePanelPreferences(MainTablePreferences tablePreferences, AutoCompletePreferences autoCompletePreferences, EntryEditorPreferences entryEditorPreferences, KeyBindingRepository keyBindings, PreviewPreferences previewPreferences, Double entryEditorDividerPosition) { - this.tablePreferences = tablePreferences; - this.autoCompletePreferences = autoCompletePreferences; - this.entryEditorPreferences = entryEditorPreferences; - this.keyBindings = keyBindings; - this.previewPreferences = previewPreferences; - this.entryEditorDividerPosition.setValue(entryEditorDividerPosition); - } - - public static BasePanelPreferences from(JabRefPreferences preferences) { - BasePanelPreferences basePanelPreferences = new BasePanelPreferences( - preferences.getMainTablePreferences(), - preferences.getAutoCompletePreferences(), - preferences.getEntryEditorPreferences(), - Globals.getKeyPrefs(), - preferences.getPreviewPreferences(), - preferences.getDouble(JabRefPreferences.ENTRY_EDITOR_HEIGHT)); - EasyBind.subscribe(basePanelPreferences.entryEditorDividerPosition, value -> preferences.putDouble(JabRefPreferences.ENTRY_EDITOR_HEIGHT, value.doubleValue())); - return basePanelPreferences; - } - - public double getEntryEditorDividerPosition() { - return entryEditorDividerPosition.get(); - } - - public void setEntryEditorDividerPosition(double entryEditorDividerPosition) { - this.entryEditorDividerPosition.set(entryEditorDividerPosition); - } - - public DoubleProperty entryEditorDividerPositionProperty() { - return entryEditorDividerPosition; - } - - public MainTablePreferences getTablePreferences() { - return tablePreferences; - } - - public AutoCompletePreferences getAutoCompletePreferences() { - return autoCompletePreferences; - } - - public void setAutoCompletePreferences(AutoCompletePreferences autoCompletePreferences) { - this.autoCompletePreferences = autoCompletePreferences; - } - - public EntryEditorPreferences getEntryEditorPreferences() { - return entryEditorPreferences; - } - - public KeyBindingRepository getKeyBindings() { - return keyBindings; - } - - public PreviewPreferences getPreviewPreferences() { - return previewPreferences; - } -} diff --git a/src/main/java/org/jabref/gui/JabRefFrame.java b/src/main/java/org/jabref/gui/JabRefFrame.java index b0211176e8b..64462f161db 100644 --- a/src/main/java/org/jabref/gui/JabRefFrame.java +++ b/src/main/java/org/jabref/gui/JabRefFrame.java @@ -1087,9 +1087,9 @@ private void trackOpenNewDatabase(LibraryTab libraryTab) { public LibraryTab addTab(BibDatabaseContext databaseContext, boolean raisePanel) { Objects.requireNonNull(databaseContext); - LibraryTab bp = new LibraryTab(this, BasePanelPreferences.from(Globals.prefs), databaseContext, ExternalFileTypes.getInstance()); - addTab(bp, raisePanel); - return bp; + LibraryTab libraryTab = new LibraryTab(this, prefs, databaseContext, ExternalFileTypes.getInstance()); + addTab(libraryTab, raisePanel); + return libraryTab; } private boolean readyForAutosave(BibDatabaseContext context) { diff --git a/src/main/java/org/jabref/gui/LibraryTab.java b/src/main/java/org/jabref/gui/LibraryTab.java index 4b5a3992bce..364134b1412 100644 --- a/src/main/java/org/jabref/gui/LibraryTab.java +++ b/src/main/java/org/jabref/gui/LibraryTab.java @@ -52,6 +52,7 @@ import org.jabref.model.entry.field.Field; import org.jabref.model.entry.field.FieldFactory; import org.jabref.preferences.JabRefPreferences; +import org.jabref.preferences.PreferencesService; import com.google.common.eventbus.Subscribe; import com.tobiasdiez.easybind.EasyBind; @@ -77,8 +78,9 @@ public class LibraryTab extends Tab { private final EntryEditor entryEditor; private final DialogService dialogService; + private final PreferencesService preferencesService; + private MainTable mainTable; - private BasePanelPreferences preferences; private BasePanelMode mode = BasePanelMode.SHOWING_NOTHING; private SplitPane splitPane; private DatabaseChangePane changePane; @@ -97,13 +99,16 @@ public class LibraryTab extends Tab { private Optional currentSearchQuery = Optional.empty(); private Optional changeMonitor = Optional.empty(); - public LibraryTab(JabRefFrame frame, BasePanelPreferences preferences, BibDatabaseContext bibDatabaseContext, ExternalFileTypes externalFileTypes) { - this.preferences = Objects.requireNonNull(preferences); + public LibraryTab(JabRefFrame frame, + PreferencesService preferencesService, + BibDatabaseContext bibDatabaseContext, + ExternalFileTypes externalFileTypes) { this.frame = Objects.requireNonNull(frame); this.bibDatabaseContext = Objects.requireNonNull(bibDatabaseContext); this.externalFileTypes = Objects.requireNonNull(externalFileTypes); this.undoManager = frame.getUndoManager(); this.dialogService = frame.getDialogService(); + this.preferencesService = Objects.requireNonNull(preferencesService); bibDatabaseContext.getDatabase().registerListener(this); bibDatabaseContext.getMetaData().registerListener(this); @@ -255,8 +260,6 @@ public SuggestionProviders getSuggestionProviders() { return suggestionProviders; } - - public BasePanelMode getMode() { return mode; } @@ -342,8 +345,8 @@ public void insertEntries(final List entries) { UpdateField.setAutomaticFields(entry, true, true, - Globals.prefs.getOwnerPreferences(), - Globals.prefs.getTimestampPreferences()); + preferencesService.getOwnerPreferences(), + preferencesService.getTimestampPreferences()); } // Create an UndoableInsertEntries object. getUndoManager().addEdit(new UndoableInsertEntries(bibDatabaseContext.getDatabase(), entries)); @@ -375,7 +378,7 @@ private void createMainTable() { dialogService, Globals.stateManager, externalFileTypes, - preferences.getKeyBindings()); + Globals.getKeyPrefs()); // Add the listener that binds selection to state manager (TODO: should be replaced by proper JavaFX binding as soon as table is implemented in JavaFX) mainTable.addSelectionListener(listEvent -> Globals.stateManager.setSelectedEntries(mainTable.getSelectedEntries())); @@ -388,11 +391,8 @@ private void createMainTable() { } public void setupMainPanel() { - preferences = BasePanelPreferences.from(Globals.prefs); - splitPane = new SplitPane(); splitPane.setOrientation(Orientation.VERTICAL); - adjustSplitter(); // restore last splitting state (before mainTable is created as creation affects the stored size of the entryEditors) createMainTable(); @@ -425,7 +425,7 @@ public void setupMainPanel() { * Set up auto completion for this database */ private void setupAutoCompletion() { - AutoCompletePreferences autoCompletePreferences = preferences.getAutoCompletePreferences(); + AutoCompletePreferences autoCompletePreferences = preferencesService.getAutoCompletePreferences(); if (autoCompletePreferences.shouldAutoComplete()) { suggestionProviders = new SuggestionProviders(getDatabase(), Globals.journalAbbreviationRepository); } else { @@ -439,12 +439,6 @@ public void updateSearchManager() { frame.getGlobalSearchBar().setAutoCompleter(searchAutoCompleter); } - private void adjustSplitter() { - if (mode == BasePanelMode.SHOWING_EDITOR) { - splitPane.setDividerPositions(preferences.getEntryEditorDividerPosition()); - } - } - public EntryEditor getEntryEditor() { return entryEditor; } @@ -477,7 +471,8 @@ private void showBottomPane(BasePanelMode newMode) { splitPane.getItems().add(1, pane); } mode = newMode; - adjustSplitter(); + + splitPane.setDividerPositions(preferencesService.getEntryEditorPreferences().getDividerPosition()); } /** @@ -578,7 +573,8 @@ private boolean showDeleteConfirmationDialog(int numberOfEntries) { */ private void saveDividerLocation(Number position) { if (mode == BasePanelMode.SHOWING_EDITOR) { - preferences.setEntryEditorDividerPosition(position.doubleValue()); + preferencesService.storeEntryEditorPreferences( + preferencesService.getEntryEditorPreferences().withDividerPosition(position.doubleValue())); } } diff --git a/src/main/java/org/jabref/gui/StateManager.java b/src/main/java/org/jabref/gui/StateManager.java index 7554467b7ed..c049c3fab3a 100644 --- a/src/main/java/org/jabref/gui/StateManager.java +++ b/src/main/java/org/jabref/gui/StateManager.java @@ -51,9 +51,7 @@ public class StateManager { private final OptionalObjectProperty activeSearchQuery = OptionalObjectProperty.empty(); private final ObservableMap searchResultMap = FXCollections.observableHashMap(); private final OptionalObjectProperty focusOwner = OptionalObjectProperty.empty(); - private final ObservableList> backgroundTasks = FXCollections.observableArrayList(task -> { - return new Observable[]{task.progressProperty(), task.runningProperty()}; - }); + private final ObservableList> backgroundTasks = FXCollections.observableArrayList(task -> new Observable[]{task.progressProperty(), task.runningProperty()}); private final EasyBinding anyTaskRunning = EasyBind.reduce(backgroundTasks, tasks -> tasks.anyMatch(Task::isRunning)); private final EasyBinding tasksProgress = EasyBind.reduce(backgroundTasks, tasks -> tasks.filter(Task::isRunning).mapToDouble(Task::getProgress).average().orElse(1)); private final ObservableMap dialogWindowStates = FXCollections.observableHashMap(); diff --git a/src/main/java/org/jabref/gui/entryeditor/EntryEditorPreferences.java b/src/main/java/org/jabref/gui/entryeditor/EntryEditorPreferences.java index 82d2fea3b06..278c9a85427 100644 --- a/src/main/java/org/jabref/gui/entryeditor/EntryEditorPreferences.java +++ b/src/main/java/org/jabref/gui/entryeditor/EntryEditorPreferences.java @@ -14,6 +14,7 @@ public class EntryEditorPreferences { private final boolean shouldShowLatexCitationsTab; private boolean showSourceTabByDefault; private boolean enableValidation; + private double dividerPosition; public EntryEditorPreferences(Map> entryEditorTabList, boolean shouldOpenOnNewEntry, @@ -21,7 +22,8 @@ public EntryEditorPreferences(Map> entryEditorTabList, boolean isMrdlibAccepted, boolean shouldShowLatexCitationsTab, boolean showSourceTabByDefault, - boolean enableValidation) { + boolean enableValidation, + double dividerPosition) { this.entryEditorTabList = entryEditorTabList; this.shouldOpenOnNewEntry = shouldOpenOnNewEntry; @@ -30,6 +32,7 @@ public EntryEditorPreferences(Map> entryEditorTabList, this.shouldShowLatexCitationsTab = shouldShowLatexCitationsTab; this.showSourceTabByDefault = showSourceTabByDefault; this.enableValidation = enableValidation; + this.dividerPosition = dividerPosition; } public Map> getEntryEditorTabList() { @@ -59,4 +62,13 @@ public boolean shouldShowLatexCitationsTab() { public boolean isEnableValidation() { return enableValidation; } + + public double getDividerPosition() { + return dividerPosition; + } + + public EntryEditorPreferences withDividerPosition(double dividerPosition) { + this.dividerPosition = dividerPosition; + return this; + } } diff --git a/src/main/java/org/jabref/gui/importer/actions/OpenDatabaseAction.java b/src/main/java/org/jabref/gui/importer/actions/OpenDatabaseAction.java index 4e9a682f061..8b2f79ec02d 100644 --- a/src/main/java/org/jabref/gui/importer/actions/OpenDatabaseAction.java +++ b/src/main/java/org/jabref/gui/importer/actions/OpenDatabaseAction.java @@ -11,7 +11,6 @@ import java.util.Objects; import java.util.Optional; -import org.jabref.gui.BasePanelPreferences; import org.jabref.gui.DialogService; import org.jabref.gui.Globals; import org.jabref.gui.JabRefFrame; @@ -207,7 +206,7 @@ private LibraryTab addNewDatabase(ParserResult result, final Path file, boolean ParserResultWarningDialog.showParserResultWarningDialog(result, frame); } - LibraryTab libraryTab = new LibraryTab(frame, BasePanelPreferences.from(Globals.prefs), result.getDatabaseContext(), ExternalFileTypes.getInstance()); + LibraryTab libraryTab = new LibraryTab(frame, Globals.prefs, result.getDatabaseContext(), ExternalFileTypes.getInstance()); frame.addTab(libraryTab, raisePanel); return libraryTab; } diff --git a/src/main/java/org/jabref/gui/preferences/EntryEditorTabViewModel.java b/src/main/java/org/jabref/gui/preferences/EntryEditorTabViewModel.java index de221e7dfc8..b3ccf7c58ec 100644 --- a/src/main/java/org/jabref/gui/preferences/EntryEditorTabViewModel.java +++ b/src/main/java/org/jabref/gui/preferences/EntryEditorTabViewModel.java @@ -71,15 +71,9 @@ public void setValues() { } switch (initialAutoCompletePreferences.getFirstNameMode()) { - case ONLY_ABBREVIATED: - firstNameModeAbbreviatedProperty.setValue(true); - break; - case ONLY_FULL: - firstNameModeFullProperty.setValue(true); - break; - default: - firstNameModeBothProperty.setValue(true); - break; + case ONLY_ABBREVIATED -> firstNameModeAbbreviatedProperty.setValue(true); + case ONLY_FULL -> firstNameModeFullProperty.setValue(true); + default -> firstNameModeBothProperty.setValue(true); } } @@ -92,7 +86,8 @@ public void storeSettings() { acceptRecommendationsProperty.getValue(), enableLatexCitationsTabProperty.getValue(), defaultSourceProperty.getValue(), - enableValidationProperty.getValue())); + enableValidationProperty.getValue(), + initialEntryEditorPreferences.getDividerPosition())); // default AutoCompletePreferences.NameFormat nameFormat = AutoCompletePreferences.NameFormat.BOTH; diff --git a/src/main/java/org/jabref/preferences/JabRefPreferences.java b/src/main/java/org/jabref/preferences/JabRefPreferences.java index f3e6517cce9..e9f40db0f0a 100644 --- a/src/main/java/org/jabref/preferences/JabRefPreferences.java +++ b/src/main/java/org/jabref/preferences/JabRefPreferences.java @@ -1735,7 +1735,8 @@ public EntryEditorPreferences getEntryEditorPreferences() { getBoolean(ACCEPT_RECOMMENDATIONS), getBoolean(SHOW_LATEX_CITATIONS), getBoolean(DEFAULT_SHOW_SOURCE), - getBoolean(VALIDATE_IN_ENTRY_EDITOR)); + getBoolean(VALIDATE_IN_ENTRY_EDITOR), + getDouble(ENTRY_EDITOR_HEIGHT)); } @Override @@ -1747,6 +1748,7 @@ public void storeEntryEditorPreferences(EntryEditorPreferences preferences) { putBoolean(SHOW_LATEX_CITATIONS, preferences.shouldShowLatexCitationsTab()); putBoolean(DEFAULT_SHOW_SOURCE, preferences.showSourceTabByDefault()); putBoolean(VALIDATE_IN_ENTRY_EDITOR, preferences.isEnableValidation()); + putDouble(ENTRY_EDITOR_HEIGHT, preferences.getDividerPosition()); } //************************************************************************************************************* From 25646f2a000ee753d5480b6689e25a525731f9c3 Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Fri, 16 Oct 2020 16:50:47 +0200 Subject: [PATCH 08/20] Removed calls to JabRefPreferences in LibraryTab.java --- src/main/java/org/jabref/gui/LibraryTab.java | 20 +++++++++---------- .../jabref/gui/UpdateTimestampListener.java | 14 ++++++------- .../gui/preferences/GeneralTabViewModel.java | 4 ++-- .../preferences/GeneralPreferences.java | 13 ++++++++---- .../jabref/preferences/JabRefPreferences.java | 6 +++--- 5 files changed, 31 insertions(+), 26 deletions(-) diff --git a/src/main/java/org/jabref/gui/LibraryTab.java b/src/main/java/org/jabref/gui/LibraryTab.java index 364134b1412..6720e6c4a15 100644 --- a/src/main/java/org/jabref/gui/LibraryTab.java +++ b/src/main/java/org/jabref/gui/LibraryTab.java @@ -51,7 +51,6 @@ import org.jabref.model.entry.event.EntryChangedEvent; import org.jabref.model.entry.field.Field; import org.jabref.model.entry.field.FieldFactory; -import org.jabref.preferences.JabRefPreferences; import org.jabref.preferences.PreferencesService; import com.google.common.eventbus.Subscribe; @@ -114,10 +113,10 @@ public LibraryTab(JabRefFrame frame, bibDatabaseContext.getMetaData().registerListener(this); this.sidePaneManager = frame.getSidePaneManager(); - this.tableModel = new MainTableDataModel(getBibDatabaseContext(), Globals.prefs, Globals.stateManager); + this.tableModel = new MainTableDataModel(getBibDatabaseContext(), preferencesService, Globals.stateManager); citationStyleCache = new CitationStyleCache(bibDatabaseContext); - annotationCache = new FileAnnotationCache(bibDatabaseContext, Globals.prefs.getFilePreferences()); + annotationCache = new FileAnnotationCache(bibDatabaseContext, preferencesService.getFilePreferences()); setupMainPanel(); setupAutoCompletion(); @@ -130,7 +129,7 @@ public LibraryTab(JabRefFrame frame, // ensure that all entry changes mark the panel as changed this.bibDatabaseContext.getDatabase().registerListener(this); - this.getDatabase().registerListener(new UpdateTimestampListener(Globals.prefs)); + this.getDatabase().registerListener(new UpdateTimestampListener(preferencesService)); this.entryEditor = new EntryEditor(this, externalFileTypes); @@ -159,7 +158,7 @@ public LibraryTab(JabRefFrame frame, * C:\git-repositories\jabref\src\test\resources\testbib\jabref-authors.bib (BibLaTeX) – JabRef */ private void refreshTabTitle(boolean isChanged) { - boolean isAutosaveEnabled = Globals.prefs.getBoolean(JabRefPreferences.LOCAL_AUTO_SAVE); + boolean isAutosaveEnabled = preferencesService.getShouldAutosave(); DatabaseLocation databaseLocation = bibDatabaseContext.getLocation(); Optional file = bibDatabaseContext.getDatabasePath(); @@ -352,7 +351,7 @@ public void insertEntries(final List entries) { getUndoManager().addEdit(new UndoableInsertEntries(bibDatabaseContext.getDatabase(), entries)); this.changedProperty.setValue(true); // The database just changed. - if (Globals.prefs.getBoolean(JabRefPreferences.AUTO_OPEN_FORM)) { + if (preferencesService.getEntryEditorPreferences().shouldOpenOnNewEntry()) { showAndEdit(entries.get(0)); } clearAndSelect(entries.get(0)); @@ -374,7 +373,7 @@ private void createMainTable() { mainTable = new MainTable(tableModel, this, bibDatabaseContext, - Globals.prefs, + preferencesService, dialogService, Globals.stateManager, externalFileTypes, @@ -544,7 +543,7 @@ public BibDatabase getDatabase() { } private boolean showDeleteConfirmationDialog(int numberOfEntries) { - if (Globals.prefs.getBoolean(JabRefPreferences.CONFIRM_DELETE)) { + if (preferencesService.getGeneralPreferences().shouldConfirmDelete()) { String title = Localization.lang("Delete entry"); String message = Localization.lang("Really delete the selected entry?"); String okButton = Localization.lang("Delete entry"); @@ -561,7 +560,8 @@ private boolean showDeleteConfirmationDialog(int numberOfEntries) { okButton, cancelButton, Localization.lang("Disable this confirmation dialog"), - optOut -> Globals.prefs.putBoolean(JabRefPreferences.CONFIRM_DELETE, !optOut)); + optOut -> preferencesService.storeGeneralPreferences( + preferencesService.getGeneralPreferences().withConfirmDelete(!optOut))); } else { return true; } @@ -702,7 +702,7 @@ public void listen(EntriesAddedEvent addedEntriesEvent) { } // Automatically add new entries to the selected group (or set of groups) - if (Globals.prefs.getBoolean(JabRefPreferences.AUTO_ASSIGN_GROUP)) { + if (preferencesService.getGroupsPreferences().shouldAutoAssignGroup()) { Globals.stateManager.getSelectedGroup(bibDatabaseContext).forEach( selectedGroup -> selectedGroup.addEntriesToGroup(addedEntriesEvent.getBibEntries())); } diff --git a/src/main/java/org/jabref/gui/UpdateTimestampListener.java b/src/main/java/org/jabref/gui/UpdateTimestampListener.java index 4af4d661c29..aad998db035 100644 --- a/src/main/java/org/jabref/gui/UpdateTimestampListener.java +++ b/src/main/java/org/jabref/gui/UpdateTimestampListener.java @@ -1,7 +1,7 @@ package org.jabref.gui; import org.jabref.model.entry.event.EntryChangedEvent; -import org.jabref.preferences.JabRefPreferences; +import org.jabref.preferences.PreferencesService; import com.google.common.eventbus.Subscribe; @@ -9,17 +9,17 @@ * Updates the timestamp of changed entries if the feature is enabled */ class UpdateTimestampListener { - private final JabRefPreferences jabRefPreferences; + private final PreferencesService preferencesService; - UpdateTimestampListener(JabRefPreferences jabRefPreferences) { - this.jabRefPreferences = jabRefPreferences; + UpdateTimestampListener(PreferencesService preferencesService) { + this.preferencesService = preferencesService; } @Subscribe public void listen(EntryChangedEvent event) { - if (jabRefPreferences.getTimestampPreferences().includeTimestamps()) { - event.getBibEntry().setField(jabRefPreferences.getTimestampPreferences().getTimestampField(), - jabRefPreferences.getTimestampPreferences().now()); + if (preferencesService.getTimestampPreferences().includeTimestamps()) { + event.getBibEntry().setField(preferencesService.getTimestampPreferences().getTimestampField(), + preferencesService.getTimestampPreferences().now()); } } } diff --git a/src/main/java/org/jabref/gui/preferences/GeneralTabViewModel.java b/src/main/java/org/jabref/gui/preferences/GeneralTabViewModel.java index 59af8c67886..777dac8e66f 100644 --- a/src/main/java/org/jabref/gui/preferences/GeneralTabViewModel.java +++ b/src/main/java/org/jabref/gui/preferences/GeneralTabViewModel.java @@ -103,8 +103,8 @@ public void setValues() { selectedBiblatexModeProperty.setValue(initialGeneralPreferences.getDefaultBibDatabaseMode()); inspectionWarningDuplicateProperty.setValue(initialGeneralPreferences.isWarnAboutDuplicatesInInspection()); - confirmDeleteProperty.setValue(initialGeneralPreferences.isConfirmDelete()); - allowIntegerEditionProperty.setValue(initialGeneralPreferences.isAllowIntegerEditionBibtex()); + confirmDeleteProperty.setValue(initialGeneralPreferences.shouldConfirmDelete()); + allowIntegerEditionProperty.setValue(initialGeneralPreferences.shouldAllowIntegerEditionBibtex()); memoryStickModeProperty.setValue(initialGeneralPreferences.isMemoryStickMode()); collectTelemetryProperty.setValue(preferencesService.shouldCollectTelemetry()); showAdvancedHintsProperty.setValue(initialGeneralPreferences.shouldShowAdvancedHints()); diff --git a/src/main/java/org/jabref/preferences/GeneralPreferences.java b/src/main/java/org/jabref/preferences/GeneralPreferences.java index 8e80440da53..0db44970816 100644 --- a/src/main/java/org/jabref/preferences/GeneralPreferences.java +++ b/src/main/java/org/jabref/preferences/GeneralPreferences.java @@ -9,7 +9,7 @@ public class GeneralPreferences { private final BibDatabaseMode defaultBibDatabaseMode; private final boolean warnAboutDuplicatesInInspection; - private final boolean confirmDelete; + private boolean confirmDelete; private final boolean allowIntegerEditionBibtex; private final boolean memoryStickMode; private final boolean collectTelemetry; @@ -45,11 +45,16 @@ public boolean isWarnAboutDuplicatesInInspection() { return warnAboutDuplicatesInInspection; } - public boolean isConfirmDelete() { + public boolean shouldConfirmDelete() { return confirmDelete; } - public boolean isAllowIntegerEditionBibtex() { + public GeneralPreferences withConfirmDelete(boolean confirmDelete) { + this.confirmDelete = confirmDelete; + return this; + } + + public boolean shouldAllowIntegerEditionBibtex() { return allowIntegerEditionBibtex; } @@ -57,7 +62,7 @@ public boolean isMemoryStickMode() { return memoryStickMode; } - public boolean isCollectTelemetry() { + public boolean shouldCollectTelemetry() { return collectTelemetry; } diff --git a/src/main/java/org/jabref/preferences/JabRefPreferences.java b/src/main/java/org/jabref/preferences/JabRefPreferences.java index e9f40db0f0a..2e908686c38 100644 --- a/src/main/java/org/jabref/preferences/JabRefPreferences.java +++ b/src/main/java/org/jabref/preferences/JabRefPreferences.java @@ -1526,10 +1526,10 @@ public void storeGeneralPreferences(GeneralPreferences preferences) { put(DEFAULT_ENCODING, preferences.getDefaultEncoding().name()); putBoolean(BIBLATEX_DEFAULT_MODE, (preferences.getDefaultBibDatabaseMode() == BibDatabaseMode.BIBLATEX)); putBoolean(WARN_ABOUT_DUPLICATES_IN_INSPECTION, preferences.isWarnAboutDuplicatesInInspection()); - putBoolean(CONFIRM_DELETE, preferences.isConfirmDelete()); - putBoolean(ALLOW_INTEGER_EDITION_BIBTEX, preferences.isAllowIntegerEditionBibtex()); + putBoolean(CONFIRM_DELETE, preferences.shouldConfirmDelete()); + putBoolean(ALLOW_INTEGER_EDITION_BIBTEX, preferences.shouldAllowIntegerEditionBibtex()); putBoolean(MEMORY_STICK_MODE, preferences.isMemoryStickMode()); - setShouldCollectTelemetry(preferences.isCollectTelemetry()); + setShouldCollectTelemetry(preferences.shouldCollectTelemetry()); putBoolean(SHOW_ADVANCED_HINTS, preferences.shouldShowAdvancedHints()); } From add74ef2d4e02abf116085c78bcf2c36a7ccb876 Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Sat, 17 Oct 2020 23:33:00 +0200 Subject: [PATCH 09/20] Reworded panel to libraryTab and suggested switch statement refactor --- .../org/jabref/gui/exporter/SaveAction.java | 14 ++---- .../gui/exporter/SaveDatabaseAction.java | 49 ++++++++++--------- 2 files changed, 28 insertions(+), 35 deletions(-) diff --git a/src/main/java/org/jabref/gui/exporter/SaveAction.java b/src/main/java/org/jabref/gui/exporter/SaveAction.java index c070159311d..80061fa220c 100644 --- a/src/main/java/org/jabref/gui/exporter/SaveAction.java +++ b/src/main/java/org/jabref/gui/exporter/SaveAction.java @@ -35,17 +35,9 @@ public void execute() { Globals.entryTypesManager); switch (saveMethod) { - case SAVE: - saveDatabaseAction.save(); - break; - case SAVE_AS: - saveDatabaseAction.saveAs(); - break; - case SAVE_SELECTED: - saveDatabaseAction.saveSelectedAsPlain(); - break; - default: - // Never happens + case SAVE -> saveDatabaseAction.save(); + case SAVE_AS -> saveDatabaseAction.saveAs(); + case SAVE_SELECTED -> saveDatabaseAction.saveSelectedAsPlain(); } } } diff --git a/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java b/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java index 759f8f9ecd5..6a1a1af30bf 100644 --- a/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java +++ b/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java @@ -49,7 +49,7 @@ public class SaveDatabaseAction { private static final Logger LOGGER = LoggerFactory.getLogger(SaveDatabaseAction.class); - private final LibraryTab panel; + private final LibraryTab libraryTab; private final JabRefFrame frame; private final DialogService dialogService; private final JabRefPreferences preferences; @@ -60,7 +60,7 @@ public enum SaveDatabaseMode { } public SaveDatabaseAction(LibraryTab libraryTab, JabRefPreferences preferences, BibEntryTypesManager entryTypesManager) { - this.panel = libraryTab; + this.libraryTab = libraryTab; this.frame = libraryTab.frame(); this.dialogService = frame.getDialogService(); this.preferences = preferences; @@ -68,11 +68,11 @@ public SaveDatabaseAction(LibraryTab libraryTab, JabRefPreferences preferences, } public boolean save() { - return save(panel.getBibDatabaseContext(), SaveDatabaseMode.NORMAL); + return save(libraryTab.getBibDatabaseContext(), SaveDatabaseMode.NORMAL); } public boolean save(SaveDatabaseMode mode) { - return save(panel.getBibDatabaseContext(), mode); + return save(libraryTab.getBibDatabaseContext(), mode); } /** @@ -105,7 +105,7 @@ public void saveSelectedAsPlain() { * @return true on successful save */ boolean saveAs(Path file, SaveDatabaseMode mode) { - BibDatabaseContext context = panel.getBibDatabaseContext(); + BibDatabaseContext context = libraryTab.getBibDatabaseContext(); // Close AutosaveManager and BackupManager for original library Optional databasePath = context.getDatabasePath(); @@ -129,13 +129,16 @@ boolean saveAs(Path file, SaveDatabaseMode mode) { // we managed to successfully save the file // thus, we can store the store the path into the context context.setDatabasePath(file); - // frame.refreshWindowAndTabTitles(); + + // Hack: Mock a change event, so the tab title is redrawn + libraryTab.changedProperty().setValue(true); + libraryTab.changedProperty().setValue(false); // Reinstall AutosaveManager and BackupManager for the new file name - panel.resetChangeMonitorAndChangePane(); + libraryTab.resetChangeMonitorAndChangePane(); if (readyForAutosave(context)) { AutosaveManager autosaver = AutosaveManager.start(context); - autosaver.registerListener(new AutosaveUiManager(panel)); + autosaver.registerListener(new AutosaveUiManager(libraryTab)); } if (readyForBackup(context)) { BackupManager.start(context, entryTypesManager, preferences); @@ -182,25 +185,23 @@ private boolean save(Path targetPath, SaveDatabaseMode mode) { dialogService.notify(String.format("%s...", Localization.lang("Saving library"))); } - panel.setSaving(true); + libraryTab.setSaving(true); try { - Charset encoding = panel.getBibDatabaseContext() - .getMetaData() - .getEncoding() - .orElse(preferences.getDefaultEncoding()); + Charset encoding = libraryTab.getBibDatabaseContext() + .getMetaData() + .getEncoding() + .orElse(preferences.getDefaultEncoding()); // Make sure to remember which encoding we used. - panel.getBibDatabaseContext().getMetaData().setEncoding(encoding, ChangePropagation.DO_NOT_POST_EVENT); + libraryTab.getBibDatabaseContext().getMetaData().setEncoding(encoding, ChangePropagation.DO_NOT_POST_EVENT); // Save the database boolean success = saveDatabase(targetPath, false, encoding, SavePreferences.DatabaseSaveType.ALL); if (success) { - panel.getUndoManager().markUnchanged(); + libraryTab.getUndoManager().markUnchanged(); // After a successful save the following statement marks that the base is unchanged since last save - panel.nonUndoableChangeProperty().setValue(false); - panel.changedProperty().setValue(false); - - // frame.refreshWindowAndTabTitles(); + libraryTab.nonUndoableChangeProperty().setValue(false); + libraryTab.changedProperty().setValue(false); } return success; } catch (SaveException ex) { @@ -209,7 +210,7 @@ private boolean save(Path targetPath, SaveDatabaseMode mode) { return false; } finally { // release panel from save status - panel.setSaving(false); + libraryTab.setSaving(false); } } @@ -221,12 +222,12 @@ private boolean saveDatabase(Path file, boolean selectedOnly, Charset encoding, BibtexDatabaseWriter databaseWriter = new BibtexDatabaseWriter(fileWriter, preferences, entryTypesManager); if (selectedOnly) { - databaseWriter.savePartOfDatabase(panel.getBibDatabaseContext(), panel.getSelectedEntries()); + databaseWriter.savePartOfDatabase(libraryTab.getBibDatabaseContext(), libraryTab.getSelectedEntries()); } else { - databaseWriter.saveDatabase(panel.getBibDatabaseContext()); + databaseWriter.saveDatabase(libraryTab.getBibDatabaseContext()); } - panel.registerUndoableChanges(databaseWriter.getSaveActionsFieldChanges()); + libraryTab.registerUndoableChanges(databaseWriter.getSaveActionsFieldChanges()); if (fileWriter.hasEncodingProblems()) { saveWithDifferentEncoding(file, selectedOnly, preferences.getEncoding(), fileWriter.getEncodingProblems(), saveType); @@ -260,7 +261,7 @@ private void saveWithDifferentEncoding(Path file, boolean selectedOnly, Charset Optional newEncoding = dialogService.showChoiceDialogAndWait(Localization.lang("Save library"), Localization.lang("Select new encoding"), Localization.lang("Save library"), encoding, Encodings.getCharsets()); if (newEncoding.isPresent()) { // Make sure to remember which encoding we used. - panel.getBibDatabaseContext().getMetaData().setEncoding(newEncoding.get(), ChangePropagation.DO_NOT_POST_EVENT); + libraryTab.getBibDatabaseContext().getMetaData().setEncoding(newEncoding.get(), ChangePropagation.DO_NOT_POST_EVENT); saveDatabase(file, selectedOnly, newEncoding.get(), saveType); } From 5ae3c580da2e1dc5901e821e6282b8566d5e8f19 Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Sat, 17 Oct 2020 23:34:23 +0200 Subject: [PATCH 10/20] Refactored setting window title --- src/main/java/org/jabref/gui/JabRefFrame.java | 56 ++++++++----------- 1 file changed, 23 insertions(+), 33 deletions(-) diff --git a/src/main/java/org/jabref/gui/JabRefFrame.java b/src/main/java/org/jabref/gui/JabRefFrame.java index 64462f161db..27c2c05f70d 100644 --- a/src/main/java/org/jabref/gui/JabRefFrame.java +++ b/src/main/java/org/jabref/gui/JabRefFrame.java @@ -13,6 +13,9 @@ import java.util.stream.Collectors; import javafx.application.Platform; +import javafx.beans.Observable; +import javafx.beans.binding.Bindings; +import javafx.beans.binding.StringBinding; import javafx.beans.value.ChangeListener; import javafx.beans.value.ObservableValue; import javafx.concurrent.Task; @@ -185,20 +188,6 @@ public JabRefFrame(Stage mainStage) { } } }); - - Platform.runLater(() -> { - EasyBind.subscribe(tabbedPane.getSelectionModel().selectedItemProperty(), tab -> { - if (tab != null) { - LibraryTab libraryTab = (LibraryTab) tab; - StringBuilder windowTitle = new StringBuilder(libraryTab.nameProperty().get()); - windowTitle.append(" \u2013 "); - windowTitle.append(FRAME_TITLE); - mainStage.setTitle(windowTitle.toString()); - } else { - mainStage.setTitle(FRAME_TITLE); - } - }); - }); } private void initDragAndDrop() { @@ -547,7 +536,7 @@ private Node createToolbar() { } /** - * Returns the indexed BasePanel. + * Returns the indexed LibraryTab. * * @param i Index of base */ @@ -556,7 +545,7 @@ public LibraryTab getLibraryTabAt(int i) { } /** - * Returns a list of all BasePanels in this frame. + * Returns a list of all LibraryTabs in this frame. */ public List getLibraryTabs() { return tabbedPane.getTabs().stream() @@ -616,32 +605,33 @@ public void init() { EasyBind.subscribe(tabbedPane.getSelectionModel().selectedItemProperty(), tab -> { if (tab == null) { stateManager.setSelectedEntries(Collections.emptyList()); + mainStage.titleProperty().unbind(); + mainStage.setTitle(FRAME_TITLE); return; } - LibraryTab newLibraryTab = (LibraryTab) tab; + LibraryTab libraryTab = (LibraryTab) tab; // Poor-mans binding to global state - stateManager.setSelectedEntries(newLibraryTab.getSelectedEntries()); + stateManager.setSelectedEntries(libraryTab.getSelectedEntries()); // Update active search query when switching between databases - stateManager.activeSearchQueryProperty().set(newLibraryTab.getCurrentSearchQuery()); - - // groupSidePane.getToggleCommand().setSelected(sidePaneManager.isComponentVisible(GroupSidePane.class)); - // previewToggle.setSelected(Globals.prefs.getPreviewPreferences().isPreviewPanelEnabled()); - // generalFetcher.getToggleCommand().setSelected(sidePaneManager.isComponentVisible(WebSearchPane.class)); - // openOfficePanel.getToggleCommand().setSelected(sidePaneManager.isComponentVisible(OpenOfficeSidePanel.class)); - - // We need to refresh the window title only - // There is currently no optimized method to set the title only (because that lead to code duplication) - // Thus, we refresh everything - // refreshWindowAndTabTitles(); + stateManager.activeSearchQueryProperty().set(libraryTab.getCurrentSearchQuery()); // Update search autocompleter with information for the correct database: - newLibraryTab.updateSearchManager(); - - newLibraryTab.getUndoManager().postUndoRedoEvent(); - newLibraryTab.getMainTable().requestFocus(); + libraryTab.updateSearchManager(); + + libraryTab.getUndoManager().postUndoRedoEvent(); + libraryTab.getMainTable().requestFocus(); + + // Set window title + ArrayList observables = new ArrayList<>(List.of(libraryTab.changedProperty(), libraryTab.nameProperty())); + StringBinding windowTitle = Bindings.createStringBinding(() -> + (libraryTab.changedProperty().getValue() ? "*" : "") + + libraryTab.nameProperty().getValue() + " \u2013 " + + FRAME_TITLE, + observables.toArray(Observable[]::new)); + mainStage.titleProperty().bind(windowTitle); }); initShowTrackingNotification(); } From 36dbc4bdbac464487e2a0f3d0522199953f2b83d Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Sat, 17 Oct 2020 23:42:01 +0200 Subject: [PATCH 11/20] Refactored setting window title --- src/main/java/org/jabref/gui/LibraryTab.java | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/main/java/org/jabref/gui/LibraryTab.java b/src/main/java/org/jabref/gui/LibraryTab.java index 6720e6c4a15..6c383de52cf 100644 --- a/src/main/java/org/jabref/gui/LibraryTab.java +++ b/src/main/java/org/jabref/gui/LibraryTab.java @@ -86,11 +86,11 @@ public class LibraryTab extends Tab { private boolean saving; private PersonNameSuggestionProvider searchAutoCompleter; - private BooleanProperty changedProperty = new SimpleBooleanProperty(false); - private BooleanProperty nonUndoableChangeProperty = new SimpleBooleanProperty(false); + private final BooleanProperty changedProperty = new SimpleBooleanProperty(false); + private final BooleanProperty nonUndoableChangeProperty = new SimpleBooleanProperty(false); // Used to track whether the base has changed since last save. - private StringProperty nameProperty = new SimpleStringProperty(); + private final StringProperty nameProperty = new SimpleStringProperty(); private BibEntry showing; private SuggestionProviders suggestionProviders; @SuppressWarnings({"FieldCanBeLocal"}) private Subscription dividerPositionSubscription; From be77a2a5cd7f1a61398e9133b022ddefd33727bd Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Sun, 18 Oct 2020 00:27:34 +0200 Subject: [PATCH 12/20] Refactored collectDatabaseFilePaths to stream --- src/main/java/org/jabref/gui/JabRefFrame.java | 26 +++++-------------- src/main/java/org/jabref/gui/LibraryTab.java | 17 ++++++++++-- .../java/org/jabref/gui/StateManager.java | 5 ++++ 3 files changed, 27 insertions(+), 21 deletions(-) diff --git a/src/main/java/org/jabref/gui/JabRefFrame.java b/src/main/java/org/jabref/gui/JabRefFrame.java index 27c2c05f70d..ec0fce0213d 100644 --- a/src/main/java/org/jabref/gui/JabRefFrame.java +++ b/src/main/java/org/jabref/gui/JabRefFrame.java @@ -18,6 +18,7 @@ import javafx.beans.binding.StringBinding; import javafx.beans.value.ChangeListener; import javafx.beans.value.ObservableValue; +import javafx.collections.FXCollections; import javafx.concurrent.Task; import javafx.geometry.Orientation; import javafx.scene.Group; @@ -574,12 +575,13 @@ public void init() { initDragAndDrop(); - // setBounds(GraphicsEnvironment.getLocalGraphicsEnvironment().getMaximumWindowBounds()); - // WindowLocation pw = new WindowLocation(this, JabRefPreferences.POS_X, JabRefPreferences.POS_Y, JabRefPreferences.SIZE_X, - // JabRefPreferences.SIZE_Y); - // pw.displayWindowAtStoredLocation(); - // Bind global state + stateManager.openDatabases().bindContent( + tabbedPane.getTabs().stream() + .map(tab -> (LibraryTab) tab) + .map(LibraryTab::getBibDatabaseContext) + .collect(Collectors.toCollection(FXCollections::observableArrayList))); + stateManager.activeDatabaseProperty().bind( EasyBind.map(tabbedPane.getSelectionModel().selectedItemProperty(), selectedTab -> Optional.ofNullable(selectedTab) @@ -1004,20 +1006,6 @@ public void setupAllTables() { }); } - public List collectDatabaseFilePaths() { - List dbPaths = new ArrayList<>(getBasePanelCount()); - - for (LibraryTab libraryTab : getLibraryTabs()) { - // db file exists - if (libraryTab.getBibDatabaseContext().getDatabasePath().isPresent()) { - dbPaths.add(libraryTab.getBibDatabaseContext().getDatabasePath().get().toAbsolutePath().toString()); - } else { - dbPaths.add(""); - } - } - return dbPaths; - } - private ContextMenu createTabContextMenu(KeyBindingRepository keyBindingRepository) { ContextMenu contextMenu = new ContextMenu(); ActionFactory factory = new ActionFactory(keyBindingRepository); diff --git a/src/main/java/org/jabref/gui/LibraryTab.java b/src/main/java/org/jabref/gui/LibraryTab.java index 6c383de52cf..bf26307ce01 100644 --- a/src/main/java/org/jabref/gui/LibraryTab.java +++ b/src/main/java/org/jabref/gui/LibraryTab.java @@ -1,6 +1,7 @@ package org.jabref.gui; import java.nio.file.Path; +import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.Objects; @@ -133,7 +134,9 @@ public LibraryTab(JabRefFrame frame, this.entryEditor = new EntryEditor(this, externalFileTypes); - EasyBind.subscribe(changedProperty, this::refreshTabTitle); + Platform.runLater(() -> + EasyBind.subscribe(changedProperty, this::refreshTabTitle) + ); } /** @@ -193,7 +196,7 @@ private void refreshTabTitle(boolean isChanged) { addChangedInformation(toolTipText, fileName); } - List uniquePathParts = FileUtil.uniquePathSubstrings(frame.collectDatabaseFilePaths()); + List uniquePathParts = FileUtil.uniquePathSubstrings(collectAllDatabasePaths()); // String uniquePath = uniquePathParts.get(i); /* if (!uniquePath.equals(fileName) && uniquePath.contains(File.separator)) { @@ -247,6 +250,16 @@ private static void addSharedDbInformation(StringBuilder text, BibDatabaseContex text.append("]"); } + private List collectAllDatabasePaths() { + List list = new ArrayList<>(); + Globals.stateManager.openDatabases().stream() + .map(BibDatabaseContext::getDatabasePath) + .forEachOrdered(pathOptional -> pathOptional.ifPresentOrElse( + path -> list.add(path.toAbsolutePath().toString()), + () -> list.add(""))); + return list; + } + @Subscribe public void listen(BibDatabaseContextChangedEvent event) { this.changedProperty.setValue(true); diff --git a/src/main/java/org/jabref/gui/StateManager.java b/src/main/java/org/jabref/gui/StateManager.java index c049c3fab3a..e61c4bc8487 100644 --- a/src/main/java/org/jabref/gui/StateManager.java +++ b/src/main/java/org/jabref/gui/StateManager.java @@ -44,6 +44,7 @@ public class StateManager { private final CustomLocalDragboard localDragboard = new CustomLocalDragboard(); + private final ReadOnlyListWrapper openDatabases = new ReadOnlyListWrapper<>(FXCollections.observableArrayList()); private final OptionalObjectProperty activeDatabase = OptionalObjectProperty.empty(); private final ReadOnlyListWrapper activeGroups = new ReadOnlyListWrapper<>(FXCollections.observableArrayList()); private final ObservableList selectedEntries = FXCollections.observableArrayList(); @@ -64,6 +65,10 @@ public CustomLocalDragboard getLocalDragboard() { return localDragboard; } + public ReadOnlyListProperty openDatabases() { + return openDatabases.getReadOnlyProperty(); + } + public OptionalObjectProperty activeDatabaseProperty() { return activeDatabase; } From 0ab5e559f73c9dba78e8998dc2c0faef65af31d2 Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Sun, 18 Oct 2020 15:26:32 +0200 Subject: [PATCH 13/20] Reenabled unique path parsing --- src/main/java/org/jabref/gui/JabRefFrame.java | 14 +----- src/main/java/org/jabref/gui/LibraryTab.java | 48 +++++++++++-------- .../java/org/jabref/gui/StateManager.java | 7 +-- .../gui/exporter/SaveDatabaseAction.java | 4 +- 4 files changed, 34 insertions(+), 39 deletions(-) diff --git a/src/main/java/org/jabref/gui/JabRefFrame.java b/src/main/java/org/jabref/gui/JabRefFrame.java index ec0fce0213d..e7b4254717d 100644 --- a/src/main/java/org/jabref/gui/JabRefFrame.java +++ b/src/main/java/org/jabref/gui/JabRefFrame.java @@ -18,7 +18,6 @@ import javafx.beans.binding.StringBinding; import javafx.beans.value.ChangeListener; import javafx.beans.value.ObservableValue; -import javafx.collections.FXCollections; import javafx.concurrent.Task; import javafx.geometry.Orientation; import javafx.scene.Group; @@ -570,17 +569,11 @@ public void init() { tabbedPane.setTabDragPolicy(TabPane.TabDragPolicy.REORDER); initLayout(); - initKeyBindings(); - initDragAndDrop(); // Bind global state - stateManager.openDatabases().bindContent( - tabbedPane.getTabs().stream() - .map(tab -> (LibraryTab) tab) - .map(LibraryTab::getBibDatabaseContext) - .collect(Collectors.toCollection(FXCollections::observableArrayList))); + EasyBind.bindContent(stateManager.getOpenTabs(), tabbedPane.getTabs()); stateManager.activeDatabaseProperty().bind( EasyBind.map(tabbedPane.getSelectionModel().selectedItemProperty(), @@ -1023,8 +1016,6 @@ private ContextMenu createTabContextMenu(KeyBindingRepository keyBindingReposito } public void addTab(LibraryTab libraryTab, boolean raisePanel) { - // "" is passed as title, because it is updated below at "refreshWindowAndTabTitles()" - tabbedPane.getTabs().add(libraryTab); libraryTab.setOnCloseRequest(event -> { @@ -1034,8 +1025,6 @@ public void addTab(LibraryTab libraryTab, boolean raisePanel) { libraryTab.setContextMenu(createTabContextMenu(Globals.getKeyPrefs())); - // refreshWindowAndTabTitles(); - if (raisePanel) { tabbedPane.getSelectionModel().select(libraryTab); } @@ -1166,7 +1155,6 @@ private void removeTab(LibraryTab libraryTab) { DefaultTaskExecutor.runInJavaFXThread(() -> { libraryTab.cleanUp(); tabbedPane.getTabs().remove(libraryTab); - // this.refreshWindowAndTabTitles(); }); } diff --git a/src/main/java/org/jabref/gui/LibraryTab.java b/src/main/java/org/jabref/gui/LibraryTab.java index bf26307ce01..9e6baa22ea1 100644 --- a/src/main/java/org/jabref/gui/LibraryTab.java +++ b/src/main/java/org/jabref/gui/LibraryTab.java @@ -1,5 +1,6 @@ package org.jabref.gui; +import java.io.File; import java.nio.file.Path; import java.util.ArrayList; import java.util.Collections; @@ -8,6 +9,7 @@ import java.util.Optional; import javafx.application.Platform; +import javafx.beans.binding.Bindings; import javafx.beans.property.BooleanProperty; import javafx.beans.property.SimpleBooleanProperty; import javafx.beans.property.SimpleStringProperty; @@ -134,31 +136,29 @@ public LibraryTab(JabRefFrame frame, this.entryEditor = new EntryEditor(this, externalFileTypes); - Platform.runLater(() -> - EasyBind.subscribe(changedProperty, this::refreshTabTitle) - ); + Platform.runLater(() -> { + EasyBind.subscribe(changedProperty, this::refreshTabTitle); + // FIXME: currently the tab titles are not refreshed after a tab is closed + EasyBind.subscribe(Bindings.size(Globals.stateManager.getOpenTabs()), + (databases) -> refreshTabTitle(changedProperty.getValue())); + }); } /** - * Determines the title of the tab - * - * We aim for following in a tab: + * Sets the title of the tab + * filename modification-asterisk (database-mode) – path-fragment * - * filename (datbase-mode) – path-fragment – JabRef - * - * path-fragment is only shown if filename is not (globally) unique + * (path-fragment is only shown if filename is not (globally) unique) + * The modification-asterisk (*) is shown if the file was modified since last save * * Example: + * jabref-authors.bib* (BibLaTeX) – testbib * - * jabref-authors.bib (BibLaTeX) – testbib – JabRef - * - * For the JabRef window, it should be - * - * full-path (database-mode) – JabRef + * For the JabRef window, the variable nameProperty is proviced, consisting if * + * filename (database-mode) - path-fragment * * Example: - * - * C:\git-repositories\jabref\src\test\resources\testbib\jabref-authors.bib (BibLaTeX) – JabRef + * jabref-authors.bib (BibLaTeX) - testbib */ private void refreshTabTitle(boolean isChanged) { boolean isAutosaveEnabled = preferencesService.getShouldAutosave(); @@ -196,15 +196,19 @@ private void refreshTabTitle(boolean isChanged) { addChangedInformation(toolTipText, fileName); } + // Add unique path fragment List uniquePathParts = FileUtil.uniquePathSubstrings(collectAllDatabasePaths()); - - // String uniquePath = uniquePathParts.get(i); - /* if (!uniquePath.equals(fileName) && uniquePath.contains(File.separator)) { + Optional uniquePathPart = uniquePathParts.stream() + .filter(part -> databasePath.toString().contains(part) + && !part.equals(fileName) && part.contains(File.separator)) + .findFirst(); + if (uniquePathPart.isPresent()) { + String uniquePath = uniquePathPart.get(); // remove filename uniquePath = uniquePath.substring(0, uniquePath.lastIndexOf(File.separator)); tabTitle.append(" \u2013 ").append(uniquePath); tabName.append(" \u2013 ").append(uniquePath); - } */ + } } else { if (databaseLocation == DatabaseLocation.LOCAL) { tabTitle.append(Localization.lang("untitled")); @@ -252,7 +256,9 @@ private static void addSharedDbInformation(StringBuilder text, BibDatabaseContex private List collectAllDatabasePaths() { List list = new ArrayList<>(); - Globals.stateManager.openDatabases().stream() + Globals.stateManager.getOpenTabs().stream() + .map(tab -> (LibraryTab) tab) + .map(LibraryTab::getBibDatabaseContext) .map(BibDatabaseContext::getDatabasePath) .forEachOrdered(pathOptional -> pathOptional.ifPresentOrElse( path -> list.add(path.toAbsolutePath().toString()), diff --git a/src/main/java/org/jabref/gui/StateManager.java b/src/main/java/org/jabref/gui/StateManager.java index e61c4bc8487..15235007998 100644 --- a/src/main/java/org/jabref/gui/StateManager.java +++ b/src/main/java/org/jabref/gui/StateManager.java @@ -16,6 +16,7 @@ import javafx.collections.ObservableMap; import javafx.concurrent.Task; import javafx.scene.Node; +import javafx.scene.control.Tab; import org.jabref.gui.util.CustomLocalDragboard; import org.jabref.gui.util.DialogWindowState; @@ -44,7 +45,7 @@ public class StateManager { private final CustomLocalDragboard localDragboard = new CustomLocalDragboard(); - private final ReadOnlyListWrapper openDatabases = new ReadOnlyListWrapper<>(FXCollections.observableArrayList()); + private final ObservableList openTabs = FXCollections.observableArrayList(); private final OptionalObjectProperty activeDatabase = OptionalObjectProperty.empty(); private final ReadOnlyListWrapper activeGroups = new ReadOnlyListWrapper<>(FXCollections.observableArrayList()); private final ObservableList selectedEntries = FXCollections.observableArrayList(); @@ -65,8 +66,8 @@ public CustomLocalDragboard getLocalDragboard() { return localDragboard; } - public ReadOnlyListProperty openDatabases() { - return openDatabases.getReadOnlyProperty(); + public ObservableList getOpenTabs() { + return openTabs; } public OptionalObjectProperty activeDatabaseProperty() { diff --git a/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java b/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java index 6a1a1af30bf..dfed854913d 100644 --- a/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java +++ b/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java @@ -131,8 +131,8 @@ boolean saveAs(Path file, SaveDatabaseMode mode) { context.setDatabasePath(file); // Hack: Mock a change event, so the tab title is redrawn - libraryTab.changedProperty().setValue(true); - libraryTab.changedProperty().setValue(false); + libraryTab.changedProperty().setValue(!libraryTab.changedProperty().getValue()); + libraryTab.changedProperty().setValue(!libraryTab.changedProperty().getValue()); // Reinstall AutosaveManager and BackupManager for the new file name libraryTab.resetChangeMonitorAndChangePane(); From 1ad25fe41198afb3003b8d0b877e14877c423e3b Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Sun, 18 Oct 2020 17:42:40 +0200 Subject: [PATCH 14/20] Changed getOpenTabs to getOpenDatabases in StateManager --- src/main/java/org/jabref/gui/JabRefFrame.java | 8 +++++++- src/main/java/org/jabref/gui/LibraryTab.java | 6 ++---- src/main/java/org/jabref/gui/StateManager.java | 7 +++---- .../java/org/jabref/gui/exporter/SaveDatabaseAction.java | 5 +---- 4 files changed, 13 insertions(+), 13 deletions(-) diff --git a/src/main/java/org/jabref/gui/JabRefFrame.java b/src/main/java/org/jabref/gui/JabRefFrame.java index e7b4254717d..16b3c091be7 100644 --- a/src/main/java/org/jabref/gui/JabRefFrame.java +++ b/src/main/java/org/jabref/gui/JabRefFrame.java @@ -143,6 +143,7 @@ import com.google.common.eventbus.Subscribe; import com.tobiasdiez.easybind.EasyBind; +import com.tobiasdiez.easybind.EasyObservableList; import org.controlsfx.control.PopOver; import org.controlsfx.control.TaskProgressView; import org.fxmisc.richtext.CodeArea; @@ -164,6 +165,8 @@ public class JabRefFrame extends BorderPane { private final FileHistoryMenu fileHistory; + @SuppressWarnings({"FieldCanBeLocal"}) private EasyObservableList openDatabaseList; + private final Stage mainStage; private final StateManager stateManager; private final CountingUndoManager undoManager; @@ -573,7 +576,10 @@ public void init() { initDragAndDrop(); // Bind global state - EasyBind.bindContent(stateManager.getOpenTabs(), tabbedPane.getTabs()); + + // This variable cannot be inlined, since otherwise the list created by EasyBind is being garbage collected + openDatabaseList = EasyBind.map(tabbedPane.getTabs(), tab -> ((LibraryTab) tab).getBibDatabaseContext()); + EasyBind.bindContent(stateManager.getOpenDatabases(), openDatabaseList); stateManager.activeDatabaseProperty().bind( EasyBind.map(tabbedPane.getSelectionModel().selectedItemProperty(), diff --git a/src/main/java/org/jabref/gui/LibraryTab.java b/src/main/java/org/jabref/gui/LibraryTab.java index 9e6baa22ea1..dc9d91ad067 100644 --- a/src/main/java/org/jabref/gui/LibraryTab.java +++ b/src/main/java/org/jabref/gui/LibraryTab.java @@ -139,7 +139,7 @@ public LibraryTab(JabRefFrame frame, Platform.runLater(() -> { EasyBind.subscribe(changedProperty, this::refreshTabTitle); // FIXME: currently the tab titles are not refreshed after a tab is closed - EasyBind.subscribe(Bindings.size(Globals.stateManager.getOpenTabs()), + EasyBind.subscribe(Bindings.size(Globals.stateManager.getOpenDatabases()), (databases) -> refreshTabTitle(changedProperty.getValue())); }); } @@ -256,9 +256,7 @@ private static void addSharedDbInformation(StringBuilder text, BibDatabaseContex private List collectAllDatabasePaths() { List list = new ArrayList<>(); - Globals.stateManager.getOpenTabs().stream() - .map(tab -> (LibraryTab) tab) - .map(LibraryTab::getBibDatabaseContext) + Globals.stateManager.getOpenDatabases().stream() .map(BibDatabaseContext::getDatabasePath) .forEachOrdered(pathOptional -> pathOptional.ifPresentOrElse( path -> list.add(path.toAbsolutePath().toString()), diff --git a/src/main/java/org/jabref/gui/StateManager.java b/src/main/java/org/jabref/gui/StateManager.java index 15235007998..f1ffee17247 100644 --- a/src/main/java/org/jabref/gui/StateManager.java +++ b/src/main/java/org/jabref/gui/StateManager.java @@ -16,7 +16,6 @@ import javafx.collections.ObservableMap; import javafx.concurrent.Task; import javafx.scene.Node; -import javafx.scene.control.Tab; import org.jabref.gui.util.CustomLocalDragboard; import org.jabref.gui.util.DialogWindowState; @@ -45,7 +44,7 @@ public class StateManager { private final CustomLocalDragboard localDragboard = new CustomLocalDragboard(); - private final ObservableList openTabs = FXCollections.observableArrayList(); + private final ObservableList openDatabases = FXCollections.observableArrayList(); private final OptionalObjectProperty activeDatabase = OptionalObjectProperty.empty(); private final ReadOnlyListWrapper activeGroups = new ReadOnlyListWrapper<>(FXCollections.observableArrayList()); private final ObservableList selectedEntries = FXCollections.observableArrayList(); @@ -66,8 +65,8 @@ public CustomLocalDragboard getLocalDragboard() { return localDragboard; } - public ObservableList getOpenTabs() { - return openTabs; + public ObservableList getOpenDatabases() { + return openDatabases; } public OptionalObjectProperty activeDatabaseProperty() { diff --git a/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java b/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java index dfed854913d..bb1e678bf34 100644 --- a/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java +++ b/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java @@ -129,10 +129,7 @@ boolean saveAs(Path file, SaveDatabaseMode mode) { // we managed to successfully save the file // thus, we can store the store the path into the context context.setDatabasePath(file); - - // Hack: Mock a change event, so the tab title is redrawn - libraryTab.changedProperty().setValue(!libraryTab.changedProperty().getValue()); - libraryTab.changedProperty().setValue(!libraryTab.changedProperty().getValue()); + // FIXME: We need to refresh the tab titles // Reinstall AutosaveManager and BackupManager for the new file name libraryTab.resetChangeMonitorAndChangePane(); From 85fc7850fe9010b2d8602ec2df6fcba1cff0af0d Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Sun, 18 Oct 2020 20:59:42 +0200 Subject: [PATCH 15/20] Fixed refresh of tab title on tab close and open --- src/main/java/org/jabref/gui/JabRefFrame.java | 2 +- src/main/java/org/jabref/gui/LibraryTab.java | 11 +++++------ .../gui/importer/ParserResultWarningDialog.java | 6 +++--- 3 files changed, 9 insertions(+), 10 deletions(-) diff --git a/src/main/java/org/jabref/gui/JabRefFrame.java b/src/main/java/org/jabref/gui/JabRefFrame.java index 16b3c091be7..ad19354b054 100644 --- a/src/main/java/org/jabref/gui/JabRefFrame.java +++ b/src/main/java/org/jabref/gui/JabRefFrame.java @@ -556,7 +556,7 @@ public List getLibraryTabs() { .collect(Collectors.toList()); } - public void showBasePanelAt(int i) { + public void showLibraryTabAt(int i) { tabbedPane.getSelectionModel().select(i); } diff --git a/src/main/java/org/jabref/gui/LibraryTab.java b/src/main/java/org/jabref/gui/LibraryTab.java index dc9d91ad067..05c57c1f089 100644 --- a/src/main/java/org/jabref/gui/LibraryTab.java +++ b/src/main/java/org/jabref/gui/LibraryTab.java @@ -9,11 +9,11 @@ import java.util.Optional; import javafx.application.Platform; -import javafx.beans.binding.Bindings; import javafx.beans.property.BooleanProperty; import javafx.beans.property.SimpleBooleanProperty; import javafx.beans.property.SimpleStringProperty; import javafx.beans.property.StringProperty; +import javafx.collections.ListChangeListener; import javafx.geometry.Orientation; import javafx.scene.Node; import javafx.scene.control.SplitPane; @@ -137,10 +137,9 @@ public LibraryTab(JabRefFrame frame, this.entryEditor = new EntryEditor(this, externalFileTypes); Platform.runLater(() -> { - EasyBind.subscribe(changedProperty, this::refreshTabTitle); - // FIXME: currently the tab titles are not refreshed after a tab is closed - EasyBind.subscribe(Bindings.size(Globals.stateManager.getOpenDatabases()), - (databases) -> refreshTabTitle(changedProperty.getValue())); + EasyBind.subscribe(changedProperty, this::updateTabTitle); + Globals.stateManager.getOpenDatabases().addListener((ListChangeListener) c -> + updateTabTitle(changedProperty.getValue())); }); } @@ -160,7 +159,7 @@ public LibraryTab(JabRefFrame frame, * Example: * jabref-authors.bib (BibLaTeX) - testbib */ - private void refreshTabTitle(boolean isChanged) { + public void updateTabTitle(boolean isChanged) { boolean isAutosaveEnabled = preferencesService.getShouldAutosave(); DatabaseLocation databaseLocation = bibDatabaseContext.getLocation(); diff --git a/src/main/java/org/jabref/gui/importer/ParserResultWarningDialog.java b/src/main/java/org/jabref/gui/importer/ParserResultWarningDialog.java index 43a0b2f4afe..ec07cbc93b4 100644 --- a/src/main/java/org/jabref/gui/importer/ParserResultWarningDialog.java +++ b/src/main/java/org/jabref/gui/importer/ParserResultWarningDialog.java @@ -45,7 +45,7 @@ public static void showParserResultWarningDialog(final ParserResult parserResult // Switch tab if asked to do so if (dataBaseNumber >= 0) { - jabRefFrame.showBasePanelAt(dataBaseNumber); + jabRefFrame.showLibraryTabAt(dataBaseNumber); } // Generate string with warning texts @@ -59,10 +59,10 @@ public static void showParserResultWarningDialog(final ParserResult parserResult // Generate dialog title String dialogTitle; - if (dataBaseNumber < 0) { + if (dataBaseNumber < 0 || parserResult.getPath().isEmpty()) { dialogTitle = Localization.lang("Warnings"); } else { - dialogTitle = Localization.lang("Warnings") + " (" + parserResult.getFile().get().getName() + ")"; + dialogTitle = Localization.lang("Warnings") + " (" + parserResult.getPath().get().getFileName() + ")"; } // Show dialog From 067325d990433f2a71236eac92ed313e91548fa9 Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Sun, 18 Oct 2020 21:18:53 +0200 Subject: [PATCH 16/20] Fixed SaveDatabaseActionTest --- src/main/java/org/jabref/gui/LibraryTab.java | 5 +++++ .../java/org/jabref/gui/exporter/SaveDatabaseAction.java | 4 +--- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/src/main/java/org/jabref/gui/LibraryTab.java b/src/main/java/org/jabref/gui/LibraryTab.java index 05c57c1f089..c3c143de633 100644 --- a/src/main/java/org/jabref/gui/LibraryTab.java +++ b/src/main/java/org/jabref/gui/LibraryTab.java @@ -708,6 +708,11 @@ public void markNonUndoableBaseChanged() { this.changedProperty.setValue(true); } + public void resetChangedProperties() { + this.nonUndoableChangeProperty.setValue(false); + this.changedProperty.setValue(false); + } + private class GroupTreeListener { @Subscribe diff --git a/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java b/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java index bb1e678bf34..7e98241ad7d 100644 --- a/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java +++ b/src/main/java/org/jabref/gui/exporter/SaveDatabaseAction.java @@ -196,9 +196,7 @@ private boolean save(Path targetPath, SaveDatabaseMode mode) { if (success) { libraryTab.getUndoManager().markUnchanged(); - // After a successful save the following statement marks that the base is unchanged since last save - libraryTab.nonUndoableChangeProperty().setValue(false); - libraryTab.changedProperty().setValue(false); + libraryTab.resetChangedProperties(); } return success; } catch (SaveException ex) { From 5324a9fd88ca070405429712f3b41ae378b163a3 Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Mon, 19 Oct 2020 22:49:26 +0200 Subject: [PATCH 17/20] Removed nameProperty and bound tab title to frame title --- src/main/java/org/jabref/gui/JabRefFrame.java | 12 +++----- src/main/java/org/jabref/gui/LibraryTab.java | 29 ++----------------- 2 files changed, 7 insertions(+), 34 deletions(-) diff --git a/src/main/java/org/jabref/gui/JabRefFrame.java b/src/main/java/org/jabref/gui/JabRefFrame.java index ad19354b054..0cb5141367f 100644 --- a/src/main/java/org/jabref/gui/JabRefFrame.java +++ b/src/main/java/org/jabref/gui/JabRefFrame.java @@ -13,7 +13,6 @@ import java.util.stream.Collectors; import javafx.application.Platform; -import javafx.beans.Observable; import javafx.beans.binding.Bindings; import javafx.beans.binding.StringBinding; import javafx.beans.value.ChangeListener; @@ -625,13 +624,10 @@ public void init() { libraryTab.getUndoManager().postUndoRedoEvent(); libraryTab.getMainTable().requestFocus(); - // Set window title - ArrayList observables = new ArrayList<>(List.of(libraryTab.changedProperty(), libraryTab.nameProperty())); - StringBinding windowTitle = Bindings.createStringBinding(() -> - (libraryTab.changedProperty().getValue() ? "*" : "") - + libraryTab.nameProperty().getValue() + " \u2013 " - + FRAME_TITLE, - observables.toArray(Observable[]::new)); + // Set window title - copy tab title + StringBinding windowTitle = Bindings.createStringBinding( + () -> libraryTab.textProperty().getValue() + " \u2013 " + FRAME_TITLE, + libraryTab.textProperty()); mainStage.titleProperty().bind(windowTitle); }); initShowTrackingNotification(); diff --git a/src/main/java/org/jabref/gui/LibraryTab.java b/src/main/java/org/jabref/gui/LibraryTab.java index c3c143de633..b5fe5dd5b86 100644 --- a/src/main/java/org/jabref/gui/LibraryTab.java +++ b/src/main/java/org/jabref/gui/LibraryTab.java @@ -11,8 +11,6 @@ import javafx.application.Platform; import javafx.beans.property.BooleanProperty; import javafx.beans.property.SimpleBooleanProperty; -import javafx.beans.property.SimpleStringProperty; -import javafx.beans.property.StringProperty; import javafx.collections.ListChangeListener; import javafx.geometry.Orientation; import javafx.scene.Node; @@ -93,7 +91,6 @@ public class LibraryTab extends Tab { private final BooleanProperty nonUndoableChangeProperty = new SimpleBooleanProperty(false); // Used to track whether the base has changed since last save. - private final StringProperty nameProperty = new SimpleStringProperty(); private BibEntry showing; private SuggestionProviders suggestionProviders; @SuppressWarnings({"FieldCanBeLocal"}) private Subscription dividerPositionSubscription; @@ -145,19 +142,13 @@ public LibraryTab(JabRefFrame frame, /** * Sets the title of the tab - * filename modification-asterisk (database-mode) – path-fragment + * modification-asterisk filename – path-fragment * - * (path-fragment is only shown if filename is not (globally) unique) * The modification-asterisk (*) is shown if the file was modified since last save + * (path-fragment is only shown if filename is not (globally) unique) * * Example: - * jabref-authors.bib* (BibLaTeX) – testbib - * - * For the JabRef window, the variable nameProperty is proviced, consisting if * - * filename (database-mode) - path-fragment - * - * Example: - * jabref-authors.bib (BibLaTeX) - testbib + * *jabref-authors.bib – testbib */ public void updateTabTitle(boolean isChanged) { boolean isAutosaveEnabled = preferencesService.getShouldAutosave(); @@ -167,13 +158,11 @@ public void updateTabTitle(boolean isChanged) { StringBuilder tabTitle = new StringBuilder(); StringBuilder toolTipText = new StringBuilder(); - StringBuilder tabName = new StringBuilder(); if (file.isPresent()) { Path databasePath = file.get(); String fileName = databasePath.getFileName().toString(); tabTitle.append(fileName); - tabName.append(fileName); toolTipText.append(databasePath.toAbsolutePath().toString()); if (isChanged && !isAutosaveEnabled) { tabTitle.append('*'); @@ -184,12 +173,9 @@ public void updateTabTitle(boolean isChanged) { addSharedDbInformation(tabTitle, bibDatabaseContext); toolTipText.append(' '); addSharedDbInformation(toolTipText, bibDatabaseContext); - tabName.append(" \u2013 "); - addSharedDbInformation(tabName, bibDatabaseContext); } addModeInfo(toolTipText, bibDatabaseContext); - addModeInfo(tabName, bibDatabaseContext); if (isChanged && !isAutosaveEnabled) { addChangedInformation(toolTipText, fileName); @@ -206,32 +192,27 @@ public void updateTabTitle(boolean isChanged) { // remove filename uniquePath = uniquePath.substring(0, uniquePath.lastIndexOf(File.separator)); tabTitle.append(" \u2013 ").append(uniquePath); - tabName.append(" \u2013 ").append(uniquePath); } } else { if (databaseLocation == DatabaseLocation.LOCAL) { tabTitle.append(Localization.lang("untitled")); - tabName.append(Localization.lang("untitled")); if (bibDatabaseContext.getDatabase().hasEntries()) { // if the database is not empty and no file is assigned, // the database came from an import and has to be treated somehow // -> mark as changed tabTitle.append('*'); - tabName.append('*'); } } else { addSharedDbInformation(tabTitle, bibDatabaseContext); addSharedDbInformation(toolTipText, bibDatabaseContext); } addModeInfo(toolTipText, bibDatabaseContext); - addModeInfo(tabName, bibDatabaseContext); if (databaseLocation == DatabaseLocation.LOCAL && bibDatabaseContext.getDatabase().hasEntries()) { addChangedInformation(toolTipText, Localization.lang("untitled")); } } textProperty().setValue(tabTitle.toString()); - nameProperty.setValue(tabName.toString()); setTooltip(new Tooltip(toolTipText.toString())); } @@ -683,10 +664,6 @@ public void cut() { mainTable.cut(); } - public StringProperty nameProperty() { - return nameProperty; - } - public BooleanProperty changedProperty() { return changedProperty; } From 9c8b91b17fa717aee5a7daf3233f58bae1e0f893 Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Mon, 19 Oct 2020 22:55:52 +0200 Subject: [PATCH 18/20] CHANGELOG.md --- CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 5c26f8942fc..e92fbe4de51 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -37,6 +37,7 @@ inserting new citations in a OpenOffic/LibreOffice document. [#6957](https://git - We improved the duplicate detection when identifiers like DOI or arxiv are semantiaclly the same, but just syntactically differ (e.g. with or without http(s):// prefix). [#6707](https://github.com/JabRef/jabref/issues/6707) - We changed in the group interface "Generate groups from keywords in a BibTeX field" by "Generate groups from keywords in the following field". [#6983](https://github.com/JabRef/jabref/issues/6983) - We changed the name of a group type from "Searching for keywords" to "Searching for a keyword". [6995](https://github.com/JabRef/jabref/pull/6995) +- We changed the way JabRef displays the title of a tab and of the window. [4161](https://github.com/JabRef/jabref/issues/4161) ### Fixed From 506e8de01edc93d53712bdeee2a694316d68a690 Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Mon, 19 Oct 2020 23:00:44 +0200 Subject: [PATCH 19/20] Changed tooltip to display multiline texts --- src/main/java/org/jabref/gui/LibraryTab.java | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/main/java/org/jabref/gui/LibraryTab.java b/src/main/java/org/jabref/gui/LibraryTab.java index b5fe5dd5b86..f0e169fb26b 100644 --- a/src/main/java/org/jabref/gui/LibraryTab.java +++ b/src/main/java/org/jabref/gui/LibraryTab.java @@ -217,13 +217,13 @@ public void updateTabTitle(boolean isChanged) { } private static void addChangedInformation(StringBuilder text, String fileName) { - text.append(". "); + text.append("\n"); text.append(Localization.lang("Library '%0' has changed.", fileName)); } private static void addModeInfo(StringBuilder text, BibDatabaseContext bibDatabaseContext) { String mode = bibDatabaseContext.getMode().getFormattedName(); - String modeInfo = String.format(" (%s)", Localization.lang("%0 mode", mode)); + String modeInfo = String.format("\n%s", Localization.lang("%0 mode", mode)); text.append(modeInfo); } From 45514a2f2732139db22cef064e7a528bc93c12d5 Mon Sep 17 00:00:00 2001 From: Carl Christian Snethlage Date: Mon, 19 Oct 2020 23:06:14 +0200 Subject: [PATCH 20/20] Reordered display and added comments --- src/main/java/org/jabref/gui/LibraryTab.java | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/src/main/java/org/jabref/gui/LibraryTab.java b/src/main/java/org/jabref/gui/LibraryTab.java index f0e169fb26b..2cb7174d95c 100644 --- a/src/main/java/org/jabref/gui/LibraryTab.java +++ b/src/main/java/org/jabref/gui/LibraryTab.java @@ -160,13 +160,16 @@ public void updateTabTitle(boolean isChanged) { StringBuilder toolTipText = new StringBuilder(); if (file.isPresent()) { + // Modification asterisk + if (isChanged && !isAutosaveEnabled) { + tabTitle.append('*'); + } + + // Filename Path databasePath = file.get(); String fileName = databasePath.getFileName().toString(); tabTitle.append(fileName); toolTipText.append(databasePath.toAbsolutePath().toString()); - if (isChanged && !isAutosaveEnabled) { - tabTitle.append('*'); - } if (databaseLocation == DatabaseLocation.SHARED) { tabTitle.append(" \u2013 "); @@ -175,13 +178,15 @@ public void updateTabTitle(boolean isChanged) { addSharedDbInformation(toolTipText, bibDatabaseContext); } + // Database mode addModeInfo(toolTipText, bibDatabaseContext); + // Changed information (tooltip) if (isChanged && !isAutosaveEnabled) { addChangedInformation(toolTipText, fileName); } - // Add unique path fragment + // Unique path fragment List uniquePathParts = FileUtil.uniquePathSubstrings(collectAllDatabasePaths()); Optional uniquePathPart = uniquePathParts.stream() .filter(part -> databasePath.toString().contains(part)