mirror of
				https://github.com/zadam/trilium.git
				synced 2025-10-26 07:46:30 +01:00 
			
		
		
		
	feat(native-buttons): fallback to original implementation for Linux
This commit is contained in:
		| @@ -1,6 +1,7 @@ | ||||
| import FlexContainer from "../widgets/containers/flex_container.js"; | ||||
| import GlobalMenuWidget from "../widgets/buttons/global_menu.js"; | ||||
| import TabRowWidget from "../widgets/tab_row.js"; | ||||
| import TitleBarButtonsWidget from "../widgets/title_bar_buttons.js"; | ||||
| import LeftPaneContainer from "../widgets/containers/left_pane_container.js"; | ||||
| import NoteTreeWidget from "../widgets/note_tree.js"; | ||||
| import NoteTitleWidget from "../widgets/note_title.js"; | ||||
| @@ -94,7 +95,11 @@ export default class DesktopLayout { | ||||
|  | ||||
|         const launcherPaneIsHorizontal = (options.get("layoutOrientation") === "horizontal"); | ||||
|         const launcherPane = this.#buildLauncherPane(launcherPaneIsHorizontal); | ||||
|         const isMac = (window.glob.platform === "darwin"); | ||||
|         const isWindows = (window.glob.platform === "windows"); | ||||
|         const hasNativeTitleBar = (window.glob.hasNativeTitleBar); | ||||
|         const fullWidthTabBar = true; | ||||
|         const customTitleBarButtons = (hasNativeTitleBar && !isMac && !isWindows); | ||||
|  | ||||
|         return new RootContainer(true) | ||||
|             .setParent(appContext) | ||||
| @@ -104,6 +109,7 @@ export default class DesktopLayout { | ||||
|                 .child(new FlexContainer( "row").id("tab-row-left-spacer")) | ||||
|                 .optChild(launcherPaneIsHorizontal, new LeftPaneToggleWidget(true)) | ||||
|                 .child(new TabRowWidget().class("full-width")) | ||||
|                 .optChild(customTitleBarButtons, new TitleBarButtonsWidget()) | ||||
|                 .css('height', '40px') | ||||
|                 .css('background-color', 'var(--launcher-pane-background-color)') | ||||
|                 .setParent(appContext) | ||||
| @@ -122,6 +128,7 @@ export default class DesktopLayout { | ||||
|                     .css("flex-grow", "1") | ||||
|                     .optChild(!fullWidthTabBar, new FlexContainer('row') | ||||
|                         .child(new TabRowWidget()) | ||||
|                         .optChild(customTitleBarButtons, new TitleBarButtonsWidget()) | ||||
|                         .css('height', '40px') | ||||
|                     ) | ||||
|                     .child(new FlexContainer('row') | ||||
|   | ||||
							
								
								
									
										112
									
								
								src/public/app/widgets/title_bar_buttons.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										112
									
								
								src/public/app/widgets/title_bar_buttons.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,112 @@ | ||||
| import BasicWidget from "./basic_widget.js"; | ||||
| import options from "../services/options.js"; | ||||
| import utils from "../services/utils.js"; | ||||
| import { t } from "../services/i18n.js"; | ||||
|  | ||||
| const TPL = ` | ||||
| <div class="title-bar-buttons"> | ||||
|     <style> | ||||
|     .title-bar-buttons { | ||||
|         flex-shrink: 0; | ||||
|     } | ||||
|  | ||||
|     .title-bar-buttons div button { | ||||
|         border: none !important; | ||||
|         border-radius: 0; | ||||
|         background: none !important; | ||||
|         font-size: 150%; | ||||
|         height: 40px; | ||||
|         width: 40px; | ||||
|         display: flex; | ||||
|         align-items: center; | ||||
|         justify-content: center; | ||||
|     } | ||||
|      | ||||
|     .title-bar-buttons div:hover button { | ||||
|         background-color: var(--accented-background-color) !important; | ||||
|     } | ||||
|  | ||||
|     .title-bar-buttons div { | ||||
|         display: inline-block; | ||||
|         height: 40px; | ||||
|         width: 40px; | ||||
|     } | ||||
|      | ||||
|     .title-bar-buttons .top-btn.active{ | ||||
|         background-color:var(--accented-background-color); | ||||
|     } | ||||
|  | ||||
|     .title-bar-buttons .btn.focus, .title-bar-buttons .btn:focus { | ||||
|         box-shadow: none; | ||||
|     } | ||||
|     </style> | ||||
|  | ||||
|     <!-- divs act as a hitbox for the buttons, making them clickable on corners --> | ||||
|     <div class="top-btn" title="${t("title_bar_buttons.window-on-top")}"><button class="btn bx bx-pin"></button></div> | ||||
|     <div class="minimize-btn"><button class="btn bx bx-minus"></button></div> | ||||
|     <div class="maximize-btn"><button class="btn bx bx-checkbox"></button></div> | ||||
|     <div class="close-btn"><button class="btn bx bx-x"></button></div> | ||||
| </div>`; | ||||
|  | ||||
| export default class TitleBarButtonsWidget extends BasicWidget { | ||||
|     doRender() { | ||||
|         if (!utils.isElectron() || options.is('nativeTitleBarVisible')) { | ||||
|             return this.$widget = $('<div>'); | ||||
|         } | ||||
|  | ||||
|         this.$widget = $(TPL); | ||||
|         this.contentSized(); | ||||
|  | ||||
|         const $topBtn = this.$widget.find(".top-btn"); | ||||
|         const $minimizeBtn = this.$widget.find(".minimize-btn"); | ||||
|         const $maximizeBtn = this.$widget.find(".maximize-btn"); | ||||
|         const $closeBtn = this.$widget.find(".close-btn"); | ||||
|  | ||||
|         // When the window is restarted, the window will not be reset when it is set to the top, | ||||
|         // so get the window status and set the icon background | ||||
|         setTimeout(() => { | ||||
|             const remote = utils.dynamicRequire('@electron/remote'); | ||||
|             if (remote.BrowserWindow.getFocusedWindow()?.isAlwaysOnTop()) { | ||||
|                 $topBtn.addClass('active'); | ||||
|             } | ||||
|         }, 1000); | ||||
|  | ||||
|         $topBtn.on('click', () => { | ||||
|             $topBtn.trigger('blur'); | ||||
|             const remote = utils.dynamicRequire('@electron/remote'); | ||||
|             const focusedWindow = remote.BrowserWindow.getFocusedWindow(); | ||||
|             const isAlwaysOnTop = focusedWindow.isAlwaysOnTop() | ||||
|             if (isAlwaysOnTop) { | ||||
|                 focusedWindow.setAlwaysOnTop(false) | ||||
|                 $topBtn.removeClass('active'); | ||||
|             } else { | ||||
|                 focusedWindow.setAlwaysOnTop(true); | ||||
|                 $topBtn.addClass('active'); | ||||
|             } | ||||
|         }); | ||||
|  | ||||
|         $minimizeBtn.on('click', () => { | ||||
|             $minimizeBtn.trigger('blur'); | ||||
|             const remote = utils.dynamicRequire('@electron/remote'); | ||||
|             remote.BrowserWindow.getFocusedWindow().minimize(); | ||||
|         }); | ||||
|  | ||||
|         $maximizeBtn.on('click', () => { | ||||
|             $maximizeBtn.trigger('blur'); | ||||
|             const remote = utils.dynamicRequire('@electron/remote'); | ||||
|             const focusedWindow = remote.BrowserWindow.getFocusedWindow(); | ||||
|  | ||||
|             if (focusedWindow.isMaximized()) { | ||||
|                 focusedWindow.unmaximize(); | ||||
|             } else { | ||||
|                 focusedWindow.maximize(); | ||||
|             } | ||||
|         }); | ||||
|  | ||||
|         $closeBtn.on('click', () => { | ||||
|             $closeBtn.trigger('blur'); | ||||
|             const remote = utils.dynamicRequire('@electron/remote'); | ||||
|             remote.BrowserWindow.getFocusedWindow().close(); | ||||
|         }); | ||||
|     } | ||||
| } | ||||
| @@ -114,9 +114,21 @@ async function createMainWindow(app: App) { | ||||
|  | ||||
| function getWindowExtraOpts() { | ||||
|     const extraOpts: Partial<BrowserWindowConstructorOptions> = {}; | ||||
|  | ||||
|     const isMac = (process.platform === "darwin"); | ||||
|     const isWindows = (process.platform === "win32"); | ||||
|  | ||||
|     if (!optionService.getOptionBool('nativeTitleBarVisible')) { | ||||
|         extraOpts.titleBarStyle = (process.platform !== "darwin" ? "hidden" : "hiddenInset"); | ||||
|         extraOpts.titleBarOverlay = true; | ||||
|         if (isMac) { | ||||
|             extraOpts.titleBarStyle = "hiddenInset"; | ||||
|             extraOpts.titleBarOverlay = true; | ||||
|         } else if (isWindows) { | ||||
|             extraOpts.titleBarStyle = "hidden"; | ||||
|             extraOpts.titleBarOverlay = true; | ||||
|         } else { | ||||
|             // Linux or other platforms. | ||||
|             extraOpts.frame = false; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     return extraOpts; | ||||
|   | ||||
| @@ -36,6 +36,8 @@ | ||||
|         triliumVersion: "<%= triliumVersion %>", | ||||
|         assetPath: "<%= assetPath %>", | ||||
|         appPath: "<%= appPath %>", | ||||
|         platform: "<%= platform %>", | ||||
|         hasNativeTitleBar: "<%= hasNativeTitleBar %>", | ||||
|         TRILIUM_SAFE_MODE: <%= !!process.env.TRILIUM_SAFE_MODE %> | ||||
|     }; | ||||
| </script> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user