Merge branch 'dev' of https://github.com/CloudHill/notion-enhancer into dev
							
								
								
									
										56
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						| @ -2,11 +2,61 @@ | |||||||
| 
 | 
 | ||||||
| **potential future features (not confirmed)** | **potential future features (not confirmed)** | ||||||
| 
 | 
 | ||||||
| - [groupy-like tabbing](https://www.npmjs.com/package/electron-tabs) |  | ||||||
| - [improved responsiveness](https://chrome.google.com/webstore/detail/notion%20%20-responsiveness-f/leadcilhbmibbkgbnjgmmnfgnnhmeddk) |  | ||||||
| - [highlight/mark viewer](https://chrome.google.com/webstore/detail/notion%2B-mark-manager/hipgmnlpnimedfepbfbfiaobohhffcfc) | - [highlight/mark viewer](https://chrome.google.com/webstore/detail/notion%2B-mark-manager/hipgmnlpnimedfepbfbfiaobohhffcfc) | ||||||
| - [advanced math editor](https://github.com/Manueloccorso/NotionMathEditor_BrowserExtension) | - [advanced math editor](https://github.com/Manueloccorso/NotionMathEditor_BrowserExtension) | ||||||
| - re-orderable extensions | 
 | ||||||
|  | ### v0.10.0 (wip) | ||||||
|  | 
 | ||||||
|  | a flexibility update. | ||||||
|  | 
 | ||||||
|  | - new: mods can be reordered in the menu to control what order styling/scripts are added/executed in. | ||||||
|  |   higher up on the list = higher priority of application = loaded last in order to override others. | ||||||
|  |   (excluding the core, which though pinned to the top of the list is always loaded first so theming | ||||||
|  |   variables can be modified.) | ||||||
|  | - new: in-page columns are disabled/wrapped and pages are wider when | ||||||
|  |   the window is narrower than 600px for improved responsiveness. | ||||||
|  | - new: relaunch button in tray menu. | ||||||
|  | - new: a core mod option to make transitions snappy/0s. | ||||||
|  | - new: a core mod option for a default page id/url (all new windows will load it instead of the | ||||||
|  |   normal "most recent" page). | ||||||
|  | - new: css variables for increasing line spacing/paragraph margins. | ||||||
|  | - new: patch the notion:// url scheme/protocol to work on linux. | ||||||
|  | - improved: menu will now respect integrated titlebar setting. | ||||||
|  | - improved: use keyup listeners instead of a globalShortcut for the enhancements menu toggle. | ||||||
|  | - bugfix: removed messenger emoji set as the provider no longer supports it. | ||||||
|  | - bugfix: remove shadow around light mode board headers | ||||||
|  |   \+ minor text colour fixes for night shift theming. | ||||||
|  | - bugfix: properly detect/respond to `EACCES`/`EBUSY` errors. | ||||||
|  | - bugfix: night shift checks every interaction, | ||||||
|  |   will respond to system changes without any manual changes. | ||||||
|  | - bugfix: toc blocks can have text colours. | ||||||
|  | - bugfix: bypass preview extension works with the back/forward keyboard shortcuts. | ||||||
|  | - bugfix: (maybe) fix csp issues under proxy. | ||||||
|  | - bugfix: remove focus mode footer from neutral theme. | ||||||
|  | - bugfix: improvements to the colour theming, particularly to make real- and fake-light/dark | ||||||
|  |   modes (as applied by the night shift extension) look consistent. | ||||||
|  |   relevant variables (assuming all are prefixed by `--theme_[dark|light]--`): | ||||||
|  |   `box-shadow`, `box-shadow_strong`, `select_input`, and `ui-border` | ||||||
|  | - bugfix: font sizing applied to overlays/previews. | ||||||
|  | - bugfix: removed typo in variable name for brown text. | ||||||
|  | - bugfix: primary-colour text (mainly in "add a \_" popups) is now properly themed. | ||||||
|  | - bugfix: right-to-left extension applies to text in columns. | ||||||
|  | - tweak: sticky table/list rows. | ||||||
|  | - theme: "material ocean" = an oceanic colour palette. | ||||||
|  | - theme: "dracula" = a theme based on the popular dracula color palette | ||||||
|  |   originally by zeno rocha and friends. | ||||||
|  | - extension: "tabs" = have multiple notion pages open in a single window. | ||||||
|  | 
 | ||||||
|  | a fork of notion-deb-builder that does generate an app.asar has been created and is once again supported. | ||||||
|  | 
 | ||||||
|  | // todo | ||||||
|  | 
 | ||||||
|  | - new: menu shows theme conflicts. | ||||||
|  | - improved: default option for showing/hiding page properties. | ||||||
|  | - bugfix: night shift working on macOS. | ||||||
|  | - bugfix: windows are properly hidden/shown on macOS. | ||||||
|  | - extension: "tweaks" = common layout changes. | ||||||
|  | - update themes to new variables. | ||||||
| 
 | 
 | ||||||
| ### v0.9.1 (2020-09-26) | ### v0.9.1 (2020-09-26) | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -20,7 +20,7 @@ _for examples of the stuff described below in action._ | |||||||
| 
 | 
 | ||||||
| _at the moment, for ease of development and use (and security assurance), there's no way for users_ | _at the moment, for ease of development and use (and security assurance), there's no way for users_ | ||||||
| _to install their own modules. this means that testing modules requires_ | _to install their own modules. this means that testing modules requires_ | ||||||
| _[running a dev build of the enhancer](DOCUMENTATION.md#testing). a better system is in the works._ | _[running a dev build of the enhancer](https://github.com/dragonwocky/notion-enhancer/blob/master/CONTRIBUTING.md#testing). a better system is in the works._ | ||||||
| 
 | 
 | ||||||
| _once your mod is working, open a pull request to add it to the enhancer!_ | _once your mod is working, open a pull request to add it to the enhancer!_ | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										51
									
								
								README.md
									
									
									
									
									
								
							
							
						
						| @ -17,6 +17,8 @@ for support, join the [discord server](https://discord.gg/sFWPXtA). | |||||||
| - the [official windows/mac releases](https://notion.so/desktop). | - the [official windows/mac releases](https://notion.so/desktop). | ||||||
| - the arch linux AUR [notion-app](https://aur.archlinux.org/packages/notion-app/) package. | - the arch linux AUR [notion-app](https://aur.archlinux.org/packages/notion-app/) package. | ||||||
| - the linux [notion-app](https://github.com/jaredallard/notion-app) installer. | - the linux [notion-app](https://github.com/jaredallard/notion-app) installer. | ||||||
|  | - [@haydn-jones](https://github.com/haydn-jones/)'s fork of the | ||||||
|  |   linux [notion-deb-builder](https://github.com/haydn-jones/notion-deb-builder). | ||||||
| 
 | 
 | ||||||
| (it can also be run from the wsl to apply enhancements to the windows app.) | (it can also be run from the wsl to apply enhancements to the windows app.) | ||||||
| 
 | 
 | ||||||
| @ -31,10 +33,23 @@ a chrome extension may be coming soon for web client support. | |||||||
| 
 | 
 | ||||||
| during installation/removal, make sure no notion processes are running! (check your task manager.) | during installation/removal, make sure no notion processes are running! (check your task manager.) | ||||||
| 
 | 
 | ||||||
| **win10, macOS** | **win10** | ||||||
| 
 | 
 | ||||||
| 1. [install node.js](https://nodejs.org/en/download/) (_a computer restart may be required here._) | [install node.js](https://nodejs.org/en/download/) (_a computer restart may be required here_), | ||||||
| 2. execute `npm i -g notion-enhancer` in the terminal/command prompt. | then execute `npm i -g notion-enhancer` in the command prompt. | ||||||
|  | 
 | ||||||
|  | **macOS** | ||||||
|  | 
 | ||||||
|  | [install node.js](https://nodejs.org/en/download/) (_a computer restart may be required here_), | ||||||
|  | then execute the following lines in the terminal: | ||||||
|  | 
 | ||||||
|  | ``` | ||||||
|  | sudo chmod -R a+wr /usr/local/lib/node_modules | ||||||
|  | sudo chmod -R a+wr /usr/local/bin | ||||||
|  | sudo chmod -R a+wr /Applications/Notion/Contents/Resources | ||||||
|  | sudo chmod -R a+wr /Applications/Notion.app/Contents/Resources | ||||||
|  | npm i -g notion-enhancer | ||||||
|  | ``` | ||||||
| 
 | 
 | ||||||
| **debian/ubuntu, chromeOS, WSL (to modify the win10 app)** | **debian/ubuntu, chromeOS, WSL (to modify the win10 app)** | ||||||
| 
 | 
 | ||||||
| @ -43,7 +58,7 @@ execute the following lines in the terminal: | |||||||
| ``` | ``` | ||||||
| bash curl -sL https://deb.nodesource.com setup_current.x | sudo -E bash - | bash curl -sL https://deb.nodesource.com setup_current.x | sudo -E bash - | ||||||
| sudo apt-get install -y nodejs | sudo apt-get install -y nodejs | ||||||
| sudo npm i -g notion-enhancer | npm i -g notion-enhancer | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| **arch linux, manjaro** | **arch linux, manjaro** | ||||||
| @ -81,6 +96,14 @@ Options: | |||||||
|   -v, --version  : display version number |   -v, --version  : display version number | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
|  | ### faq | ||||||
|  | 
 | ||||||
|  | **the themes aren't working?** | ||||||
|  | 
 | ||||||
|  | if you pick a dark theme it will only be applied if notion is in dark mode, | ||||||
|  | and if you pick a light theme it will only work if notion is in light mode. | ||||||
|  | do `CMD/CTRL+SHIFT+L` to toggle between them. | ||||||
|  | 
 | ||||||
| **is this against notion's terms of service? can i get in trouble for using it?** | **is this against notion's terms of service? can i get in trouble for using it?** | ||||||
| 
 | 
 | ||||||
| definitely not! i contacted their support team to check, and the response was awesome: | definitely not! i contacted their support team to check, and the response was awesome: | ||||||
| @ -91,8 +114,16 @@ team to take to heart for future improvements." | |||||||
| 
 | 
 | ||||||
| ## features | ## features | ||||||
| 
 | 
 | ||||||
| once applied, modules can be configured via the graphical menu, which is opened from | most of the enhancer's functionality is split into configurable enhancement modules, | ||||||
| the tray/menubar icon or with `ALT+E`. | but some basic improvements are built in by default: | ||||||
|  | 
 | ||||||
|  | - the notion:// url scheme/protocol is patched to work on linux. | ||||||
|  | - in-page columns are disabled/wrapped and pages are wider when | ||||||
|  |   the window is narrower than 600px for improved responsiveness. | ||||||
|  | - a tray/menubar icon: links relevant to the enhancer + buttons to manage notion windows. | ||||||
|  | 
 | ||||||
|  | once applied, modules can be configured via the graphical menu, | ||||||
|  | which is opened from the tray/menubar icon or with `OPTION/ALT+E`. | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
| 
 | 
 | ||||||
| @ -164,7 +195,8 @@ on top of other windows even if it's not focused. | |||||||
| 
 | 
 | ||||||
| **tags:** #extension | **tags:** #extension | ||||||
| 
 | 
 | ||||||
| **description:** link files for small client-side tweaks. | **description:** link files for small client-side tweaks. (not sure how to do something? check out the | ||||||
|  | [tweaks](https://github.com/dragonwocky/notion-enhancer/blob/master/TWEAKS.md) collection.) | ||||||
| 
 | 
 | ||||||
| **author**: [dragonwocky](https://github.com/dragonwocky/) | **author**: [dragonwocky](https://github.com/dragonwocky/) | ||||||
| 
 | 
 | ||||||
| @ -343,8 +375,9 @@ the font you would like to use, or leave it blank to not change anything. | |||||||
| a couple months after I ([@dragonwocky](https://github.com/dragonwocky/)) picked the project up, at first extending | a couple months after I ([@dragonwocky](https://github.com/dragonwocky/)) picked the project up, at first extending | ||||||
| upon the original base and later moving to the javascript module system. | upon the original base and later moving to the javascript module system. | ||||||
| 
 | 
 | ||||||
| since then, various community members have helped out heaps - some listed as | the enhancer wouldn't be anything near to what it is now though without | ||||||
|  | interested community members testing, coding and ideating features - some are listed as | ||||||
| [contributors](https://github.com/dragonwocky/notion-enhancer/graphs/contributors) here on github, | [contributors](https://github.com/dragonwocky/notion-enhancer/graphs/contributors) here on github, | ||||||
| but many helping with code, feedback and testing on discord and in emails. | but many more have been helping out on discord and in emails. | ||||||
| 
 | 
 | ||||||
| individual modules have their original authors attributed. | individual modules have their original authors attributed. | ||||||
|  | |||||||
							
								
								
									
										26
									
								
								TWEAKS.md
									
									
									
									
									
								
							
							
						
						| @ -70,10 +70,34 @@ then use the 3 dots up in the top-right corner to remove them. | |||||||
| 
 | 
 | ||||||
| <img src="https://user-images.githubusercontent.com/16874139/90969951-30f22800-e542-11ea-954c-e36873e19217.png" width="45%"></img> <img src="https://user-images.githubusercontent.com/16874139/90969962-55e69b00-e542-11ea-8ed3-287922805210.png" width="45%"></img> | <img src="https://user-images.githubusercontent.com/16874139/90969951-30f22800-e542-11ea-954c-e36873e19217.png" width="45%"></img> <img src="https://user-images.githubusercontent.com/16874139/90969962-55e69b00-e542-11ea-8ed3-287922805210.png" width="45%"></img> | ||||||
| 
 | 
 | ||||||
|  | ### sticky table/list row | ||||||
|  | 
 | ||||||
|  | note: this will make the first row stick to the top of the screen when scrolling down. | ||||||
|  | to stick a specific row replace `:nth-child(2)` with `[data-block-id="ROW_BLOCK_ID_HERE"]`. | ||||||
|  | 
 | ||||||
|  | does not apply to inline databases. | ||||||
|  | 
 | ||||||
|  | ```css | ||||||
|  | .notion-collection_view_page-block | ||||||
|  |   .notion-page-block.notion-collection-item:nth-child(2) { | ||||||
|  |   background: var(--theme--main); | ||||||
|  |   z-index: 10; | ||||||
|  |   position: sticky; | ||||||
|  |   top: 0; | ||||||
|  | } | ||||||
|  | .notion-table-view | ||||||
|  |   .notion-collection_view_page-block | ||||||
|  |   .notion-page-block.notion-collection-item:nth-child(2) { | ||||||
|  |   top: 32px; | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  |  | ||||||
|  | 
 | ||||||
| ### table columns below 100px | ### table columns below 100px | ||||||
| 
 | 
 | ||||||
| **not recommended!** this may cause buggy viewing. | **not recommended!** this may cause buggy viewing. | ||||||
| as it is a per-table-column style, unlike all others here, it must be prepended with the block ID and repeated for each column. | as it is a per-table-column style, unlike most others here, it must be prepended with the block ID and repeated for each column. | ||||||
| 
 | 
 | ||||||
| to see how to do this, watch [this video](https://www.youtube.com/watch?v=6V7eqShm_4w). | to see how to do this, watch [this video](https://www.youtube.com/watch?v=6V7eqShm_4w). | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -11,26 +11,26 @@ module.exports = { | |||||||
|   tags: ['extension'], |   tags: ['extension'], | ||||||
|   name: 'bypass preview', |   name: 'bypass preview', | ||||||
|   desc: 'go straight to the normal full view when opening a page.', |   desc: 'go straight to the normal full view when opening a page.', | ||||||
|   version: '0.1.0', |   version: '0.1.2', | ||||||
|   author: 'dragonwocky', |   author: 'dragonwocky', | ||||||
|   hacks: { |   hacks: { | ||||||
|     'renderer/preload.js'(store, __exports) { |     'renderer/preload.js'(store, __exports) { | ||||||
|       document.addEventListener('readystatechange', (event) => { |       document.addEventListener('readystatechange', (event) => { | ||||||
|         if (document.readyState !== 'complete') return false; |         if (document.readyState !== 'complete') return false; | ||||||
|         const attempt_interval = setInterval(enhance, 500); |         let queue = []; | ||||||
|         function enhance() { |         const observer = new MutationObserver((list, observer) => { | ||||||
|           const notion_elem = document.querySelector('.notion-app-inner'); |           if (!queue.length) requestIdleCallback(() => handle(queue)); | ||||||
|           if (!notion_elem) return; |           queue.push(...list); | ||||||
|           clearInterval(attempt_interval); |         }); | ||||||
|           const observer = new MutationObserver(handle); |         observer.observe(document.body, { | ||||||
|           observer.observe(notion_elem, { |  | ||||||
|           childList: true, |           childList: true, | ||||||
|           subtree: true, |           subtree: true, | ||||||
|  |           attributes: true, | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
|           let pageHistory = []; |         let lastPageID; | ||||||
|           handle(); |         function handle(list) { | ||||||
|           function handle(list, observer) { |           queue = []; | ||||||
|           const pageID = (location.search |           const pageID = (location.search | ||||||
|               .slice(1) |               .slice(1) | ||||||
|               .split('&') |               .split('&') | ||||||
| @ -42,26 +42,12 @@ module.exports = { | |||||||
|             preview = document.querySelector( |             preview = document.querySelector( | ||||||
|               '.notion-peek-renderer [style*="height: 45px;"] a' |               '.notion-peek-renderer [style*="height: 45px;"] a' | ||||||
|             ); |             ); | ||||||
|             if ( |           if (!pageID) return; | ||||||
|               pageID && |  | ||||||
|               (!pageHistory[0] || |  | ||||||
|                 pageHistory[0][0] !== pageID || |  | ||||||
|                 pageHistory[0][1] !== !!preview) |  | ||||||
|             ) { |  | ||||||
|           if (preview) { |           if (preview) { | ||||||
|                 if ( |             if (pageID === lastPageID) { | ||||||
|                   pageHistory[1] && |               history.back(); | ||||||
|                   pageHistory[0][0] === pageID && |  | ||||||
|                   pageHistory[1][0] === pageID && |  | ||||||
|                   pageHistory[1][1] |  | ||||||
|                 ) { |  | ||||||
|                   document.querySelector('.notion-history-back-button').click(); |  | ||||||
|             } else preview.click(); |             } else preview.click(); | ||||||
|               } |           } else lastPageID = pageID; | ||||||
|               // most recent is at start for easier access
 |  | ||||||
|               pageHistory.unshift([pageID, !!preview]); |  | ||||||
|             } |  | ||||||
|           } |  | ||||||
|         } |         } | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | |||||||
| @ -5,5 +5,5 @@ | |||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| .notion-peek-renderer { | .notion-peek-renderer { | ||||||
|   opacity: 0; |   display: none; | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										16
									
								
								mods/cherrycola/mod.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,16 @@ | |||||||
|  | /* | ||||||
|  |  * cherry cola | ||||||
|  |  * (c) 2020 Alexa Baldon (https://github.com/runargs)
 | ||||||
|  |  * under the MIT license | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | 'use strict'; | ||||||
|  | 
 | ||||||
|  | module.exports = { | ||||||
|  |   id: 'ec5c4640-68d4-4d25-aefd-62c7e9737cfb', | ||||||
|  |   tags: ['theme', 'dark'], | ||||||
|  |   name: 'cherry cola', | ||||||
|  |   desc: 'a delightfully plummy, cherry cola flavored theme.', | ||||||
|  |   version: '0.1.0', | ||||||
|  |   author: 'runargs', | ||||||
|  | }; | ||||||
							
								
								
									
										150
									
								
								mods/cherrycola/styles.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,150 @@ | |||||||
|  | /* | ||||||
|  |  * cherry cola | ||||||
|  |  * (c) 2020 Alexa Baldon (https://github.com/runargs) | ||||||
|  |  * (c) 2020 dragonwocky <thedragonring.bod@gmail.com> (https://dragonwocky.me/) | ||||||
|  |  * under the MIT license | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | :root { | ||||||
|  |   --cola-main: #180915; | ||||||
|  |   --cola-sec: #1d0919; | ||||||
|  |   --cola-tet: #492341; | ||||||
|  |   --cola-info: #9b6890; | ||||||
|  |   --cola-accent: #bf799b; | ||||||
|  |   --cola-gray: #8a8a8a; | ||||||
|  |   --cola-brown: #755241; | ||||||
|  |   --cola-orange: #e6846b; | ||||||
|  |   --cola-yellow: #d7b56e; | ||||||
|  |   --cola-green: #8f9b4f; | ||||||
|  |   --cola-blue: #6ebdb7; | ||||||
|  |   --cola-purple: #813d63; | ||||||
|  |   --cola-pink: #d86f71; | ||||||
|  |   --cola-red: #a33232; | ||||||
|  | 
 | ||||||
|  |   /* Main */ | ||||||
|  |   --theme_dark--main: var(--cola-main); | ||||||
|  |   --theme_dark--sidebar: var(--cola-sec); | ||||||
|  |   --theme_dark--overlay: var(--cola-sec); | ||||||
|  |   --theme_dark--dragarea: #210a1c; | ||||||
|  |   --theme_dark--box-shadow: rgba(20, 0, 16, 0.2) 0px 0px 0px 1px, | ||||||
|  |     rgba(20, 0, 16, 0.2) 0px 2px 4px; | ||||||
|  |   --theme_dark--box-shadow_strong: rgba(20, 0, 16, 0.1) 0px 0px 0px 1px, | ||||||
|  |     rgba(20, 0, 16, 0.2) 0px 3px 6px, rgba(20, 0, 16, 0.4) 0px 9px 24px; | ||||||
|  | 
 | ||||||
|  |   /* Scrollbar */ | ||||||
|  |   --theme_dark--scrollbar: var(--cola-sec); | ||||||
|  |   --theme_dark--scrollbar_hover: var(--cola-accent); | ||||||
|  | 
 | ||||||
|  |   /* Database */ | ||||||
|  |   --theme_dark--card: var(--cola-sec); | ||||||
|  |   --theme_dark--gallery: var(--cola-sec); | ||||||
|  |   --theme_dark--select_input: var(--cola-tet); | ||||||
|  |   --theme_dark--table-border: var(--cola-tet); | ||||||
|  |   --theme_dark--ui-border: rgba(73, 35, 65, 0.7); | ||||||
|  |   --theme_dark--interactive_hover: var(--cola-tet); | ||||||
|  |   --theme_dark--button_close: var(--cola-accent); | ||||||
|  | 
 | ||||||
|  |   /* Select/hover/click  */ | ||||||
|  |   --theme_dark--selected: rgba(78, 32, 69, 0.5); | ||||||
|  |   --theme_dark--primary: var(--cola-accent); | ||||||
|  |   --theme_dark--primary_hover: var(--cola-accent); | ||||||
|  |   --theme_dark--primary_click: var(--cola-sec); | ||||||
|  |   --theme_dark--primary_indicator: var(--cola-accent); | ||||||
|  | 
 | ||||||
|  |   --theme_dark--option_active-background: var(--theme_dark--primary); | ||||||
|  |   --theme_dark--option_hover-background: var(--theme_dark--primary_hover); | ||||||
|  | 
 | ||||||
|  |   /* Danger */ | ||||||
|  |   --theme_dark--danger_text: #eb5757; | ||||||
|  |   --theme_dark--danger_border: rgba(235, 87, 87, 0.5); | ||||||
|  | 
 | ||||||
|  |   /* Default text colors */ | ||||||
|  |   --theme_dark--text: #ffffff; | ||||||
|  |   --theme_dark--text_ui: var(--cola-info); | ||||||
|  |   --theme_dark--text_ui_info: var(--cola-info); | ||||||
|  | 
 | ||||||
|  |   /* Text color options */ | ||||||
|  |   --theme_dark--text_gray: var(--cola-gray); | ||||||
|  |   --theme_dark--text_brown: var(--cola-brown); | ||||||
|  |   --theme_dark--text_orange: var(--cola-orange); | ||||||
|  |   --theme_dark--text_yellow: var(--cola-yellow); | ||||||
|  |   --theme_dark--text_green: var(--cola-green); | ||||||
|  |   --theme_dark--text_blue: var(--cola-blue); | ||||||
|  |   --theme_dark--text_purple: var(--cola-purple); | ||||||
|  |   --theme_dark--text_pink: var(--cola-pink); | ||||||
|  |   --theme_dark--text_red: var(--cola-red); | ||||||
|  | 
 | ||||||
|  |   --theme_dark--select-text: var(--cola-main); | ||||||
|  |   --theme_dark--select_gray: var(--cola-gray); | ||||||
|  |   --theme_dark--select_brown: var(--cola-brown); | ||||||
|  |   --theme_dark--select_brown-text: #ffffff; | ||||||
|  |   --theme_dark--select_orange: var(--cola-orange); | ||||||
|  |   --theme_dark--select_yellow: var(--cola-yellow); | ||||||
|  |   --theme_dark--select_green: var(--cola-green); | ||||||
|  |   --theme_dark--select_blue: var(--cola-blue); | ||||||
|  |   --theme_dark--select_purple: var(--cola-purple); | ||||||
|  |   --theme_dark--select_purple-text: #ffffff; | ||||||
|  |   --theme_dark--select_pink: var(--cola-pink); | ||||||
|  |   --theme_dark--select_red: var(--cola-red); | ||||||
|  |   --theme_dark--select_red-text: #ffffff; | ||||||
|  | 
 | ||||||
|  |   --theme_dark--line-text: var(--cola-main); | ||||||
|  |   --theme_dark--line_gray: var(--cola-gray); | ||||||
|  |   --theme_dark--line_brown: var(--cola-brown); | ||||||
|  |   --theme_dark--line_orange: var(--cola-orange); | ||||||
|  |   --theme_dark--line_yellow: var(--cola-yellow); | ||||||
|  |   --theme_dark--line_green: var(--cola-green); | ||||||
|  |   --theme_dark--line_blue: var(--cola-blue); | ||||||
|  |   --theme_dark--line_purple: var(--cola-purple); | ||||||
|  |   --theme_dark--line_pink: var(--cola-pink); | ||||||
|  |   --theme_dark--line_red: var(--cola-red); | ||||||
|  | 
 | ||||||
|  |   --theme_dark--bg-text: var(--theme_dark--select-text); | ||||||
|  |   --theme_dark--bg_gray: var(--theme_dark--select_gray); | ||||||
|  |   --theme_dark--bg_brown: var(--theme_dark--select_brown); | ||||||
|  |   --theme_dark--bg_orange: var(--theme_dark--select_orange); | ||||||
|  |   --theme_dark--bg_yellow: var(--theme_dark--select_yellow); | ||||||
|  |   --theme_dark--bg_green: var(--theme_dark--select_green); | ||||||
|  |   --theme_dark--bg_blue: var(--theme_dark--select_blue); | ||||||
|  |   --theme_dark--bg_purple: var(--theme_dark--select_purple); | ||||||
|  |   --theme_dark--bg_pink: var(--theme_dark--select_pink); | ||||||
|  |   --theme_dark--bg_red: var(--theme_dark--select_red); | ||||||
|  | 
 | ||||||
|  |   /* Callout blocks */ | ||||||
|  |   --theme_dark--callout-text: var(--theme_dark--line-text); | ||||||
|  |   --theme_dark--callout_gray: var(--theme_dark--line_gray); | ||||||
|  |   --theme_dark--callout_brown: var(--theme_dark--line_brown); | ||||||
|  |   --theme_dark--callout_orange: var(--theme_dark--line_orange); | ||||||
|  |   --theme_dark--callout_yellow: var(--theme_dark--line_yellow); | ||||||
|  |   --theme_dark--callout_green: var(--theme_dark--line_green); | ||||||
|  |   --theme_dark--callout_blue: var(--theme_dark--line_blue); | ||||||
|  |   --theme_dark--callout_purple: var(--theme_dark--line_purple); | ||||||
|  |   --theme_dark--callout_pink: var(--theme_dark--line_pink); | ||||||
|  |   --theme_dark--callout_red: var(--theme_dark--line_red); | ||||||
|  | 
 | ||||||
|  |   /* Incline/code text */ | ||||||
|  |   --theme_dark--code_inline-text: var(--cola-accent); | ||||||
|  |   --theme_dark--code_inline-background: var(--cola-main); | ||||||
|  |   --theme_dark--code-text: var(--theme_dark--text); | ||||||
|  |   --theme_dark--code-background: var(--cola-sec); | ||||||
|  |   --theme_dark--code_function: var(--theme_dark--text_blue); | ||||||
|  |   --theme_dark--code_keyword: var(--theme_dark--text_pink); | ||||||
|  |   --theme_dark--code_tag: var(--theme_dark--text_pink); | ||||||
|  |   --theme_dark--code_operator: var(--theme_dark--text_yellow); | ||||||
|  |   --theme_dark--code_important: var(--theme_dark--text_yellow); | ||||||
|  |   --theme_dark--code_property: var(--theme_dark--text_pink); | ||||||
|  |   --theme_dark--code_builtin: var(--theme_dark--text_yellow); | ||||||
|  |   --theme_dark--code_attr-name: var(--theme_dark--text_yellow); | ||||||
|  |   --theme_dark--code_comment: var(--theme_dark--text_gray); | ||||||
|  |   --theme_dark--code_punctuation: var(--theme_dark--text_gray); | ||||||
|  |   --theme_dark--code_doctype: var(--theme_dark--text_gray); | ||||||
|  |   --theme_dark--code_number: var(--theme_dark--text_purple); | ||||||
|  |   --theme_dark--code_string: var(--theme_dark--text_orange); | ||||||
|  |   --theme_dark--code_attr-value: var(--theme_dark--text_orange); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /* Quotations as serif */ | ||||||
|  | .notion-dark-theme .notion-quote-block { | ||||||
|  |   font-family: Georgia, 'Times New Roman', Times, serif; | ||||||
|  |   background-color: var(--cola-sec); | ||||||
|  | } | ||||||
| @ -15,7 +15,7 @@ module.exports = (store) => { | |||||||
|     buttons = { |     buttons = { | ||||||
|       element: helpers.createElement('<div class="window-buttons-area"></div>'), |       element: helpers.createElement('<div class="window-buttons-area"></div>'), | ||||||
|       insert: [ |       insert: [ | ||||||
|         ...((store('mods', {})['72886371-dada-49a7-9afc-9f275ecf29d3'] || {}) |         ...((store('mods')['72886371-dada-49a7-9afc-9f275ecf29d3'] || {}) | ||||||
|           .enabled |           .enabled | ||||||
|           ? ['alwaysontop'] |           ? ['alwaysontop'] | ||||||
|           : []), |           : []), | ||||||
| @ -83,19 +83,19 @@ module.exports = (store) => { | |||||||
| 
 | 
 | ||||||
|   (async () => { |   (async () => { | ||||||
|     for (let btn of buttons.insert) { |     for (let btn of buttons.insert) { | ||||||
|       buttons.element.innerHTML += `<button class="window-button" id="btn-${btn}">${await buttons.icons[ |       buttons.element.innerHTML += `<button class="window-button btn-${btn}">${await buttons.icons[ | ||||||
|         btn |         btn | ||||||
|       ]()}</button>`; |       ]()}</button>`; | ||||||
|     } |     } | ||||||
|     for (let btn of buttons.insert) { |     for (let btn of buttons.insert) { | ||||||
|       document.querySelector(`.window-button#btn-${btn}`).onclick = |       buttons.element.querySelector(`.window-button.btn-${btn}`).onclick = | ||||||
|         buttons.actions[btn]; |         buttons.actions[btn]; | ||||||
|     } |     } | ||||||
|     if (store().frameless && !store().tiling_mode && !is_mac) { |     if (store().frameless && !store().tiling_mode && !is_mac) { | ||||||
|       window.addEventListener('resize', (event) => { |       window.addEventListener('resize', (event) => { | ||||||
|         Promise.resolve(buttons.icons.maximize()).then((icon) => { |         Promise.resolve(buttons.icons.maximize()).then((icon) => { | ||||||
|           icon = icon.toString(); |           icon = icon.toString(); | ||||||
|           const el = buttons.element.querySelector('#btn-maximize'); |           const el = buttons.element.querySelector('.btn-maximize'); | ||||||
|           if (el.innerHTML != icon) el.innerHTML = icon; |           if (el.innerHTML != icon) el.innerHTML = icon; | ||||||
|         }); |         }); | ||||||
|       }); |       }); | ||||||
|  | |||||||
| @ -13,11 +13,61 @@ module.exports = (store, __exports) => { | |||||||
|     notionIpc = require(`${helpers.__notion.replace( |     notionIpc = require(`${helpers.__notion.replace( | ||||||
|       /\\/g, |       /\\/g, | ||||||
|       '/' |       '/' | ||||||
|     )}/app/helpers/notionIpc.js`);
 |     )}/app/helpers/notionIpc.js`),
 | ||||||
|  |     { toKeyEvent } = require('keyboardevent-from-electron-accelerator'), | ||||||
|  |     tabsEnabled = (store('mods')['e1692c29-475e-437b-b7ff-3eee872e1a42'] || {}) | ||||||
|  |       .enabled; | ||||||
| 
 | 
 | ||||||
|   // additional hotkeys
 |  | ||||||
|   document.defaultView.addEventListener('keyup', (event) => { |   document.defaultView.addEventListener('keyup', (event) => { | ||||||
|     if (event.code === 'F5') location.reload(); |     // additional hotkeys
 | ||||||
|  |     if (event.key === 'F5') location.reload(); | ||||||
|  |     // open menu on hotkey toggle
 | ||||||
|  |     const hotkey = toKeyEvent(store().menu_toggle); | ||||||
|  |     let triggered = true; | ||||||
|  |     for (let prop in hotkey) | ||||||
|  |       if (hotkey[prop] !== event[prop]) triggered = false; | ||||||
|  |     if (triggered) electron.ipcRenderer.send('enhancer:open-menu'); | ||||||
|  |     if (tabsEnabled) { | ||||||
|  |       // switch between tabs via key modifier
 | ||||||
|  |       const select_tab_modifier = toKeyEvent( | ||||||
|  |         store('e1692c29-475e-437b-b7ff-3eee872e1a42').select_modifier | ||||||
|  |       ); | ||||||
|  |       let triggered = true; | ||||||
|  |       for (let prop in select_tab_modifier) | ||||||
|  |         if (select_tab_modifier[prop] !== event[prop]) triggered = false; | ||||||
|  |       if ( | ||||||
|  |         triggered && | ||||||
|  |         [ | ||||||
|  |           '1', | ||||||
|  |           '2', | ||||||
|  |           '3', | ||||||
|  |           '4', | ||||||
|  |           '5', | ||||||
|  |           '6', | ||||||
|  |           '7', | ||||||
|  |           '8', | ||||||
|  |           '9', | ||||||
|  |           'ArrowRight', | ||||||
|  |           'ArrowLeft', | ||||||
|  |         ].includes(event.key) | ||||||
|  |       ) | ||||||
|  |         electron.ipcRenderer.sendToHost('enhancer:select-tab', event.key); | ||||||
|  |       // create/close tab keybindings
 | ||||||
|  |       const new_tab_keybinding = toKeyEvent( | ||||||
|  |         store('e1692c29-475e-437b-b7ff-3eee872e1a42').new_tab | ||||||
|  |       ); | ||||||
|  |       triggered = true; | ||||||
|  |       for (let prop in new_tab_keybinding) | ||||||
|  |         if (new_tab_keybinding[prop] !== event[prop]) triggered = false; | ||||||
|  |       if (triggered) electron.ipcRenderer.sendToHost('enhancer:new-tab'); | ||||||
|  |       const close_tab_keybinding = toKeyEvent( | ||||||
|  |         store('e1692c29-475e-437b-b7ff-3eee872e1a42').close_tab | ||||||
|  |       ); | ||||||
|  |       triggered = true; | ||||||
|  |       for (let prop in close_tab_keybinding) | ||||||
|  |         if (close_tab_keybinding[prop] !== event[prop]) triggered = false; | ||||||
|  |       if (triggered) electron.ipcRenderer.sendToHost('enhancer:close-tab'); | ||||||
|  |     } | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|   const attempt_interval = setInterval(enhance, 500); |   const attempt_interval = setInterval(enhance, 500); | ||||||
| @ -29,18 +79,19 @@ module.exports = (store, __exports) => { | |||||||
|       return; |       return; | ||||||
|     clearInterval(attempt_interval); |     clearInterval(attempt_interval); | ||||||
| 
 | 
 | ||||||
|     // scrollbars
 |     // toggleable styles
 | ||||||
|     if (store().smooth_scrollbars) |     if (store().smooth_scrollbars) | ||||||
|       document.body.classList.add('smooth-scrollbars'); |       document.body.classList.add('smooth-scrollbars'); | ||||||
|  |     if (store().snappy_transitions) | ||||||
|  |       document.body.classList.add('snappy-transitions'); | ||||||
| 
 | 
 | ||||||
|     // frameless
 |     // frameless
 | ||||||
|     if (store().frameless && !store().tiling_mode) { |     if (store().frameless && !store().tiling_mode && !tabsEnabled) { | ||||||
|       document.body.classList.add('frameless'); |       document.body.classList.add('frameless'); | ||||||
|       // draggable area
 |       // draggable area
 | ||||||
|       const dragarea = helpers.createElement( |       document | ||||||
|         '<div class="window-dragarea"></div>' |         .querySelector('.notion-topbar') | ||||||
|       ); |         .prepend(helpers.createElement('<div class="window-dragarea"></div>')); | ||||||
|       document.querySelector('.notion-topbar').prepend(dragarea); |  | ||||||
|       document.documentElement.style.setProperty( |       document.documentElement.style.setProperty( | ||||||
|         '--configured--dragarea_height', |         '--configured--dragarea_height', | ||||||
|         `${store().dragarea_height + 2}px` |         `${store().dragarea_height + 2}px` | ||||||
| @ -48,10 +99,12 @@ module.exports = (store, __exports) => { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // window buttons
 |     // window buttons
 | ||||||
|  |     if (!tabsEnabled) { | ||||||
|       const buttons = require('./buttons.js')(store); |       const buttons = require('./buttons.js')(store); | ||||||
|       document |       document | ||||||
|         .querySelector('.notion-topbar > div[style*="display: flex"]') |         .querySelector('.notion-topbar > div[style*="display: flex"]') | ||||||
|         .appendChild(buttons.element); |         .appendChild(buttons.element); | ||||||
|  |     } | ||||||
|     document |     document | ||||||
|       .querySelector('.notion-history-back-button') |       .querySelector('.notion-history-back-button') | ||||||
|       .parentElement.nextElementSibling.classList.add( |       .parentElement.nextElementSibling.classList.add( | ||||||
| @ -66,7 +119,7 @@ module.exports = (store, __exports) => { | |||||||
|         document.querySelector('.notion-app-inner') |         document.querySelector('.notion-app-inner') | ||||||
|       ).getPropertyValue(prop); |       ).getPropertyValue(prop); | ||||||
| 
 | 
 | ||||||
|     // ctrl+f theming
 |     // external theming
 | ||||||
|     document.defaultView.addEventListener('keydown', (event) => { |     document.defaultView.addEventListener('keydown', (event) => { | ||||||
|       if ((event.ctrlKey || event.metaKey) && event.key === 'f') { |       if ((event.ctrlKey || event.metaKey) && event.key === 'f') { | ||||||
|         notionIpc.sendNotionToIndex('search:set-theme', { |         notionIpc.sendNotionToIndex('search:set-theme', { | ||||||
| @ -95,10 +148,9 @@ module.exports = (store, __exports) => { | |||||||
|       } |       } | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     // enhancer menu
 |  | ||||||
|     function setThemeVars() { |     function setThemeVars() { | ||||||
|       electron.ipcRenderer.send( |       electron.ipcRenderer.send( | ||||||
|         'enhancer:set-theme-vars', |         'enhancer:set-menu-theme', | ||||||
|         [ |         [ | ||||||
|           '--theme--main', |           '--theme--main', | ||||||
|           '--theme--sidebar', |           '--theme--sidebar', | ||||||
| @ -115,6 +167,7 @@ module.exports = (store, __exports) => { | |||||||
|           '--theme--interactive_hover-border', |           '--theme--interactive_hover-border', | ||||||
|           '--theme--button_close', |           '--theme--button_close', | ||||||
|           '--theme--button_close-fill', |           '--theme--button_close-fill', | ||||||
|  |           '--theme--selected', | ||||||
|           '--theme--primary', |           '--theme--primary', | ||||||
|           '--theme--primary_click', |           '--theme--primary_click', | ||||||
|           '--theme--option-color', |           '--theme--option-color', | ||||||
| @ -132,28 +185,60 @@ module.exports = (store, __exports) => { | |||||||
|           '--theme--select_red', |           '--theme--select_red', | ||||||
|           '--theme--line_text', |           '--theme--line_text', | ||||||
|           '--theme--line_yellow', |           '--theme--line_yellow', | ||||||
|  |           '--theme--line_yellow-text', | ||||||
|           '--theme--line_green', |           '--theme--line_green', | ||||||
|  |           '--theme--line_green-text', | ||||||
|           '--theme--line_blue', |           '--theme--line_blue', | ||||||
|  |           '--theme--line_blue-text', | ||||||
|           '--theme--line_red', |           '--theme--line_red', | ||||||
|  |           '--theme--line_red-text', | ||||||
|           '--theme--code_inline-text', |           '--theme--code_inline-text', | ||||||
|           '--theme--code_inline-background', |           '--theme--code_inline-background', | ||||||
|         ].map((rule) => [rule, getStyle(rule)]) |         ].map((rule) => [rule, getStyle(rule)]) | ||||||
|       ); |       ); | ||||||
|  |       if (tabsEnabled) { | ||||||
|  |         electron.ipcRenderer.sendToHost( | ||||||
|  |           'enhancer:set-tab-theme', | ||||||
|  |           [ | ||||||
|  |             '--theme--main', | ||||||
|  |             '--theme--dragarea', | ||||||
|  |             '--theme--font_sans', | ||||||
|  |             '--theme--table-border', | ||||||
|  |             '--theme--interactive_hover', | ||||||
|  |             '--theme--interactive_hover-border', | ||||||
|  |             '--theme--button_close', | ||||||
|  |             '--theme--button_close-fill', | ||||||
|  |             '--theme--option_active-background', | ||||||
|  |             '--theme--selected', | ||||||
|  |             '--theme--text', | ||||||
|  |           ].map((rule) => [rule, getStyle(rule)]) | ||||||
|  |         ); | ||||||
|  |       } | ||||||
|     } |     } | ||||||
|     setThemeVars(); |     setThemeVars(); | ||||||
|     const theme_observer = new MutationObserver(setThemeVars); |     new MutationObserver(setThemeVars).observe( | ||||||
|     theme_observer.observe(document.querySelector('.notion-app-inner'), { |       document.querySelector('.notion-app-inner'), | ||||||
|       attributes: true, |       { attributes: true } | ||||||
|     }); |     ); | ||||||
|     electron.ipcRenderer.on('enhancer:get-theme-vars', setThemeVars); |     electron.ipcRenderer.on('enhancer:get-menu-theme', setThemeVars); | ||||||
| 
 | 
 | ||||||
|     const sidebar_observer = new MutationObserver(setSidebarWidth); |     if (tabsEnabled) { | ||||||
|     sidebar_observer.observe(document.querySelector('.notion-sidebar'), { |       let tab_title = ''; | ||||||
|       attributes: true, |       __electronApi.setWindowTitle = (title) => { | ||||||
|     }); |         if (tab_title !== title) { | ||||||
|  |           tab_title = title; | ||||||
|  |           electron.ipcRenderer.sendToHost('enhancer:set-tab-title', title); | ||||||
|  |         } | ||||||
|  |       }; | ||||||
|  |       __electronApi.openInNewWindow = (urlPath) => { | ||||||
|  |         electron.ipcRenderer.sendToHost( | ||||||
|  |           'enhancer:new-tab', | ||||||
|  |           `notion://www.notion.so${urlPath}` | ||||||
|  |         ); | ||||||
|  |       }; | ||||||
|  |     } else if (store().frameless && !store().tiling_mode) { | ||||||
|       let sidebar_width; |       let sidebar_width; | ||||||
|       function setSidebarWidth(list) { |       function setSidebarWidth(list) { | ||||||
|       if (!store().frameless && store().tiling_mode) return; |  | ||||||
|         const new_sidebar_width = |         const new_sidebar_width = | ||||||
|           list[0].target.style.height === 'auto' |           list[0].target.style.height === 'auto' | ||||||
|             ? '0px' |             ? '0px' | ||||||
| @ -166,6 +251,11 @@ module.exports = (store, __exports) => { | |||||||
|           ); |           ); | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|  |       new MutationObserver(setSidebarWidth).observe( | ||||||
|  |         document.querySelector('.notion-sidebar'), | ||||||
|  |         { attributes: true } | ||||||
|  |       ); | ||||||
|       setSidebarWidth([{ target: document.querySelector('.notion-sidebar') }]); |       setSidebarWidth([{ target: document.querySelector('.notion-sidebar') }]); | ||||||
|     } |     } | ||||||
|  |   } | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -37,9 +37,7 @@ | |||||||
|   background: var(--theme--interactive_hover); |   background: var(--theme--interactive_hover); | ||||||
|   box-shadow: 0 0 0 0.5px var(--theme--interactive_hover-border); |   box-shadow: 0 0 0 0.5px var(--theme--interactive_hover-border); | ||||||
| } | } | ||||||
| .window-button#btn-close:hover { | .window-button.btn-close:hover { | ||||||
|   background: var(--theme--button_close); |   background: var(--theme--button_close); | ||||||
| } |   color: var(--theme--button_close-fill); | ||||||
| .window-button#btn-close:hover svg line { |  | ||||||
|   stroke: var(--theme--button_close-fill); |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -50,11 +50,11 @@ body:not([style]) > * { | |||||||
| body:not([style])::after { | body:not([style])::after { | ||||||
|   content: ''; |   content: ''; | ||||||
|   position: absolute; |   position: absolute; | ||||||
|   left: 44vw; |   left: calc(50% - 13px); | ||||||
|   top: calc(50% - 7.5vw); |   top: calc(50% + 10px); | ||||||
|   width: 10vw; |   width: 18px; | ||||||
|   height: 10vw; |   height: 18px; | ||||||
|   border: 4px solid rgb(34, 34, 34); |   border: 4px solid rgb(34, 34, 34, 0.5); | ||||||
|   border-top-color: transparent; |   border-top-color: transparent; | ||||||
|   border-radius: 50%; |   border-radius: 50%; | ||||||
|   animation: spin 0.8s linear infinite; |   animation: spin 0.8s linear infinite; | ||||||
| @ -93,7 +93,7 @@ s { | |||||||
| 
 | 
 | ||||||
| /* titlebar */ | /* titlebar */ | ||||||
| 
 | 
 | ||||||
| #menu-titlebar::before { | #titlebar::before { | ||||||
|   content: ''; |   content: ''; | ||||||
|   position: absolute; |   position: absolute; | ||||||
|   width: 100%; |   width: 100%; | ||||||
| @ -103,20 +103,18 @@ s { | |||||||
|   height: 2px; |   height: 2px; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #menu-titlebar { | #titlebar { | ||||||
|   display: flex; |   display: flex; | ||||||
|   -webkit-app-region: drag; |   -webkit-app-region: drag; | ||||||
| } |  | ||||||
| #menu-titlebar button { |  | ||||||
|   -webkit-app-region: no-drag; |  | ||||||
| } |  | ||||||
| #menu-titlebar { |  | ||||||
|   background: var(--theme--dragarea); |   background: var(--theme--dragarea); | ||||||
| } | } | ||||||
| #menu-titlebar > .window-buttons-area { | #titlebar button { | ||||||
|  |   -webkit-app-region: no-drag; | ||||||
|  | } | ||||||
|  | #titlebar .window-buttons-area { | ||||||
|   margin: 0.4em 0.4em 0.4em auto; |   margin: 0.4em 0.4em 0.4em auto; | ||||||
| } | } | ||||||
| #menu-titlebar > .window-buttons-area:empty { | #titlebar .window-buttons-area:empty { | ||||||
|   display: none; |   display: none; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -148,6 +146,7 @@ s { | |||||||
|   color: var(--theme--select_red); |   color: var(--theme--select_red); | ||||||
| } | } | ||||||
| #alerts .error { | #alerts .error { | ||||||
|  |   color: var(--theme--line_red-text); | ||||||
|   background: var(--theme--line_red); |   background: var(--theme--line_red); | ||||||
|   border-color: var(--theme--select_red); |   border-color: var(--theme--select_red); | ||||||
| } | } | ||||||
| @ -155,6 +154,7 @@ s { | |||||||
|   color: var(--theme--select_yellow); |   color: var(--theme--select_yellow); | ||||||
| } | } | ||||||
| #alerts .warning { | #alerts .warning { | ||||||
|  |   color: var(--theme--line_yellow-text); | ||||||
|   background: var(--theme--line_yellow); |   background: var(--theme--line_yellow); | ||||||
|   border-color: var(--theme--select_yellow); |   border-color: var(--theme--select_yellow); | ||||||
| } | } | ||||||
| @ -162,6 +162,7 @@ s { | |||||||
|   color: var(--theme--select_blue); |   color: var(--theme--select_blue); | ||||||
| } | } | ||||||
| #alerts .info { | #alerts .info { | ||||||
|  |   color: var(--theme--line_blue-text); | ||||||
|   background: var(--theme--line_blue); |   background: var(--theme--line_blue); | ||||||
|   border-color: var(--theme--select_blue); |   border-color: var(--theme--select_blue); | ||||||
| } | } | ||||||
| @ -170,6 +171,7 @@ s { | |||||||
|   color: var(--theme--select_green); |   color: var(--theme--select_green); | ||||||
| } | } | ||||||
| #alerts .success { | #alerts .success { | ||||||
|  |   color: var(--theme--line_green-text); | ||||||
|   background: var(--theme--line_green); |   background: var(--theme--line_green); | ||||||
|   border-color: var(--theme--select_green); |   border-color: var(--theme--select_green); | ||||||
| } | } | ||||||
| @ -231,7 +233,7 @@ s { | |||||||
|   background: var(--theme--option-background); |   background: var(--theme--option-background); | ||||||
|   color: var(--theme--option-color); |   color: var(--theme--option-color); | ||||||
|   border-radius: 2px; |   border-radius: 2px; | ||||||
|   transition: color 200ms, background 200ms; |   transition: color 200ms, background 200ms, opacity 200ms; | ||||||
|   user-select: none; |   user-select: none; | ||||||
| } | } | ||||||
| #search #tags > span:not(:last-child) { | #search #tags > span:not(:last-child) { | ||||||
| @ -254,6 +256,9 @@ s { | |||||||
| 
 | 
 | ||||||
| /* module meta */ | /* module meta */ | ||||||
| 
 | 
 | ||||||
|  | #modules { | ||||||
|  |   position: relative; | ||||||
|  | } | ||||||
| #modules section { | #modules section { | ||||||
|   background: var(--theme--sidebar); |   background: var(--theme--sidebar); | ||||||
|   border: 1px solid var(--theme--table-border); |   border: 1px solid var(--theme--table-border); | ||||||
| @ -589,3 +594,65 @@ s { | |||||||
|     height: 132.5px; |     height: 132.5px; | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | /* draggable re-ordering of mods */ | ||||||
|  | 
 | ||||||
|  | #draggable-toggle { | ||||||
|  |   background: none; | ||||||
|  |   border: none; | ||||||
|  |   margin-top: 0.8em; | ||||||
|  |   padding-left: 0; | ||||||
|  |   cursor: pointer; | ||||||
|  |   color: var(--theme--text_ui); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | [data-bolded] { | ||||||
|  |   display: inline-flex; | ||||||
|  |   flex-direction: column; | ||||||
|  | } | ||||||
|  | [data-bolded]::after { | ||||||
|  |   content: attr(data-bolded); | ||||||
|  |   height: 0; | ||||||
|  |   visibility: hidden; | ||||||
|  |   overflow: hidden; | ||||||
|  |   user-select: none; | ||||||
|  |   pointer-events: none; | ||||||
|  |   font-weight: bold; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .reorder #search #tags > span, | ||||||
|  | .reorder #search #tags > span:hover { | ||||||
|  |   opacity: 0.7; | ||||||
|  |   background: var(--theme--option-background); | ||||||
|  | } | ||||||
|  | .reorder #search #tags > .selected, | ||||||
|  | .reorder #search #tags > .selected:hover { | ||||||
|  |   background: var(--tag_color, var(--theme--option_active-background)); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .reorder #modules .dragged-over::after { | ||||||
|  |   content: ''; | ||||||
|  |   height: 0.25em; | ||||||
|  |   width: 99%; | ||||||
|  |   position: absolute; | ||||||
|  |   margin: 0.3em 0; | ||||||
|  |   opacity: 0.7; | ||||||
|  |   background: var(--theme--selected); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .reorder #modules .switch, | ||||||
|  | .reorder #modules .tags, | ||||||
|  | .reorder #modules .desc, | ||||||
|  | .reorder #modules .options, | ||||||
|  | .reorder #modules .author, | ||||||
|  | .reorder #modules .version { | ||||||
|  |   display: none; | ||||||
|  | } | ||||||
|  | .reorder #modules label { | ||||||
|  |   cursor: pointer; | ||||||
|  | } | ||||||
|  | .reorder #modules label::before { | ||||||
|  |   content: '::'; | ||||||
|  |   margin-right: 0.4em; | ||||||
|  |   color: var(--theme--text_ui); | ||||||
|  | } | ||||||
|  | |||||||
							
								
								
									
										26
									
								
								mods/core/css/responsive.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,26 @@ | |||||||
|  | /* | ||||||
|  |  * notion-enhancer | ||||||
|  |  * (c) 2020 dragonwocky <thedragonring.bod@gmail.com> (https://dragonwocky.me/) | ||||||
|  |  * under the MIT license | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | @media (max-width: 600px) { | ||||||
|  |   .notion-column_list-block [style='display: flex;'] > div { | ||||||
|  |     width: 100% !important; | ||||||
|  |   } | ||||||
|  |   .notion-column_list-block [style='display: flex;'] { | ||||||
|  |     flex-direction: column !important; | ||||||
|  |   } | ||||||
|  | 
 | ||||||
|  |   .notion-app-inner { | ||||||
|  |     --theme_dark--page_normal-width: 100%; | ||||||
|  |     --theme_dark--page-padding: calc(48px + env(safe-area-inset-left)); | ||||||
|  |     --theme_light--page_normal-width: 100%; | ||||||
|  |     --theme_light--page-padding: calc(48px + env(safe-area-inset-left)); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .snappy-transitions * { | ||||||
|  |   animation-duration: 0s !important; | ||||||
|  |   transition-duration: 0s !important; | ||||||
|  | } | ||||||
| @ -11,6 +11,7 @@ | |||||||
| .smooth-scrollbars ::-webkit-scrollbar { | .smooth-scrollbars ::-webkit-scrollbar { | ||||||
|   width: 8px; /* vertical */ |   width: 8px; /* vertical */ | ||||||
|   height: 8px; /* horizontal */ |   height: 8px; /* horizontal */ | ||||||
|  |   -webkit-app-region: no-drag; | ||||||
| } | } | ||||||
| .smooth-scrollbars ::-webkit-scrollbar-corner { | .smooth-scrollbars ::-webkit-scrollbar-corner { | ||||||
|   background-color: transparent; /* overlap */ |   background-color: transparent; /* overlap */ | ||||||
|  | |||||||
							
								
								
									
										189
									
								
								mods/core/css/tabs.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,189 @@ | |||||||
|  | /* | ||||||
|  |  * notion-enhancer | ||||||
|  |  * (c) 2020 dragonwocky <thedragonring.bod@gmail.com> (https://dragonwocky.me/) | ||||||
|  |  * under the MIT license | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | @import './buttons.css'; | ||||||
|  | 
 | ||||||
|  | * { | ||||||
|  |   box-sizing: border-box; | ||||||
|  |   word-break: break-word; | ||||||
|  |   text-decoration: none; | ||||||
|  |   text-size-adjust: 100%; | ||||||
|  |   font-family: var(--theme--font_sans) !important; | ||||||
|  |   outline-color: var(--theme--table-border); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | @keyframes spin { | ||||||
|  |   from { | ||||||
|  |     transform: rotate(0deg); | ||||||
|  |   } | ||||||
|  |   to { | ||||||
|  |     transform: rotate(360deg); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | @keyframes tabSlide { | ||||||
|  |   from { | ||||||
|  |     width: 0; | ||||||
|  |   } | ||||||
|  |   to { | ||||||
|  |     width: 8.5em; | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | body:not([style*='--theme']):not(.error) > * { | ||||||
|  |   opacity: 0; | ||||||
|  | } | ||||||
|  | body:not([style*='--theme']):not(.error)::after { | ||||||
|  |   content: ''; | ||||||
|  |   position: absolute; | ||||||
|  |   left: calc(50% - 15px); | ||||||
|  |   top: calc(50% + 10px); | ||||||
|  |   width: 18px; | ||||||
|  |   height: 18px; | ||||||
|  |   border: 4px solid rgb(34, 34, 34, 0.5); | ||||||
|  |   border-top-color: transparent; | ||||||
|  |   border-radius: 50%; | ||||||
|  |   animation: spin 0.8s linear infinite; | ||||||
|  | } | ||||||
|  | body[style*='--theme']::after { | ||||||
|  |   z-index: 1; | ||||||
|  |   content: ''; | ||||||
|  |   position: absolute; | ||||||
|  |   left: calc(50% - 15px); | ||||||
|  |   top: calc(50% + 10px); | ||||||
|  |   width: 18px; | ||||||
|  |   height: 18px; | ||||||
|  |   opacity: 0.5; | ||||||
|  |   border: 4px solid var(--theme--text); | ||||||
|  |   border-top-color: transparent; | ||||||
|  |   border-radius: 50%; | ||||||
|  |   animation: spin 0.8s linear infinite; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | html, | ||||||
|  | body, | ||||||
|  | #root { | ||||||
|  |   background: var(--theme--main) !important; | ||||||
|  |   position: relative; | ||||||
|  |   height: 100%; | ||||||
|  |   margin: 0; | ||||||
|  | } | ||||||
|  | #root { | ||||||
|  |   display: flex; | ||||||
|  |   flex-direction: column; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #titlebar::before { | ||||||
|  |   content: ''; | ||||||
|  |   position: absolute; | ||||||
|  |   width: 100%; | ||||||
|  |   -webkit-app-region: no-drag; | ||||||
|  |   top: 0; | ||||||
|  |   left: 0; | ||||||
|  |   height: 2px; | ||||||
|  | } | ||||||
|  | #titlebar { | ||||||
|  |   display: flex; | ||||||
|  |   flex-shrink: 1; | ||||||
|  |   user-select: none; | ||||||
|  |   -webkit-app-region: drag; | ||||||
|  |   background: var(--theme--dragarea); | ||||||
|  | } | ||||||
|  | #titlebar button { | ||||||
|  |   color: var(--theme--text); | ||||||
|  |   -webkit-app-region: no-drag; | ||||||
|  |   border: none; | ||||||
|  |   background: transparent; | ||||||
|  | } | ||||||
|  | #titlebar .window-buttons-area { | ||||||
|  |   margin: 0.5em 0.55em 0.5em auto; | ||||||
|  | } | ||||||
|  | #titlebar .window-buttons-area:empty { | ||||||
|  |   display: none; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #open-enhancer-menu::before { | ||||||
|  |   content: ''; | ||||||
|  |   height: 1.25em; | ||||||
|  |   width: 1.25em; | ||||||
|  |   display: inline-block; | ||||||
|  |   margin: auto 1em -0.25em 1em; | ||||||
|  |   background-size: contain; | ||||||
|  |   background-image: url('enhancement://core/icons/mac+linux.png'); | ||||||
|  |   background-repeat: no-repeat; | ||||||
|  | } | ||||||
|  | #tabs { | ||||||
|  |   margin-top: auto; | ||||||
|  | } | ||||||
|  | #tabs .tab { | ||||||
|  |   display: inline-flex; | ||||||
|  |   background: var(--theme--main); | ||||||
|  |   border: none; | ||||||
|  |   font-size: 1.15em; | ||||||
|  |   padding: 0.2em 0.4em; | ||||||
|  |   text-align: left; | ||||||
|  |   border-bottom: 4px solid var(--theme--table-border); | ||||||
|  |   opacity: 0.8; | ||||||
|  | } | ||||||
|  | #tabs .tab:first-child { | ||||||
|  |   margin-top: 0.5em; | ||||||
|  | } | ||||||
|  | #tabs .tab:not(.new) span:not(.close) { | ||||||
|  |   width: 8.5em; | ||||||
|  |   margin-right: 4px; | ||||||
|  |   white-space: nowrap; | ||||||
|  |   overflow: hidden; | ||||||
|  |   text-overflow: ellipsis; | ||||||
|  | } | ||||||
|  | #tabs .tab.slideIn span:not(.close) { | ||||||
|  |   animation: tabSlide 100ms ease-in-out; | ||||||
|  | } | ||||||
|  | #tabs .tab.slideOut { | ||||||
|  |   width: 0; | ||||||
|  |   animation: tabSlide 100ms ease-in-out reverse; | ||||||
|  | } | ||||||
|  | #tabs .tab .close { | ||||||
|  |   padding: 0 0.35em 0.1em 0.3em; | ||||||
|  |   margin-left: auto; | ||||||
|  |   font-weight: bold; | ||||||
|  | } | ||||||
|  | #tabs .tab.current { | ||||||
|  |   opacity: 1; | ||||||
|  |   background: var(--theme--selected); | ||||||
|  |   border-bottom: 4px solid var(--theme--option_active-background); | ||||||
|  | } | ||||||
|  | #tabs .tab.new { | ||||||
|  |   background: none; | ||||||
|  |   border: none; | ||||||
|  |   margin-left: -0.1em; | ||||||
|  | } | ||||||
|  | #tabs .tab.new span { | ||||||
|  |   padding: 0 0.35em 0.1em 0.3em; | ||||||
|  |   font-weight: bold; | ||||||
|  | } | ||||||
|  | #tabs .tab:hover { | ||||||
|  |   opacity: 1; | ||||||
|  | } | ||||||
|  | #tabs .tab .close:hover, | ||||||
|  | #tabs .tab.new span:hover, | ||||||
|  | #titlebar .window-button:hover { | ||||||
|  |   border-radius: 4px; | ||||||
|  |   background: var(--theme--table-border); | ||||||
|  |   box-shadow: 0 0 0 0.5px var(--theme--interactive_hover-border); | ||||||
|  | } | ||||||
|  | #titlebar .window-button.btn-close:hover { | ||||||
|  |   background: var(--theme--button_close); | ||||||
|  |   color: var(--theme--button_close-fill); | ||||||
|  | } | ||||||
|  | #tabs .tab.dragged-over { | ||||||
|  |   box-shadow: inset 4px 0 0 0 var(--theme--selected); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .notion { | ||||||
|  |   z-index: 2; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  |   display: none; | ||||||
|  | } | ||||||
| @ -9,20 +9,25 @@ | |||||||
| 
 | 
 | ||||||
| /** app **/ | /** app **/ | ||||||
| 
 | 
 | ||||||
|  | .notion-body, | ||||||
|  | .notion-body.dark [style*='background: rgb(47, 52, 55)'], | ||||||
|  | .notion-body.dark [style*='background-color: rgb(47, 52, 55)'], | ||||||
|  | .notion-body:not(.dark) | ||||||
|  |   .notion-light-theme | ||||||
|  |   [style*='background: white']:not(.notion-help-button), | ||||||
|  | .notion-body:not(.dark) | ||||||
|  |   .notion-dark-theme | ||||||
|  |   [style*='background: white']:not(.notion-help-button):not([style*='box-shadow: rgba(15, 15, 15, 0.05) 0px 0px 0px 1px, rgba(15, 15, 15, 0.1) 0px 3px 6px, rgba(15, 15, 15, 0.2) 0px 9px 24px;']), | ||||||
|  | .notion-body:not(.dark) [style*='background-color: white'] { | ||||||
|  |   background: var(--theme--main) !important; | ||||||
|  | } | ||||||
|  | .notion-sidebar > div, | ||||||
| .notion-body.dark [style*='background: rgb(55, 60, 63)'], | .notion-body.dark [style*='background: rgb(55, 60, 63)'], | ||||||
| .notion-body.dark [style*='background: rgb(120, 123, 123)'], | .notion-body.dark [style*='background: rgb(120, 123, 123)'], | ||||||
| .notion-body:not(.dark) [style*='background: rgb(247, 246, 243)'], | .notion-body:not(.dark) [style*='background: rgb(247, 246, 243)'], | ||||||
| .notion-body:not(.dark) [style*='background: rgb(223, 223, 222)'] { | .notion-body:not(.dark) [style*='background: rgb(223, 223, 222)'] { | ||||||
|   background: var(--theme--sidebar) !important; |   background: var(--theme--sidebar) !important; | ||||||
| } | } | ||||||
| .notion-body, |  | ||||||
| .notion-body.dark [style*='background: rgb(47, 52, 55)'], |  | ||||||
| .notion-body.dark [style*='background-color: rgb(47, 52, 55)'], |  | ||||||
| .notion-body:not(.dark) |  | ||||||
|   [style*='background: white']:not(.notion-help-button):not([style*='box-shadow: rgba(15, 15, 15, 0.05) 0px 0px 0px 1px, rgba(15, 15, 15, 0.1) 0px 3px 6px, rgba(15, 15, 15, 0.2) 0px 9px 24px;']), |  | ||||||
| .notion-body:not(.dark) [style*='background-color: white'] { |  | ||||||
|   background: var(--theme--main) !important; |  | ||||||
| } |  | ||||||
| [style*='background: rgba(15, 15, 15, 0.6)'] { | [style*='background: rgba(15, 15, 15, 0.6)'] { | ||||||
|   background: var(--theme--overlay) !important; |   background: var(--theme--overlay) !important; | ||||||
| } | } | ||||||
| @ -40,6 +45,12 @@ | |||||||
|   width: var(--theme--page_normal-width) !important; |   width: var(--theme--page_normal-width) !important; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | .notion-frame | ||||||
|  |   [style*='padding-left: calc(96px + env(safe-area-inset-left)); padding-right: calc(96px + env(safe-area-inset-right));'] { | ||||||
|  |   padding-left: var(--theme--page-padding) !important; | ||||||
|  |   padding-right: var(--theme--page-padding) !important; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| .notion-page-content [data-block-id][style*='max-width'] { | .notion-page-content [data-block-id][style*='max-width'] { | ||||||
|   max-width: 100% !important; |   max-width: 100% !important; | ||||||
| } | } | ||||||
| @ -141,7 +152,8 @@ | |||||||
| [style*='SFMono-Regular'] { | [style*='SFMono-Regular'] { | ||||||
|   font-family: var(--theme--font_code) !important; |   font-family: var(--theme--font_code) !important; | ||||||
| } | } | ||||||
| .notion-frame .notion-page-block div[placeholder='Untitled'] { | .notion-frame .notion-page-block div[placeholder='Untitled'], | ||||||
|  | .notion-overlay-container .notion-page-block div[placeholder='Untitled'] { | ||||||
|   font-size: calc( |   font-size: calc( | ||||||
|     var(--theme--font_body-size) * (var(--theme--font_heading1-size) / 1em) |     var(--theme--font_body-size) * (var(--theme--font_heading1-size) / 1em) | ||||||
|   ) !important; |   ) !important; | ||||||
| @ -161,14 +173,19 @@ | |||||||
|     var(--theme--font_body-size) * (var(--theme--font_heading3-size) / 1em) |     var(--theme--font_body-size) * (var(--theme--font_heading3-size) / 1em) | ||||||
|   ) !important; |   ) !important; | ||||||
| } | } | ||||||
| .notion-frame .notion-scroller.vertical.horizontal [style*='font-size: 14px'] { | .notion-frame .notion-scroller.vertical.horizontal [style*='font-size: 14px'], | ||||||
|  | .notion-overlay-container .notion-scroller.vertical [style*='font-size: 14px'] { | ||||||
|   font-size: var(--theme--font_label-size) !important; |   font-size: var(--theme--font_label-size) !important; | ||||||
| } | } | ||||||
| .notion-frame .notion-scroller.vertical.horizontal .notion-page-content { | .notion-frame .notion-scroller.vertical.horizontal .notion-page-content, | ||||||
|  | .notion-overlay-container .notion-scroller.vertical .notion-page-content { | ||||||
|   font-size: var(--theme--font_body-size) !important; |   font-size: var(--theme--font_body-size) !important; | ||||||
| } | } | ||||||
| .notion-frame | .notion-frame | ||||||
|   .notion-scroller.vertical.horizontal |   .notion-scroller.vertical.horizontal | ||||||
|  |   .notion-page-content[style*='font-size: 14px'], | ||||||
|  | .notion-overlay-container | ||||||
|  |   .notion-scroller.vertical | ||||||
|   .notion-page-content[style*='font-size: 14px'] { |   .notion-page-content[style*='font-size: 14px'] { | ||||||
|   font-size: var(--theme--font_body-size_small) !important; |   font-size: var(--theme--font_body-size_small) !important; | ||||||
| } | } | ||||||
| @ -179,6 +196,13 @@ | |||||||
|   font-size: var(--theme--font_sidebar-size) !important; |   font-size: var(--theme--font_sidebar-size) !important; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | /** text-block readability **/ | ||||||
|  | 
 | ||||||
|  | .notion-selectable.notion-text-block { | ||||||
|  |   line-height: var(--theme--text-block_line-height) !important; | ||||||
|  |   margin-top: var(--theme--text-block_margin-top) !important; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /** databases **/ | /** databases **/ | ||||||
| 
 | 
 | ||||||
| .notion-body.dark [style*='background: rgb(63, 68, 71)'], | .notion-body.dark [style*='background: rgb(63, 68, 71)'], | ||||||
| @ -189,7 +213,8 @@ | |||||||
|   > a[style*='background: white'], |   > a[style*='background: white'], | ||||||
| .notion-body:not(.dark) [style*='background: rgb(247, 246, 243)'], | .notion-body:not(.dark) [style*='background: rgb(247, 246, 243)'], | ||||||
| .notion-body:not(.dark) | .notion-body:not(.dark) | ||||||
|   [style*='box-shadow: rgba(15, 15, 15, 0.05) 0px 0px 0px 1px, rgba(15, 15, 15, 0.1) 0px 3px 6px, rgba(15, 15, 15, 0.2) 0px 9px 24px;'] { |   .notion-dark-theme | ||||||
|  |   [style*='background: white'][style*='box-shadow: rgba(15, 15, 15, 0.05) 0px 0px 0px 1px, rgba(15, 15, 15, 0.1) 0px 3px 6px, rgba(15, 15, 15, 0.2) 0px 9px 24px;'] { | ||||||
|   background: var(--theme--card) !important; |   background: var(--theme--card) !important; | ||||||
| } | } | ||||||
| .notion-body.dark | .notion-body.dark | ||||||
| @ -200,17 +225,36 @@ | |||||||
|   [style*='background: rgba(55, 53, 47, 0.024)'] { |   [style*='background: rgba(55, 53, 47, 0.024)'] { | ||||||
|   background: var(--theme--gallery) !important; |   background: var(--theme--gallery) !important; | ||||||
| } | } | ||||||
|  | .notion-body.dark .notion-scroller > [style*='rgb(55, 60, 63)'], | ||||||
|  | .notion-body:not(.dark) [style*='background: rgba(242, 241, 238, 0.6)'] { | ||||||
|  |   background: var(--theme--select_input) !important; | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
| .notion-body.dark | .notion-body.dark | ||||||
|   [style*='box-shadow: rgba(15, 15, 15, 0.2) 0px 0px 0px 1px, rgba(15, 15, 15, 0.2) 0px 2px 4px'], |   [style*='box-shadow: rgba(255, 255, 255, 0.14) 0px -1px inset;'], | ||||||
| .notion-body:not(.dark) [style*='box-shadow: white -3px 0px 0px'] { | .notion-body:not(.dark) | ||||||
|   box-shadow: rgba(15, 15, 15, 0.1) 0px 0px 0px 1px, |   [style*='box-shadow: rgba(55, 53, 47, 0.16) 0px -1px 0px inset'] { | ||||||
|     rgba(15, 15, 15, 0.1) 0px 2px 4px !important; |   box-shadow: rgba(55, 53, 47, 0.16) 0px -1px inset !important; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .notion-body.dark [style*='box-shadow: rgba(255, 255, 255, 0.07) 0px 1px 0px'], | ||||||
|  | .notion-body:not(.dark) | ||||||
|  |   [style*='box-shadow: rgba(55, 53, 47, 0.09) 0px 1px 0px'] { | ||||||
|  |   box-shadow: var(--theme--ui-border) 0px 1px 0px !important; | ||||||
|  | } | ||||||
|  | .notion-body.dark | ||||||
|  |   [style*='box-shadow: rgba(255, 255, 255, 0.14) 0px 1px 0px inset'], | ||||||
|  | .notion-body:not(.dark) | ||||||
|  |   [style*='box-shadow: rgba(55, 53, 47, 0.16) 0px 1px 0px inset'] { | ||||||
|  |   box-shadow: var(--theme--table-border) 0px 1px 0px inset !important; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .notion-body.dark [style*='box-shadow: rgb(47, 52, 55) -3px 0px 0px'] { | .notion-body.dark [style*='box-shadow: rgb(47, 52, 55) -3px 0px 0px'] { | ||||||
|   box-shadow: var(--theme--main) -3px 0px 0px !important; |   box-shadow: var(--theme--main) -3px 0px 0px !important; | ||||||
| } | } | ||||||
|  | .notion-body:not(.dark) [style*='box-shadow: white -3px 0px 0px;'] { | ||||||
|  |   box-shadow: none !important; | ||||||
|  | } | ||||||
| .notion-body.dark | .notion-body.dark | ||||||
|   [style*='box-shadow: rgb(47, 52, 55) -3px 0px 0px, rgba(255, 255, 255, 0.14) 0px 1px 0px'], |   [style*='box-shadow: rgb(47, 52, 55) -3px 0px 0px, rgba(255, 255, 255, 0.14) 0px 1px 0px'], | ||||||
| .notion-body:not(.dark) | .notion-body:not(.dark) | ||||||
| @ -218,7 +262,7 @@ | |||||||
| .notion-body:not(.dark) | .notion-body:not(.dark) | ||||||
|   [style*='box-shadow: rgba(255, 255, 255, 0.07) 0px -1px 0px'] { |   [style*='box-shadow: rgba(255, 255, 255, 0.07) 0px -1px 0px'] { | ||||||
|   box-shadow: var(--theme--main) -3px 0px 0px, |   box-shadow: var(--theme--main) -3px 0px 0px, | ||||||
|     var(--theme--table-border) 0px 1px 0px !important; |     var(--theme--ui-border) 0px 1px 0px !important; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .notion-body.dark [style*='border-top: 1px solid rgba(255, 255, 255,'], | .notion-body.dark [style*='border-top: 1px solid rgba(255, 255, 255,'], | ||||||
| @ -246,7 +290,7 @@ | |||||||
| .notion-body.dark [style*='box-shadow: rgba(55, 53, 47, 0.09) 0px -1px 0px'], | .notion-body.dark [style*='box-shadow: rgba(55, 53, 47, 0.09) 0px -1px 0px'], | ||||||
| .notion-body:not(.dark) | .notion-body:not(.dark) | ||||||
|   [style*='box-shadow: rgba(55, 53, 47, 0.09) 0px -1px 0px'] { |   [style*='box-shadow: rgba(55, 53, 47, 0.09) 0px -1px 0px'] { | ||||||
|   box-shadow: var(--theme--table-border) 0px -1px 0px !important; |   box-shadow: var(--theme--ui-border) 0px -1px 0px !important; | ||||||
| } | } | ||||||
| .notion-body.dark [style*='border-left: 1px solid rgba(255, 255, 255,'], | .notion-body.dark [style*='border-left: 1px solid rgba(255, 255, 255,'], | ||||||
| .notion-body.dark | .notion-body.dark | ||||||
| @ -255,12 +299,6 @@ | |||||||
| .notion-body:not(.dark) [style*='border-left: 1px solid rgba(55, 53, 47,'] { | .notion-body:not(.dark) [style*='border-left: 1px solid rgba(55, 53, 47,'] { | ||||||
|   border-left: 1px solid var(--theme--table-border) !important; |   border-left: 1px solid var(--theme--table-border) !important; | ||||||
| } | } | ||||||
| .notion-body.dark |  | ||||||
|   [style*='box-shadow: rgba(255, 255, 255, 0.14) 0px 1px 0px inset'], |  | ||||||
| .notion-body:not(.dark) |  | ||||||
|   [style*='box-shadow: rgba(55, 53, 47, 0.16) 0px 1px 0px inset'] { |  | ||||||
|   box-shadow: var(--theme--table-border) 0px 1px 0px inset !important; |  | ||||||
| } |  | ||||||
| .notion-body.dark | .notion-body.dark | ||||||
|   [style*='box-shadow: rgba(255, 255, 255, 0.14) 1px 0px 0px inset'], |   [style*='box-shadow: rgba(255, 255, 255, 0.14) 1px 0px 0px inset'], | ||||||
| .notion-body:not(.dark) | .notion-body:not(.dark) | ||||||
| @ -288,6 +326,7 @@ | |||||||
| .notion-body.dark [style*='background: rgb(71, 76, 80)'], | .notion-body.dark [style*='background: rgb(71, 76, 80)'], | ||||||
| .notion-body.dark [style*='background: rgb(80, 85, 88)'], | .notion-body.dark [style*='background: rgb(80, 85, 88)'], | ||||||
| .notion-body.dark [style*='background: rgb(98, 102, 104)'], | .notion-body.dark [style*='background: rgb(98, 102, 104)'], | ||||||
|  | .notion-body.dark [style*='height: 1px; background: rgba(255, 255, 255, 0.07)'], | ||||||
| .notion-body:not(.dark) [style*='background: rgba(55, 53, 47,'], | .notion-body:not(.dark) [style*='background: rgba(55, 53, 47,'], | ||||||
| .notion-body:not(.dark) [style*='background: rgb(239, 239, 238)'], | .notion-body:not(.dark) [style*='background: rgb(239, 239, 238)'], | ||||||
| .notion-body:not(.dark) [style*='background: rgba(206, 205, 202, 0.5)'] { | .notion-body:not(.dark) [style*='background: rgba(206, 205, 202, 0.5)'] { | ||||||
| @ -296,7 +335,8 @@ | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /* normalise inline-table size */ | /* normalise inline-table size */ | ||||||
| .notion-page-content .notion-collection_view-block { | .notion-page-content .notion-collection_view-block[style*=' width'], | ||||||
|  | .notion-page-content .notion-collection_view-block[style^='width'] { | ||||||
|   width: 100% !important; |   width: 100% !important; | ||||||
| } | } | ||||||
| .notion-page-content | .notion-page-content | ||||||
| @ -363,7 +403,8 @@ | |||||||
|   background: var(--theme--selected) !important; |   background: var(--theme--selected) !important; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| [style*=' color: rgb(46, 170, 220)'] { | [style*=' color: rgb(46, 170, 220)'], | ||||||
|  | [style^='color: rgb(46, 170, 220)'] { | ||||||
|   color: var(--theme--primary) !important; |   color: var(--theme--primary) !important; | ||||||
| } | } | ||||||
| [style*='fill: rgb(46, 170, 220)'] { | [style*='fill: rgb(46, 170, 220)'] { | ||||||
| @ -387,6 +428,19 @@ | |||||||
|   background: var(--theme--primary_indicator) !important; |   background: var(--theme--primary_indicator) !important; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | .notion-body.dark | ||||||
|  |   [style*='box-shadow: rgba(15, 15, 15, 0.1) 0px 0px 0px 1px, rgba(15, 15, 15, 0.2) 0px 3px 6px, rgba(15, 15, 15, 0.4) 0px 9px 24px'], | ||||||
|  | .notion-body:not(.dark) | ||||||
|  |   [style*='box-shadow: rgba(15, 15, 15, 0.05) 0px 0px 0px 1px, rgba(15, 15, 15, 0.1) 0px 3px 6px, rgba(15, 15, 15, 0.2) 0px 9px 24px'] { | ||||||
|  |   box-shadow: var(--theme--box-shadow_strong) !important; | ||||||
|  | } | ||||||
|  | .notion-body.dark | ||||||
|  |   [style*='box-shadow: rgba(15, 15, 15, 0.2) 0px 0px 0px 1px, rgba(15, 15, 15, 0.2) 0px 2px 4px'], | ||||||
|  | .notion-body:not(.dark) | ||||||
|  |   [style*='box-shadow: rgba(15, 15, 15, 0.1) 0px 0px 0px 1px, rgba(15, 15, 15, 0.1) 0px 2px 4px'] { | ||||||
|  |   box-shadow: var(--theme--box-shadow) !important; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| .notion-to_do-block > div [role='button']:hover, | .notion-to_do-block > div [role='button']:hover, | ||||||
| .notion-to_do-block > div [role='button']:hover .checkboxSquare, | .notion-to_do-block > div [role='button']:hover .checkboxSquare, | ||||||
| .notion-to_do-block > div [role='button']:hover .check { | .notion-to_do-block > div [role='button']:hover .check { | ||||||
| @ -422,11 +476,13 @@ | |||||||
| /** content colours **/ | /** content colours **/ | ||||||
| 
 | 
 | ||||||
| .notion-body, | .notion-body, | ||||||
| .notion-page-content [style*='color: inherit;'], |  | ||||||
| .notion-frame .notion-page-block, | .notion-frame .notion-page-block, | ||||||
| .notion-body.dark [style*=' color: rgba(255, 255, 255, 0.9)'], | .notion-body.dark [style*=' color: rgba(255, 255, 255, 0.9)'], | ||||||
|  | .notion-body.dark [style^='color: rgba(255, 255, 255, 0.9)'], | ||||||
| .notion-body.dark [style*=' color: rgba(255, 255, 255, 0.7)'], | .notion-body.dark [style*=' color: rgba(255, 255, 255, 0.7)'], | ||||||
| .notion-body:not(.dark) [style*=' color: rgb(55, 53, 47);'] { | .notion-body.dark [style^='color: rgba(255, 255, 255, 0.7)'], | ||||||
|  | .notion-body:not(.dark) [style*=' color: rgb(55, 53, 47);'], | ||||||
|  | .notion-body:not(.dark) [style^='color: rgb(55, 53, 47);'] { | ||||||
|   color: var(--theme--text) !important; |   color: var(--theme--text) !important; | ||||||
| } | } | ||||||
| .notion-body.dark [style*='color: rgba(255, 255, 255, 0.6)'], | .notion-body.dark [style*='color: rgba(255, 255, 255, 0.6)'], | ||||||
| @ -434,18 +490,38 @@ | |||||||
| .notion-body:not(.dark) [style*='color: rgba(25, 23, 17, 0.6)'] { | .notion-body:not(.dark) [style*='color: rgba(25, 23, 17, 0.6)'] { | ||||||
|   color: var(--theme--text_ui) !important; |   color: var(--theme--text_ui) !important; | ||||||
| } | } | ||||||
|  | ::placeholder { | ||||||
|  |   opacity: 1 !important; | ||||||
|  | } | ||||||
|  | ::placeholder, | ||||||
|  | [style*='-webkit-text-fill-color:'], | ||||||
| .notion-body.dark [style*='color: rgba(255, 255, 255, 0.4)'], | .notion-body.dark [style*='color: rgba(255, 255, 255, 0.4)'], | ||||||
| .notion-body:not(.dark) [style*='color: rgba(55, 53, 47, 0.4)'] { | .notion-body.dark [style*='color: rgba(255, 255, 255, 0.4)']::before, | ||||||
|  | .notion-body:not(.dark) [style*='color: rgba(55, 53, 47, 0.4)'], | ||||||
|  | .notion-body:not(.dark) [style*='color: rgba(55, 53, 47, 0.4)']::before { | ||||||
|   color: var(--theme--text_ui_info) !important; |   color: var(--theme--text_ui_info) !important; | ||||||
|  |   -webkit-text-fill-color: var(--theme--text_ui_info) !important; | ||||||
| } | } | ||||||
| .notion-body.dark [style*='fill: rgb(202, 204, 206)'] { | .notion-body.dark [style*='fill: rgb(202, 204, 206)'] { | ||||||
|   fill: var(--theme--text) !important; |   fill: var(--theme--text) !important; | ||||||
| } | } | ||||||
| .notion-body.dark [style*='fill: rgba(202, 204, 206,'], | 
 | ||||||
|  | .notion-body.dark [style*='fill: rgba(255, 255, 255, 0.6)'], | ||||||
| .notion-body:not(.dark) [style*='fill: rgba(55, 53, 47, 0.8)'], | .notion-body:not(.dark) [style*='fill: rgba(55, 53, 47, 0.8)'], | ||||||
| .notion-body:not(.dark) [style*='fill: rgba(55, 53, 47,'] { | .notion-body:not(.dark) [style*='fill: rgba(55, 53, 47, 0.6)'], | ||||||
|  | .notion-body:not(.dark) [style*='fill: rgba(25, 23, 17, 0.6)'] { | ||||||
|   fill: var(--theme--text_ui) !important; |   fill: var(--theme--text_ui) !important; | ||||||
| } | } | ||||||
|  | .notion-body.dark [style*='fill: rgba(202, 204, 206, 0.6)'], | ||||||
|  | .notion-body.dark [style*='fill: rgba(202, 204, 206, 0.4)'], | ||||||
|  | .notion-body:not(.dark) [style*='fill: rgba(55, 53, 47, 0.4)'], | ||||||
|  | .notion-body:not(.dark) [style*='fill: rgba(55, 53, 47, 0.3)'] { | ||||||
|  |   fill: var(--theme--text_ui_info) !important; | ||||||
|  | } | ||||||
|  | .notion-body.dark [style*='border-color:rgba(255,255,255,0.4);opacity:0.7'], | ||||||
|  | .notion-body:not(.dark) [style*='border-color:rgba(55,53,47,0.4);opacity:0.7'] { | ||||||
|  |   border-color: var(--theme--text_ui_info) !important; | ||||||
|  | } | ||||||
| .notion-body.dark [style*='caret-color: rgba(255, 255, 255, 0.9)'], | .notion-body.dark [style*='caret-color: rgba(255, 255, 255, 0.9)'], | ||||||
| .notion-body:not(.dark) [style*='caret-color: rgb(55, 53, 47)'] { | .notion-body:not(.dark) [style*='caret-color: rgb(55, 53, 47)'] { | ||||||
|   caret-color: var(--theme--text) !important; |   caret-color: var(--theme--text) !important; | ||||||
| @ -487,7 +563,7 @@ | |||||||
| .notion-body:not(.dark) | .notion-body:not(.dark) | ||||||
|   [style*='color: rgb(100, 71, 58); fill: rgb(100, 71, 58);'] { |   [style*='color: rgb(100, 71, 58); fill: rgb(100, 71, 58);'] { | ||||||
|   fill: var(--theme--text_brown) !important; |   fill: var(--theme--text_brown) !important; | ||||||
|   color: var(--theme--text_brown-text) !important; |   color: var(--theme--text_brown) !important; | ||||||
| } | } | ||||||
| .notion-body.dark [style*='background: rgba(147, 114, 100, 0.5)'], | .notion-body.dark [style*='background: rgba(147, 114, 100, 0.5)'], | ||||||
| .notion-body:not(.dark) [style*='background: rgba(140, 46, 0, 0.2)'] { | .notion-body:not(.dark) [style*='background: rgba(140, 46, 0, 0.2)'] { | ||||||
|  | |||||||
| @ -8,19 +8,23 @@ | |||||||
| @import './buttons.css'; | @import './buttons.css'; | ||||||
| 
 | 
 | ||||||
| .frameless .notion-topbar { | .frameless .notion-topbar { | ||||||
|   height: calc(var(--configured--dragarea_height, 10px) + 45px) !important; |   height: calc(var(--configured--dragarea_height, 15px) + 45px) !important; | ||||||
| } | } | ||||||
| .frameless .window-dragarea { | .frameless .window-dragarea { | ||||||
|   height: var(--configured--dragarea_height, 10px); |   height: var(--configured--dragarea_height, 15px); | ||||||
|   width: 100%; |   width: 100%; | ||||||
| } | } | ||||||
| .frameless .window-dragarea { | .frameless .window-dragarea { | ||||||
|   background: var(--theme--dragarea); |   background: var(--theme--dragarea); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | .frameless [style*='top: 10.4972px'] { | ||||||
|  |   top: calc(10.4972px + var(--configured--dragarea_height, 15px)) !important; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| @media (max-width: 760px) { | @media (max-width: 760px) { | ||||||
|   .frameless .notion-topbar { |   .frameless .notion-topbar { | ||||||
|     height: calc(var(--configured--dragarea_height, 10px) + 80px) !important; |     height: calc(var(--configured--dragarea_height, 15px) + 80px) !important; | ||||||
|   } |   } | ||||||
|   .frameless .notion-topbar > :nth-child(2) { |   .frameless .notion-topbar > :nth-child(2) { | ||||||
|     height: 80px !important; |     height: 80px !important; | ||||||
|  | |||||||
| @ -14,12 +14,17 @@ | |||||||
|   --theme_dark--sidebar: rgb(55, 60, 63); |   --theme_dark--sidebar: rgb(55, 60, 63); | ||||||
|   --theme_dark--overlay: rgba(15, 15, 15, 0.6); |   --theme_dark--overlay: rgba(15, 15, 15, 0.6); | ||||||
|   --theme_dark--dragarea: #272d2f; |   --theme_dark--dragarea: #272d2f; | ||||||
|  |   --theme_dark--box-shadow: rgba(15, 15, 15, 0.2) 0px 0px 0px 1px, | ||||||
|  |     rgba(15, 15, 15, 0.2) 0px 2px 4px; | ||||||
|  |   --theme_dark--box-shadow_strong: rgba(15, 15, 15, 0.1) 0px 0px 0px 1px, | ||||||
|  |     rgba(15, 15, 15, 0.2) 0px 3px 6px, rgba(15, 15, 15, 0.4) 0px 9px 24px; | ||||||
|   --theme_dark--page_normal-width: 900px; |   --theme_dark--page_normal-width: 900px; | ||||||
|   --theme_dark--page_full-width: 100%; |   --theme_dark--page_full-width: 100%; | ||||||
|  |   --theme_dark--page-padding: calc(96px + env(safe-area-inset-left)); | ||||||
|  |   --theme_dark--page_banner-height: 30vh; | ||||||
|   --theme_dark--preview-width: 977px; |   --theme_dark--preview-width: 977px; | ||||||
|   --theme_dark--preview-padding: 8rem; |   --theme_dark--preview-padding: 8rem; | ||||||
|   --theme_dark--preview_banner-height: 20vh; |   --theme_dark--preview_banner-height: 20vh; | ||||||
|   --theme_dark--page_banner-height: 30vh; |  | ||||||
| 
 | 
 | ||||||
|   --theme_dark--font_sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', |   --theme_dark--font_sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', | ||||||
|     Helvetica, 'Apple Color Emoji', Arial, sans-serif, 'Segoe UI Emoji', |     Helvetica, 'Apple Color Emoji', Arial, sans-serif, 'Segoe UI Emoji', | ||||||
| @ -41,13 +46,18 @@ | |||||||
|   --theme_dark--font_code-size: 0.796875em; |   --theme_dark--font_code-size: 0.796875em; | ||||||
|   --theme_dark--font_sidebar-size: 14px; |   --theme_dark--font_sidebar-size: 14px; | ||||||
|    |    | ||||||
|  |   --theme_dark--text-block_line-height: 1.5; | ||||||
|  |   --theme_dark--text-block_margin-top: 1px; | ||||||
|  | 
 | ||||||
|   --theme_dark--scrollbar: #505457; |   --theme_dark--scrollbar: #505457; | ||||||
|   --theme_dark--scrollbar-border: transparent; |   --theme_dark--scrollbar-border: transparent; | ||||||
|   --theme_dark--scrollbar_hover: #696d6f; |   --theme_dark--scrollbar_hover: #696d6f; | ||||||
| 
 | 
 | ||||||
|   --theme_dark--card: rgb(63, 68, 71); |   --theme_dark--card: rgb(63, 68, 71); | ||||||
|   --theme_dark--gallery: rgba(255, 255, 255, 0.05); |   --theme_dark--gallery: rgba(255, 255, 255, 0.05); | ||||||
|  |   --theme_dark--select_input: rgb(55, 60, 63); | ||||||
|   --theme_dark--table-border: rgba(255, 255, 255, 0.1); |   --theme_dark--table-border: rgba(255, 255, 255, 0.1); | ||||||
|  |   --theme_dark--ui-border: rgba(255, 255, 255, 0.07); | ||||||
|   --theme_dark--interactive_hover: rgb(71, 76, 80); |   --theme_dark--interactive_hover: rgb(71, 76, 80); | ||||||
|   --theme_dark--interactive_hover-border: transparent; |   --theme_dark--interactive_hover-border: transparent; | ||||||
|   --theme_dark--button_close: #e81123; |   --theme_dark--button_close: #e81123; | ||||||
| @ -188,12 +198,17 @@ | |||||||
|   --theme_light--sidebar: rgb(247, 246, 243); |   --theme_light--sidebar: rgb(247, 246, 243); | ||||||
|   --theme_light--overlay: rgba(15, 15, 15, 0.6); |   --theme_light--overlay: rgba(15, 15, 15, 0.6); | ||||||
|   --theme_light--dragarea: rgba(55, 53, 47, 0.04); |   --theme_light--dragarea: rgba(55, 53, 47, 0.04); | ||||||
|  |   --theme_light--box-shadow: rgba(15, 15, 15, 0.1) 0px 0px 0px 1px, | ||||||
|  |     rgba(15, 15, 15, 0.1) 0px 2px 4px; | ||||||
|  |   --theme_light--box-shadow_strong: rgba(15, 15, 15, 0.05) 0px 0px 0px 1px, | ||||||
|  |     rgba(15, 15, 15, 0.1) 0px 3px 6px, rgba(15, 15, 15, 0.2) 0px 9px 24px; | ||||||
|   --theme_light--page_normal-width: 900px; |   --theme_light--page_normal-width: 900px; | ||||||
|   --theme_light--page_full-width: 100%; |   --theme_light--page_full-width: 100%; | ||||||
|  |   --theme_light--page-padding: calc(96px + env(safe-area-inset-left)); | ||||||
|  |   --theme_light--page_banner-height: 30vh; | ||||||
|   --theme_light--preview-width: 977px; |   --theme_light--preview-width: 977px; | ||||||
|   --theme_light--preview-padding: 8rem; |   --theme_light--preview-padding: 8rem; | ||||||
|   --theme_light--preview_banner-height: 20vh; |   --theme_light--preview_banner-height: 20vh; | ||||||
|   --theme_light--page_banner-height: 30vh; |  | ||||||
| 
 | 
 | ||||||
|   --theme_light--font_sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', |   --theme_light--font_sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', | ||||||
|     Helvetica, 'Apple Color Emoji', Arial, sans-serif, 'Segoe UI Emoji', |     Helvetica, 'Apple Color Emoji', Arial, sans-serif, 'Segoe UI Emoji', | ||||||
| @ -215,13 +230,18 @@ | |||||||
|   --theme_light--font_code-size: 0.796875em; |   --theme_light--font_code-size: 0.796875em; | ||||||
|   --theme_light--font_sidebar-size: 14px; |   --theme_light--font_sidebar-size: 14px; | ||||||
|    |    | ||||||
|  |   --theme_light--text-block_line-height: 1.5; | ||||||
|  |   --theme_light--text-block_margin-top: 1px; | ||||||
|  | 
 | ||||||
|   --theme_light--scrollbar: #d9d8d6; |   --theme_light--scrollbar: #d9d8d6; | ||||||
|   --theme_light--scrollbar-border: #cacac8; |   --theme_light--scrollbar-border: #cacac8; | ||||||
|   --theme_light--scrollbar_hover: #cacac8; |   --theme_light--scrollbar_hover: #cacac8; | ||||||
| 
 | 
 | ||||||
|   --theme_light--card: rgb(247, 247, 247); |   --theme_light--card: rgb(247, 247, 247); | ||||||
|   --theme_light--gallery: rgba(55, 53, 47, 0.024); |   --theme_light--gallery: rgba(55, 53, 47, 0.024); | ||||||
|  |   --theme_light--select_input: rgba(242, 241, 238, 0.6); | ||||||
|   --theme_light--table-border: rgba(55, 53, 47, 0.16); |   --theme_light--table-border: rgba(55, 53, 47, 0.16); | ||||||
|  |   --theme_light--ui-border: rgba(55, 53, 47, 0.09); | ||||||
|   --theme_light--interactive_hover: rgb(239, 239, 239); |   --theme_light--interactive_hover: rgb(239, 239, 239); | ||||||
|   --theme_light--interactive_hover-border: transparent; |   --theme_light--interactive_hover-border: transparent; | ||||||
|   --theme_light--button_close: #e81123; |   --theme_light--button_close: #e81123; | ||||||
| @ -245,6 +265,7 @@ | |||||||
| 
 | 
 | ||||||
|   --theme_light--text: rgb(55, 53, 47); |   --theme_light--text: rgb(55, 53, 47); | ||||||
|   --theme_light--text_ui: rgba(55, 53, 47, 0.6); |   --theme_light--text_ui: rgba(55, 53, 47, 0.6); | ||||||
|  |   --theme_light--text_ui: rgba(55, 53, 47, 0.6); | ||||||
|   --theme_light--text_ui_info: rgba(55, 53, 47, 0.4); |   --theme_light--text_ui_info: rgba(55, 53, 47, 0.4); | ||||||
| 
 | 
 | ||||||
|   --theme_light--text_gray: rgb(155, 154, 151); |   --theme_light--text_gray: rgb(155, 154, 151); | ||||||
| @ -362,12 +383,15 @@ | |||||||
|   --theme--sidebar: var(--theme_dark--sidebar); |   --theme--sidebar: var(--theme_dark--sidebar); | ||||||
|   --theme--overlay: var(--theme_dark--overlay); |   --theme--overlay: var(--theme_dark--overlay); | ||||||
|   --theme--dragarea: var(--theme_dark--dragarea); |   --theme--dragarea: var(--theme_dark--dragarea); | ||||||
|  |   --theme--box-shadow: var(--theme_dark--box-shadow); | ||||||
|  |   --theme--box-shadow_strong: var(--theme_dark--box-shadow_strong); | ||||||
|   --theme--page_normal-width: var(--theme_dark--page_normal-width); |   --theme--page_normal-width: var(--theme_dark--page_normal-width); | ||||||
|   --theme--page_full-width: var(--theme_dark--page_full-width); |   --theme--page_full-width: var(--theme_dark--page_full-width); | ||||||
|  |   --theme--page-padding: var(--theme_dark--page-padding); | ||||||
|  |   --theme--page_banner-height: var(--theme_dark--page_banner-height); | ||||||
|   --theme--preview-width: var(--theme_dark--preview-width); |   --theme--preview-width: var(--theme_dark--preview-width); | ||||||
|   --theme--preview-padding: var(--theme_dark--preview-padding); |   --theme--preview-padding: var(--theme_dark--preview-padding); | ||||||
|   --theme--preview_banner-height: var(--theme_dark--preview_banner-height); |   --theme--preview_banner-height: var(--theme_dark--preview_banner-height); | ||||||
|   --theme--page_banner-height: var(--theme_dark--page_banner-height); |  | ||||||
|   --theme--font_sans: var(--theme_dark--font_sans); |   --theme--font_sans: var(--theme_dark--font_sans); | ||||||
|   --theme--font_serif: var(--theme_dark--font_serif); |   --theme--font_serif: var(--theme_dark--font_serif); | ||||||
|   --theme--font_mono: var(--theme_dark--font_mono); |   --theme--font_mono: var(--theme_dark--font_mono); | ||||||
| @ -381,12 +405,16 @@ | |||||||
|   --theme--font_body-size_small: var(--theme_dark--font_body-size_small); |   --theme--font_body-size_small: var(--theme_dark--font_body-size_small); | ||||||
|   --theme--font_code-size: var(--theme_dark--font_code-size); |   --theme--font_code-size: var(--theme_dark--font_code-size); | ||||||
|   --theme--font_sidebar-size: var(--theme_dark--font_sidebar-size); |   --theme--font_sidebar-size: var(--theme_dark--font_sidebar-size); | ||||||
|  |   --theme--text-block_line-height: var(--theme_dark--text-block_line-height); | ||||||
|  |   --theme--text-block_margin-top: var(--theme_dark--text-block_margin-top); | ||||||
|   --theme--scrollbar: var(--theme_dark--scrollbar); |   --theme--scrollbar: var(--theme_dark--scrollbar); | ||||||
|   --theme--scrollbar-border: var(--theme_dark--scrollbar-border); |   --theme--scrollbar-border: var(--theme_dark--scrollbar-border); | ||||||
|   --theme--scrollbar_hover: var(--theme_dark--scrollbar_hover); |   --theme--scrollbar_hover: var(--theme_dark--scrollbar_hover); | ||||||
|   --theme--card: var(--theme_dark--card); |   --theme--card: var(--theme_dark--card); | ||||||
|   --theme--gallery: var(--theme_dark--gallery); |   --theme--gallery: var(--theme_dark--gallery); | ||||||
|  |   --theme--select_input: var(--theme_dark--select_input); | ||||||
|   --theme--table-border: var(--theme_dark--table-border); |   --theme--table-border: var(--theme_dark--table-border); | ||||||
|  |   --theme--ui-border: var(--theme_dark--ui-border); | ||||||
|   --theme--interactive_hover: var(--theme_dark--interactive_hover); |   --theme--interactive_hover: var(--theme_dark--interactive_hover); | ||||||
|   --theme--interactive_hover-border: var( |   --theme--interactive_hover-border: var( | ||||||
|     --theme_dark--interactive_hover-border |     --theme_dark--interactive_hover-border | ||||||
| @ -521,12 +549,15 @@ | |||||||
|   --theme--sidebar: var(--theme_light--sidebar); |   --theme--sidebar: var(--theme_light--sidebar); | ||||||
|   --theme--overlay: var(--theme_light--overlay); |   --theme--overlay: var(--theme_light--overlay); | ||||||
|   --theme--dragarea: var(--theme_light--dragarea); |   --theme--dragarea: var(--theme_light--dragarea); | ||||||
|   --theme--page_normal-width: var(--theme_dark--page_normal-width); |   --theme--box-shadow: var(--theme_light--box-shadow); | ||||||
|   --theme--page_full-width: var(--theme_dark--page_full-width); |   --theme--box-shadow_strong: var(--theme_light--box-shadow_strong); | ||||||
|  |   --theme--page_normal-width: var(--theme_light--page_normal-width); | ||||||
|  |   --theme--page_full-width: var(--theme_light--page_full-width); | ||||||
|  |   --theme--page-padding: var(--theme_light--page-padding); | ||||||
|  |   --theme--page_banner-height: var(--theme_light--page_banner-height); | ||||||
|   --theme--preview-width: var(--theme_light--preview-width); |   --theme--preview-width: var(--theme_light--preview-width); | ||||||
|   --theme--preview-padding: var(--theme_light--preview-padding); |   --theme--preview-padding: var(--theme_light--preview-padding); | ||||||
|   --theme--preview_banner-height: var(--theme_light--preview_banner-height); |   --theme--preview_banner-height: var(--theme_light--preview_banner-height); | ||||||
|   --theme--page_banner-height: var(--theme_light--page_banner-height); |  | ||||||
|   --theme--font_sans: var(--theme_light--font_sans); |   --theme--font_sans: var(--theme_light--font_sans); | ||||||
|   --theme--font_serif: var(--theme_light--font_serif); |   --theme--font_serif: var(--theme_light--font_serif); | ||||||
|   --theme--font_mono: var(--theme_light--font_mono); |   --theme--font_mono: var(--theme_light--font_mono); | ||||||
| @ -540,12 +571,16 @@ | |||||||
|   --theme--font_body-size_small: var(--theme_light--font_body-size_small); |   --theme--font_body-size_small: var(--theme_light--font_body-size_small); | ||||||
|   --theme--font_code-size: var(--theme_light--font_code-size); |   --theme--font_code-size: var(--theme_light--font_code-size); | ||||||
|   --theme--font_sidebar-size: var(--theme_light--font_sidebar-size); |   --theme--font_sidebar-size: var(--theme_light--font_sidebar-size); | ||||||
|  |   --theme--text-block_line-height: var(--theme_light--text-block_line-height); | ||||||
|  |   --theme--text-block_margin-top: var(--theme_light--text-block_margin-top); | ||||||
|   --theme--scrollbar: var(--theme_light--scrollbar); |   --theme--scrollbar: var(--theme_light--scrollbar); | ||||||
|   --theme--scrollbar-border: var(--theme_light--scrollbar-border); |   --theme--scrollbar-border: var(--theme_light--scrollbar-border); | ||||||
|   --theme--scrollbar_hover: var(--theme_light--scrollbar_hover); |   --theme--scrollbar_hover: var(--theme_light--scrollbar_hover); | ||||||
|   --theme--card: var(--theme_light--card); |   --theme--card: var(--theme_light--card); | ||||||
|   --theme--gallery: var(--theme_light--gallery); |   --theme--gallery: var(--theme_light--gallery); | ||||||
|  |   --theme--select_input: var(--theme_light--select_input); | ||||||
|   --theme--table-border: var(--theme_light--table-border); |   --theme--table-border: var(--theme_light--table-border); | ||||||
|  |   --theme--ui-border: var(--theme_light--ui-border); | ||||||
|   --theme--interactive_hover: var(--theme_light--interactive_hover); |   --theme--interactive_hover: var(--theme_light--interactive_hover); | ||||||
|   --theme--interactive_hover-border: var( |   --theme--interactive_hover-border: var( | ||||||
|     --theme_light--interactive_hover-border |     --theme_light--interactive_hover-border | ||||||
|  | |||||||
| @ -7,57 +7,52 @@ | |||||||
| 'use strict'; | 'use strict'; | ||||||
| 
 | 
 | ||||||
| const store = require('../../pkg/store.js'), | const store = require('../../pkg/store.js'), | ||||||
|   { id } = require('./mod.js'), |  | ||||||
|   helpers = require('../../pkg/helpers.js'), |   helpers = require('../../pkg/helpers.js'), | ||||||
|   fs = require('fs-extra'), |   fs = require('fs-extra'), | ||||||
|   path = require('path'), |   path = require('path'), | ||||||
|   electron = require('electron'), |   electron = require('electron'), | ||||||
|   browser = electron.remote.getCurrentWindow(); |   { toKeyEvent } = require('keyboardevent-from-electron-accelerator'); | ||||||
| 
 | 
 | ||||||
| window['__start'] = async () => { | window['__start'] = async () => { | ||||||
|  |   // mod loader
 | ||||||
|  |   const modules = helpers.getEnhancements(); | ||||||
|  |   if (modules.loaded.length) | ||||||
|  |     console.info( | ||||||
|  |       `<notion-enhancer> enhancements loaded: ${modules.loaded | ||||||
|  |         .map((mod) => mod.name) | ||||||
|  |         .join(', ')}.` | ||||||
|  |     ); | ||||||
|  |   if (modules.invalid.length) { | ||||||
|  |     createAlert( | ||||||
|  |       'error', | ||||||
|  |       `invalid mods found: ${modules.invalid | ||||||
|  |         .map((mod) => `<b>${mod}</b>`) | ||||||
|  |         .join(', ')}.` | ||||||
|  |     ).append(); | ||||||
|  |   } | ||||||
|  |   const coreStore = (...args) => { | ||||||
|  |     const mod = modules.loaded.find( | ||||||
|  |       (m) => m.id === '0f0bf8b6-eae6-4273-b307-8fc43f2ee082' | ||||||
|  |     ); | ||||||
|  |     return !args.length | ||||||
|  |       ? store(mod.id, mod.defaults) | ||||||
|  |       : args.length === 1 && typeof args[0] === 'object' | ||||||
|  |       ? store(mod.id, { ...mod.defaults, ...args[0] }) | ||||||
|  |       : store(args[0], { ...mod.defaults, ...args[1] }); | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|   const buttons = require('./buttons.js')(() => ({ |   const buttons = require('./buttons.js')(() => ({ | ||||||
|     '72886371-dada-49a7-9afc-9f275ecf29d3': { |     '72886371-dada-49a7-9afc-9f275ecf29d3': { | ||||||
|       enabled: (store('mods')['72886371-dada-49a7-9afc-9f275ecf29d3'] || {}) |       enabled: (store('mods')['72886371-dada-49a7-9afc-9f275ecf29d3'] || {}) | ||||||
|         .enabled, |         .enabled, | ||||||
|     }, |     }, | ||||||
|     tiling_mode: store('0f0bf8b6-eae6-4273-b307-8fc43f2ee082').tiling_mode, |     tiling_mode: coreStore().tiling_mode, | ||||||
|     frameless: true, |     frameless: coreStore().frameless, | ||||||
|   })); |   })); | ||||||
|   document.querySelector('#menu-titlebar').appendChild(buttons.element); |   document.querySelector('#titlebar').appendChild(buttons.element); | ||||||
| 
 | 
 | ||||||
|   document.defaultView.addEventListener('keyup', (event) => { |   electron.ipcRenderer.send('enhancer:get-menu-theme'); | ||||||
|     if (event.code === 'F5') location.reload(); |   electron.ipcRenderer.on('enhancer:set-menu-theme', (event, theme) => { | ||||||
|     const meta = |  | ||||||
|       !(event.ctrlKey || event.metaKey) && !event.altKey && !event.shiftKey; |  | ||||||
|     if ( |  | ||||||
|       meta && |  | ||||||
|       document.activeElement.parentElement.id === 'tags' && |  | ||||||
|       event.key === 'Enter' |  | ||||||
|     ) |  | ||||||
|       document.activeElement.click(); |  | ||||||
|     if (document.activeElement.tagName.toLowerCase() === 'input') { |  | ||||||
|       if (document.activeElement.type === 'checkbox' && event.key === 'Enter') |  | ||||||
|         document.activeElement.checked = !document.activeElement.checked; |  | ||||||
|       if ( |  | ||||||
|         ['Escape', 'Enter'].includes(event.key) && |  | ||||||
|         document.activeElement.type !== 'checkbox' && |  | ||||||
|         (document.activeElement.parentElement.id !== 'search' || |  | ||||||
|           event.key === 'Escape') |  | ||||||
|       ) |  | ||||||
|         document.activeElement.blur(); |  | ||||||
|     } else if (meta && event.key === '/') |  | ||||||
|       document.querySelector('#search > input').focus(); |  | ||||||
|     if ( |  | ||||||
|       (event.ctrlKey || event.metaKey) && |  | ||||||
|       event.key === 'f' && |  | ||||||
|       !event.altKey && |  | ||||||
|       !event.shiftKey |  | ||||||
|     ) |  | ||||||
|       document.querySelector('#search > input').focus(); |  | ||||||
|   }); |  | ||||||
| 
 |  | ||||||
|   electron.ipcRenderer.send('enhancer:get-theme-vars'); |  | ||||||
|   electron.ipcRenderer.on('enhancer:set-theme-vars', (event, theme) => { |  | ||||||
|     for (const style of theme) |     for (const style of theme) | ||||||
|       document.body.style.setProperty(style[0], style[1]); |       document.body.style.setProperty(style[0], style[1]); | ||||||
|   }); |   }); | ||||||
| @ -121,32 +116,52 @@ window['__start'] = async () => { | |||||||
|       ).prepend(); |       ).prepend(); | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|   // mod loader
 |  | ||||||
|   const modules = helpers.getEnhancements(); |  | ||||||
|   if (modules.loaded.length) |  | ||||||
|     console.info( |  | ||||||
|       `<notion-enhancer> enhancements loaded: ${modules.loaded |  | ||||||
|         .map((mod) => mod.name) |  | ||||||
|         .join(', ')}.` |  | ||||||
|     ); |  | ||||||
|   if (modules.invalid.length) { |  | ||||||
|     createAlert( |  | ||||||
|       'error', |  | ||||||
|       `invalid mods found: ${modules.invalid |  | ||||||
|         .map((mod) => `<b>${mod}</b>`) |  | ||||||
|         .join(', ')}.` |  | ||||||
|     ).append(); |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   // further-configuration popup
 |  | ||||||
|   const $popup = document.querySelector('#popup'); |   const $popup = document.querySelector('#popup'); | ||||||
|   document.addEventListener('keyup', (event) => { |   document.addEventListener('keyup', (event) => { | ||||||
|  |     if (event.key === 'F5') location.reload(); | ||||||
|  |     // further-configuration popup
 | ||||||
|     if ( |     if ( | ||||||
|       $popup.classList.contains('visible') && |       $popup.classList.contains('visible') && | ||||||
|       [13, 27].includes(event.keyCode) |       ['Enter', 'Escape'].includes(event.key) | ||||||
|     ) |     ) | ||||||
|       $popup.classList.remove('visible'); |       $popup.classList.remove('visible'); | ||||||
|  |     // close window on hotkey toggle
 | ||||||
|  |     const hotkey = toKeyEvent(coreStore().menu_toggle); | ||||||
|  |     let triggered = true; | ||||||
|  |     for (let prop in hotkey) | ||||||
|  |       if (hotkey[prop] !== event[prop]) triggered = false; | ||||||
|  |     if (triggered || ((event.ctrlKey || event.metaKey) && event.key === 'w')) | ||||||
|  |       electron.remote.getCurrentWindow().close(); | ||||||
|  |     //  focus search
 | ||||||
|  |     const meta = | ||||||
|  |       !(event.ctrlKey || event.metaKey) && !event.altKey && !event.shiftKey; | ||||||
|  |     if ( | ||||||
|  |       meta && | ||||||
|  |       document.activeElement.parentElement.id === 'tags' && | ||||||
|  |       event.key === 'Enter' | ||||||
|  |     ) | ||||||
|  |       document.activeElement.click(); | ||||||
|  |     if (document.activeElement.tagName.toLowerCase() === 'input') { | ||||||
|  |       if (document.activeElement.type === 'checkbox' && event.key === 'Enter') | ||||||
|  |         document.activeElement.checked = !document.activeElement.checked; | ||||||
|  |       if ( | ||||||
|  |         ['Escape', 'Enter'].includes(event.key) && | ||||||
|  |         document.activeElement.type !== 'checkbox' && | ||||||
|  |         (document.activeElement.parentElement.id !== 'search' || | ||||||
|  |           event.key === 'Escape') | ||||||
|  |       ) | ||||||
|  |         document.activeElement.blur(); | ||||||
|  |     } else if (meta && event.key === '/') | ||||||
|  |       document.querySelector('#search > input').focus(); | ||||||
|  |     if ( | ||||||
|  |       (event.ctrlKey || event.metaKey) && | ||||||
|  |       event.key === 'f' && | ||||||
|  |       !event.altKey && | ||||||
|  |       !event.shiftKey | ||||||
|  |     ) | ||||||
|  |       document.querySelector('#search > input').focus(); | ||||||
|   }); |   }); | ||||||
|  | 
 | ||||||
|   let colorpicker_target = null; |   let colorpicker_target = null; | ||||||
|   const $colorpicker = colorjoe |   const $colorpicker = colorjoe | ||||||
|     .rgb('colorpicker') |     .rgb('colorpicker') | ||||||
| @ -159,7 +174,6 @@ window['__start'] = async () => { | |||||||
|       store(colorpicker_target.id)[colorpicker_target.key] = color.css(); |       store(colorpicker_target.id)[colorpicker_target.key] = color.css(); | ||||||
|     }) |     }) | ||||||
|     .update(); |     .update(); | ||||||
| 
 |  | ||||||
|   document |   document | ||||||
|     .querySelector('#colorpicker') |     .querySelector('#colorpicker') | ||||||
|     .appendChild( |     .appendChild( | ||||||
| @ -184,12 +198,12 @@ window['__start'] = async () => { | |||||||
|   }; |   }; | ||||||
|   function innerText(elem) { |   function innerText(elem) { | ||||||
|     let text = ''; |     let text = ''; | ||||||
|     for (let node of elem.childNodes) { |     for (let $node of elem.childNodes) { | ||||||
|       if (node.nodeType === 3) text += node.textContent; |       if ($node.nodeType === 3) text += $node.textContent; | ||||||
|       if (node.nodeType === 1) |       if ($node.nodeType === 1) | ||||||
|         text += ['text', 'number'].includes(node.type) |         text += ['text', 'number'].includes($node.type) | ||||||
|           ? node.value |           ? $node.value | ||||||
|           : innerText(node); |           : innerText($node); | ||||||
|     } |     } | ||||||
|     return text; |     return text; | ||||||
|   } |   } | ||||||
| @ -197,13 +211,15 @@ window['__start'] = async () => { | |||||||
|     modules.loaded.forEach((mod) => { |     modules.loaded.forEach((mod) => { | ||||||
|       const $search_input = document.querySelector('#search > input'); |       const $search_input = document.querySelector('#search > input'); | ||||||
|       if ( |       if ( | ||||||
|         (mod.elem.classList.contains('enabled') && !search_filters.enabled) || |         !document.body.classList.contains('reorder') && | ||||||
|         (mod.elem.classList.contains('disabled') && !search_filters.disabled) || |         ((mod.elem.classList.contains('enabled') && !search_filters.enabled) || | ||||||
|  |           (mod.elem.classList.contains('disabled') && | ||||||
|  |             !search_filters.disabled) || | ||||||
|           !mod.tags.some((tag) => search_filters.tags.has(tag)) || |           !mod.tags.some((tag) => search_filters.tags.has(tag)) || | ||||||
|           ($search_input.value && |           ($search_input.value && | ||||||
|             !innerText(mod.elem) |             !innerText(mod.elem) | ||||||
|               .toLowerCase() |               .toLowerCase() | ||||||
|             .includes($search_input.value.toLowerCase().trim())) |               .includes($search_input.value.toLowerCase().trim()))) | ||||||
|       ) |       ) | ||||||
|         return (mod.elem.style.display = 'none'); |         return (mod.elem.style.display = 'none'); | ||||||
|       mod.elem.style.display = 'block'; |       mod.elem.style.display = 'block'; | ||||||
| @ -223,21 +239,20 @@ window['__start'] = async () => { | |||||||
|     ); |     ); | ||||||
|     document.querySelector('#tags').append(el); |     document.querySelector('#tags').append(el); | ||||||
|     el.addEventListener('click', (event) => { |     el.addEventListener('click', (event) => { | ||||||
|  |       if (!document.body.classList.contains('reorder')) { | ||||||
|         el.className = el.className === 'selected' ? '' : 'selected'; |         el.className = el.className === 'selected' ? '' : 'selected'; | ||||||
|         onclick(el.className === 'selected'); |         onclick(el.className === 'selected'); | ||||||
|  |       } | ||||||
|     }); |     }); | ||||||
|     return el; |     return el; | ||||||
|   } |   } | ||||||
|   createTag( |   createTag('enabled', (state) => [ | ||||||
|     'enabled', |     ((search_filters.enabled = state), search()), | ||||||
|     (state) => [(search_filters.enabled = state), search()] |   ]); | ||||||
|     // 'var(--theme--bg_green)'
 |   createTag('disabled', (state) => [ | ||||||
|   ); |     (search_filters.disabled = state), | ||||||
|   createTag( |     search(), | ||||||
|     'disabled', |   ]); | ||||||
|     (state) => [(search_filters.disabled = state), search()] |  | ||||||
|     // 'var(--theme--bg_red)'
 |  | ||||||
|   ); |  | ||||||
|   for (let tag of search_filters.tags) |   for (let tag of search_filters.tags) | ||||||
|     createTag(`#${tag}`, (state) => [ |     createTag(`#${tag}`, (state) => [ | ||||||
|       state ? search_filters.tags.add(tag) : search_filters.tags.delete(tag), |       state ? search_filters.tags.add(tag) : search_filters.tags.delete(tag), | ||||||
| @ -284,20 +299,20 @@ window['__start'] = async () => { | |||||||
|     return parsed; |     return parsed; | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   let modified_notice; |   let $modified_notice; | ||||||
|   function modified() { |   function modified() { | ||||||
|     if (modified_notice) return; |     if ($modified_notice) return; | ||||||
|     modified_notice = createAlert( |     $modified_notice = createAlert( | ||||||
|       'info', |       'info', | ||||||
|       `changes may not fully apply until <span data-relaunch>app relaunch</span>.` |       `changes may not fully apply until <span data-relaunch>app relaunch</span>.` | ||||||
|     ); |     ); | ||||||
|     modified_notice.el |     $modified_notice.el | ||||||
|       .querySelector('[data-relaunch]') |       .querySelector('[data-relaunch]') | ||||||
|       .addEventListener('click', (event) => { |       .addEventListener('click', (event) => { | ||||||
|         electron.remote.app.relaunch(); |         electron.remote.app.relaunch(); | ||||||
|         electron.remote.app.quit(); |         electron.remote.app.quit(); | ||||||
|       }); |       }); | ||||||
|     modified_notice.append(); |     $modified_notice.append(); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   const file_icon = await fs.readFile( |   const file_icon = await fs.readFile( | ||||||
| @ -389,15 +404,8 @@ window['__start'] = async () => { | |||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   const $modules = document.querySelector('#modules'); |   const $modules = document.querySelector('#modules'); | ||||||
|   for (let mod of modules.loaded.sort((a, b) => | 
 | ||||||
|     a.tags.includes('core') || |   for (let mod of modules.loaded) { | ||||||
|     store('mods', { [a.id]: { pinned: false } }).pinned |  | ||||||
|       ? -1 |  | ||||||
|       : b.tags.includes('core') || |  | ||||||
|         store('mods', { [b.id]: { pinned: false } }).pinned |  | ||||||
|       ? 1 |  | ||||||
|       : a.name.localeCompare(b.name) |  | ||||||
|   )) { |  | ||||||
|     for (let fonts of mod.fonts || []) { |     for (let fonts of mod.fonts || []) { | ||||||
|       document |       document | ||||||
|         .querySelector('head') |         .querySelector('head') | ||||||
| @ -418,11 +426,13 @@ window['__start'] = async () => { | |||||||
|             }; |             }; | ||||||
|     mod.elem = helpers.createElement(` |     mod.elem = helpers.createElement(` | ||||||
|     <section class="${ |     <section class="${ | ||||||
|         mod.tags.includes('core') || enabled ? 'enabled' : 'disabled' |       mod.id === '0f0bf8b6-eae6-4273-b307-8fc43f2ee082' || enabled | ||||||
|  |         ? 'enabled' | ||||||
|  |         : 'disabled' | ||||||
|     }" id="${mod.id}"> |     }" id="${mod.id}"> | ||||||
|         <div class="meta"> |         <div class="meta"> | ||||||
|         <h3 ${ |         <h3 ${ | ||||||
|             mod.tags.includes('core') |           mod.id === '0f0bf8b6-eae6-4273-b307-8fc43f2ee082' | ||||||
|             ? `>${mod.name}` |             ? `>${mod.name}` | ||||||
|             : `class="toggle">
 |             : `class="toggle">
 | ||||||
|               <input type="checkbox" id="enable_${mod.id}" |               <input type="checkbox" id="enable_${mod.id}" | ||||||
| @ -445,7 +455,9 @@ window['__start'] = async () => { | |||||||
|             </p> |             </p> | ||||||
|             </div> |             </div> | ||||||
|             ${ |             ${ | ||||||
|           mod.options && mod.options.length ? '<div class="options"></div>' : '' |               mod.options && mod.options.length | ||||||
|  |                 ? '<div class="options"></div>' | ||||||
|  |                 : '' | ||||||
|             } |             } | ||||||
|         </section> |         </section> | ||||||
|     `);
 |     `);
 | ||||||
| @ -500,12 +512,102 @@ window['__start'] = async () => { | |||||||
|         } |         } | ||||||
|         $options.appendChild($opt); |         $options.appendChild($opt); | ||||||
|       } |       } | ||||||
|     $modules.append(mod.elem); |     if (mod.tags.includes('core')) $modules.append(mod.elem); | ||||||
|   } |   } | ||||||
| 
 |  | ||||||
|   document |   document | ||||||
|     .querySelectorAll('input[type="checkbox"]') |     .querySelectorAll('input[type="checkbox"]') | ||||||
|     .forEach((checkbox) => |     .forEach((checkbox) => | ||||||
|       checkbox.addEventListener('click', (event) => event.target.blur()) |       checkbox.addEventListener('click', (event) => event.target.blur()) | ||||||
|     ); |     ); | ||||||
|  | 
 | ||||||
|  |   // draggable re-ordering
 | ||||||
|  |   const draggable = { | ||||||
|  |     state: 0, | ||||||
|  |     tags: ['b', 'span'], | ||||||
|  |     $toggle: document.querySelector('#draggable-toggle'), | ||||||
|  |     list: modules.loaded | ||||||
|  |       .filter((m) => !m.tags.includes('core')) | ||||||
|  |       .map((m) => m.elem), | ||||||
|  |     target: null, | ||||||
|  |     render() { | ||||||
|  |       draggable.target = null; | ||||||
|  |       for (let $node of draggable.list) { | ||||||
|  |         $node.draggable = false; | ||||||
|  |         $modules.append($node); | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     mouseover(event) { | ||||||
|  |       if (!draggable.target && event.target.innerText) { | ||||||
|  |         for (let $node of draggable.list) $node.draggable = false; | ||||||
|  |         const $node = draggable.list.find( | ||||||
|  |           (node) => node.innerText === event.target.innerText | ||||||
|  |         ); | ||||||
|  |         if ($node) $node.draggable = draggable.state; | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |   }; | ||||||
|  |   document.addEventListener('dragstart', (event) => { | ||||||
|  |     draggable.target = event.target; | ||||||
|  |     event.target.style.opacity = 0.5; | ||||||
|  |   }); | ||||||
|  |   document.addEventListener('dragend', (event) => { | ||||||
|  |     event.target.style.opacity = ''; | ||||||
|  |   }); | ||||||
|  |   document.addEventListener('dragover', (event) => { | ||||||
|  |     event.preventDefault(); | ||||||
|  |     document | ||||||
|  |       .querySelectorAll('.dragged-over') | ||||||
|  |       .forEach((el) => el.classList.remove('dragged-over')); | ||||||
|  |     const $node = [ | ||||||
|  |       draggable.list[0].previousElementSibling, | ||||||
|  |       ...draggable.list, | ||||||
|  |     ].find((node) => node.innerText === event.target.innerText); | ||||||
|  |     if ($node) $node.classList.add('dragged-over'); | ||||||
|  |   }); | ||||||
|  |   document.addEventListener('drop', (event) => { | ||||||
|  |     event.preventDefault(); | ||||||
|  |     document | ||||||
|  |       .querySelectorAll('.dragged-over') | ||||||
|  |       .forEach((el) => el.classList.remove('dragged-over')); | ||||||
|  |     if ( | ||||||
|  |       draggable.target && | ||||||
|  |       draggable.target.innerText !== event.target.innerText | ||||||
|  |     ) { | ||||||
|  |       const from = draggable.list.findIndex( | ||||||
|  |           (node) => node.innerText === draggable.target.innerText | ||||||
|  |         ), | ||||||
|  |         to = | ||||||
|  |           event.target.innerText === | ||||||
|  |           draggable.list[0].previousElementSibling.innerText | ||||||
|  |             ? 0 | ||||||
|  |             : draggable.list.findIndex( | ||||||
|  |                 (node) => node.innerText === event.target.innerText | ||||||
|  |               ) + 1; | ||||||
|  |       if (to >= 0) { | ||||||
|  |         draggable.list.splice( | ||||||
|  |           to > from ? to - 1 : to, | ||||||
|  |           0, | ||||||
|  |           draggable.list.splice(from, 1)[0] | ||||||
|  |         ); | ||||||
|  |         store('mods').priority = draggable.list.map((m) => m.id); | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |     draggable.render(); | ||||||
|  |     modified(); | ||||||
|  |   }); | ||||||
|  |   document.addEventListener('mouseover', draggable.mouseover); | ||||||
|  |   draggable.render(); | ||||||
|  |   draggable.$toggle.addEventListener('click', (event) => { | ||||||
|  |     draggable.state = !draggable.state; | ||||||
|  |     draggable.tags = draggable.tags.reverse(); | ||||||
|  |     draggable.$toggle.innerHTML = ` | ||||||
|  |       <${draggable.tags[0]} data-bolded="configure">configure</${draggable.tags[0]}> | | ||||||
|  |       <${draggable.tags[1]} data-bolded="reorder">reorder</${draggable.tags[1]}> | ||||||
|  |       `;
 | ||||||
|  |     document.body.classList[draggable.state ? 'add' : 'remove']('reorder'); | ||||||
|  |     $modules | ||||||
|  |       .querySelectorAll('input') | ||||||
|  |       .forEach((input) => (input.disabled = draggable.state)); | ||||||
|  |     search(); | ||||||
|  |   }); | ||||||
| }; | }; | ||||||
| @ -1 +1 @@ | |||||||
| <svg xmlns="http://www.w3.org/2000/svg" width="250" height="250" file="currentColor" viewBox="0 0 250 250"><path d="M124.859 234.52L67.5474 135.736H102.683V12.184H147.323V135.736H182.459L124.859 234.52Z" file="currentColor"/></svg> | <svg xmlns="http://www.w3.org/2000/svg" width="250" height="250" fill="currentColor" viewBox="0 0 250 250"><path d="M124.859 234.52L67.5474 135.736H102.683V12.184H147.323V135.736H182.459L124.859 234.52Z" fill="currentColor"/></svg> | ||||||
| Before Width: | Height: | Size: 231 B After Width: | Height: | Size: 231 B | 
| @ -1 +1 @@ | |||||||
| <svg xmlns="http://www.w3.org/2000/svg" width="250" height="250" file="currentColor" viewBox="0 0 250 250"><path d="M102.683 234.52V110.968H67.5474L124.859 12.184L182.459 110.968H147.323V234.52H102.683Z" file="currentColor"/></svg> | <svg xmlns="http://www.w3.org/2000/svg" width="250" height="250" fill="currentColor" viewBox="0 0 250 250"><path d="M102.683 234.52V110.968H67.5474L124.859 12.184L182.459 110.968H147.323V234.52H102.683Z" fill="currentColor"/></svg> | ||||||
| Before Width: | Height: | Size: 231 B After Width: | Height: | Size: 231 B | 
| @ -1 +1 @@ | |||||||
| <svg xmlns="http://www.w3.org/2000/svg" width="250" height="250" file="currentColor" viewBox="0 0 250 250"><path d="M14.7346 227.26V7.03998H235.215V227.26H14.7346ZM46.4546 195.8H203.495V70.48H46.4546V195.8Z" file="currentColor"/></svg> | <svg xmlns="http://www.w3.org/2000/svg" width="250" height="250" fill="currentColor" viewBox="0 0 250 250"><path d="M14.7346 227.26V7.03998H235.215V227.26H14.7346ZM46.4546 195.8H203.495V70.48H46.4546V195.8Z" fill="currentColor"/></svg> | ||||||
| Before Width: | Height: | Size: 235 B After Width: | Height: | Size: 235 B | 
| @ -1 +1 @@ | |||||||
| <svg xmlns="http://www.w3.org/2000/svg" width="250" height="250" file="currentColor" viewBox="0 0 250 250"><path d="M16.1311 225.96V76.72H84.5111V8.07999H233.751V157.32H165.371V225.96H16.1311ZM110.771 53.58V76.72H165.371V131.32H207.491V53.58H110.771ZM42.3911 199.96H139.111V122.22H42.3911V199.96Z" file="currentColor"/></svg> | <svg xmlns="http://www.w3.org/2000/svg" width="250" height="250" fill="currentColor" viewBox="0 0 250 250"><path d="M16.1311 225.96V76.72H84.5111V8.07999H233.751V157.32H165.371V225.96H16.1311ZM110.771 53.58V76.72H165.371V131.32H207.491V53.58H110.771ZM42.3911 199.96H139.111V122.22H42.3911V199.96Z" fill="currentColor"/></svg> | ||||||
| Before Width: | Height: | Size: 325 B After Width: | Height: | Size: 325 B | 
| @ -1 +1 @@ | |||||||
| <svg xmlns="http://www.w3.org/2000/svg" width="250" height="250" file="currentColor" viewBox="0 0 250 250"><path d="M17.8021 138.04V106.072H232.074V138.04H17.8021Z" file="currentColor"/></svg> | <svg xmlns="http://www.w3.org/2000/svg" width="250" height="250" fill="currentColor" viewBox="0 0 250 250"><path d="M17.8021 138.04V106.072H232.074V138.04H17.8021Z" fill="currentColor"/></svg> | ||||||
| Before Width: | Height: | Size: 192 B After Width: | Height: | Size: 192 B | 
| @ -9,7 +9,7 @@ | |||||||
|     <link rel="stylesheet" href="./css/menu.css" /> |     <link rel="stylesheet" href="./css/menu.css" /> | ||||||
|   </head> |   </head> | ||||||
|   <body> |   <body> | ||||||
|     <header id="menu-titlebar"></header> |     <header id="titlebar"></header> | ||||||
|     <main> |     <main> | ||||||
|       <div id="alerts"></div> |       <div id="alerts"></div> | ||||||
|       <div id="search"> |       <div id="search"> | ||||||
| @ -20,6 +20,10 @@ | |||||||
|         </svg> |         </svg> | ||||||
|         <input type="text" placeholder="search ('/' to focus)" /> |         <input type="text" placeholder="search ('/' to focus)" /> | ||||||
|         <div id="tags"></div> |         <div id="tags"></div> | ||||||
|  |         <button id="draggable-toggle"> | ||||||
|  |           <b data-bolded="configure">configure</b> | | ||||||
|  |           <span data-bolded="reorder">reorder</span> | ||||||
|  |         </button> | ||||||
|       </div> |       </div> | ||||||
|       <div id="modules"></div> |       <div id="modules"></div> | ||||||
|     </main> |     </main> | ||||||
|  | |||||||
| @ -56,6 +56,12 @@ module.exports = { | |||||||
|       type: 'toggle', |       type: 'toggle', | ||||||
|       value: true, |       value: true, | ||||||
|     }, |     }, | ||||||
|  |     { | ||||||
|  |       key: 'snappy_transitions', | ||||||
|  |       label: 'snappy transitions', | ||||||
|  |       type: 'toggle', | ||||||
|  |       value: false, | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|       key: 'hotkey', |       key: 'hotkey', | ||||||
|       label: 'window display hotkey:', |       label: 'window display hotkey:', | ||||||
| @ -68,10 +74,17 @@ module.exports = { | |||||||
|       type: 'input', |       type: 'input', | ||||||
|       value: 'Alt+E', |       value: 'Alt+E', | ||||||
|     }, |     }, | ||||||
|  |     { | ||||||
|  |       key: 'default_page', | ||||||
|  |       label: 'open to default page id/url:', | ||||||
|  |       type: 'input', | ||||||
|  |       value: '', | ||||||
|  |     }, | ||||||
|   ], |   ], | ||||||
|   hacks: { |   hacks: { | ||||||
|     'main/main.js': require('./tray.js'), |     'main/main.js': require('./tray.js'), | ||||||
|     'main/createWindow.js': require('./create.js'), |     'main/systemMenu.js': require('./systemMenu.js'), | ||||||
|  |     'main/createWindow.js': require('./createWindow.js'), | ||||||
|     'renderer/index.js': require('./render.js'), |     'renderer/index.js': require('./render.js'), | ||||||
|     'renderer/preload.js': require('./client.js'), |     'renderer/preload.js': require('./client.js'), | ||||||
|   }, |   }, | ||||||
|  | |||||||
							
								
								
									
										1045
									
								
								mods/core/render.js
									
									
									
									
									
								
							
							
						
						| @ -8,3 +8,4 @@ | |||||||
| @import './css/variables.css'; | @import './css/variables.css'; | ||||||
| @import './css/scrollbars.css'; | @import './css/scrollbars.css'; | ||||||
| @import './css/titlebar.css'; | @import './css/titlebar.css'; | ||||||
|  | @import './css/responsive.css'; | ||||||
|  | |||||||
							
								
								
									
										476
									
								
								mods/core/systemMenu.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,476 @@ | |||||||
|  | /* | ||||||
|  |  * notion-enhancer | ||||||
|  |  * (c) 2020 dragonwocky <thedragonring.bod@gmail.com> (https://dragonwocky.me/)
 | ||||||
|  |  * under the MIT license | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | 'use strict'; | ||||||
|  | 
 | ||||||
|  | module.exports = (store, __exports) => { | ||||||
|  |   const electron = require('electron'), | ||||||
|  |     fs = require('fs-extra'), | ||||||
|  |     { __notion } = require('../../pkg/helpers.js'), | ||||||
|  |     createWindow = require(`${__notion}/app/main/createWindow.js`), | ||||||
|  |     config = require(`${__notion}/app/config.js`), | ||||||
|  |     notion_intl = require(`${__notion}/app/shared/notion-intl/index.js`), | ||||||
|  |     localizationHelper = require(`${__notion}/app/helpers/localizationHelper.js`), | ||||||
|  |     isMac = process.platform === 'darwin', | ||||||
|  |     // why is it inversed? i have no idea, but for some reason this is what works
 | ||||||
|  |     tabsEnabled = !(store('mods')['e1692c29-475e-437b-b7ff-3eee872e1a42'] || {}) | ||||||
|  |       .enabled, | ||||||
|  |     menuMessages = notion_intl.defineMessages({ | ||||||
|  |       fileMenuTitle: { | ||||||
|  |         id: 'desktopTopbar.fileMenu.title', | ||||||
|  |         defaultMessage: 'File', | ||||||
|  |       }, | ||||||
|  |       editMenuTitle: { | ||||||
|  |         id: 'desktopTopbar.editMenu.title', | ||||||
|  |         defaultMessage: 'Edit', | ||||||
|  |       }, | ||||||
|  |       viewMenuTitle: { | ||||||
|  |         id: 'desktopTopbar.viewMenu.title', | ||||||
|  |         defaultMessage: 'View', | ||||||
|  |       }, | ||||||
|  |       windowMenuTitle: { | ||||||
|  |         id: 'desktopTopbar.windowMenu.title', | ||||||
|  |         defaultMessage: 'Window', | ||||||
|  |       }, | ||||||
|  |       helpTitle: { | ||||||
|  |         id: 'desktopTopbar.helpMenu.title', | ||||||
|  |         defaultMessage: 'Help', | ||||||
|  |       }, | ||||||
|  |       newWindow: { | ||||||
|  |         id: 'desktopTopbar.fileMenu.newWindow', | ||||||
|  |         defaultMessage: 'New Window', | ||||||
|  |       }, | ||||||
|  |       closeWindow: { | ||||||
|  |         id: 'desktopTopbar.fileMenu.close', | ||||||
|  |         defaultMessage: 'Close Window', | ||||||
|  |       }, | ||||||
|  |       quit: { | ||||||
|  |         id: 'desktopTopbar.fileMenu.quit', | ||||||
|  |         defaultMessage: 'Exit', | ||||||
|  |       }, | ||||||
|  |       undo: { | ||||||
|  |         id: 'desktopTopbar.editMenu.undo', | ||||||
|  |         defaultMessage: 'Undo', | ||||||
|  |       }, | ||||||
|  |       redo: { | ||||||
|  |         id: 'desktopTopbar.editMenu.redo', | ||||||
|  |         defaultMessage: 'Redo', | ||||||
|  |       }, | ||||||
|  |       cut: { | ||||||
|  |         id: 'desktopTopbar.editMenu.cut', | ||||||
|  |         defaultMessage: 'Cut', | ||||||
|  |       }, | ||||||
|  |       copy: { | ||||||
|  |         id: 'desktopTopbar.editMenu.copy', | ||||||
|  |         defaultMessage: 'Copy', | ||||||
|  |       }, | ||||||
|  |       paste: { | ||||||
|  |         id: 'desktopTopbar.editMenu.paste', | ||||||
|  |         defaultMessage: 'Paste', | ||||||
|  |       }, | ||||||
|  |       selectAll: { | ||||||
|  |         id: 'desktopTopbar.editMenu.selectAll', | ||||||
|  |         defaultMessage: 'Select All', | ||||||
|  |       }, | ||||||
|  |       startSpeaking: { | ||||||
|  |         id: 'desktopTopbar.editMenu.speech.startSpeaking', | ||||||
|  |         defaultMessage: 'Start Speaking', | ||||||
|  |       }, | ||||||
|  |       stopSpeaking: { | ||||||
|  |         id: 'desktopTopbar.editMenu.speech.stopSpeaking', | ||||||
|  |         defaultMessage: 'Stop Speaking', | ||||||
|  |       }, | ||||||
|  |       speech: { | ||||||
|  |         id: 'desktopTopbar.editMenu.speech', | ||||||
|  |         defaultMessage: 'Speech', | ||||||
|  |       }, | ||||||
|  |       reload: { | ||||||
|  |         id: 'desktopTopbar.viewMenu.reload', | ||||||
|  |         defaultMessage: 'Reload', | ||||||
|  |       }, | ||||||
|  |       togglefullscreen: { | ||||||
|  |         id: 'desktopTopbar.viewMenu.togglefullscreen', | ||||||
|  |         defaultMessage: 'Toggle Full Screen', | ||||||
|  |       }, | ||||||
|  |       toggleDevTools: { | ||||||
|  |         id: 'desktopTopbar.toggleDevTools', | ||||||
|  |         defaultMessage: 'Toggle Developer Tools', | ||||||
|  |       }, | ||||||
|  |       toggleWindowDevTools: { | ||||||
|  |         id: 'desktopTopbar.toggleWindowDevTools', | ||||||
|  |         defaultMessage: 'Toggle Window Developer Tools', | ||||||
|  |       }, | ||||||
|  |       maximize: { | ||||||
|  |         id: 'desktopTopbar.windowMenu.maximize', | ||||||
|  |         defaultMessage: 'Maximize', | ||||||
|  |       }, | ||||||
|  |       minimize: { | ||||||
|  |         id: 'desktopTopbar.windowMenu.minimize', | ||||||
|  |         defaultMessage: 'Minimize', | ||||||
|  |       }, | ||||||
|  |       zoom: { | ||||||
|  |         id: 'desktopTopbar.windowMenu.zoom', | ||||||
|  |         defaultMessage: 'Zoom', | ||||||
|  |       }, | ||||||
|  |       front: { | ||||||
|  |         id: 'desktopTopbar.windowMenu.front', | ||||||
|  |         defaultMessage: 'Front', | ||||||
|  |       }, | ||||||
|  |       close: { | ||||||
|  |         id: 'desktopTopbar.windowMenu.close', | ||||||
|  |         defaultMessage: 'Close', | ||||||
|  |       }, | ||||||
|  |       help: { | ||||||
|  |         id: 'desktopTopbar.helpMenu.openHelpAndSupport', | ||||||
|  |         defaultMessage: 'Open Help & Support', | ||||||
|  |       }, | ||||||
|  |       reset: { | ||||||
|  |         id: 'desktopTopbar.appMenu.resetAppAndClearData', | ||||||
|  |         defaultMessage: 'Reset App & Clear Local Data', | ||||||
|  |       }, | ||||||
|  |       about: { | ||||||
|  |         id: 'desktopTopbar.appMenu.about', | ||||||
|  |         defaultMessage: 'About Notion', | ||||||
|  |       }, | ||||||
|  |       services: { | ||||||
|  |         id: 'desktopTopbar.appMenu.services', | ||||||
|  |         defaultMessage: 'Services', | ||||||
|  |       }, | ||||||
|  |       hide: { id: 'desktopTopbar.appMenu.hide', defaultMessage: 'Hide Notion' }, | ||||||
|  |       hideOthers: { | ||||||
|  |         id: 'desktopTopbar.appMenu.hideOthers', | ||||||
|  |         defaultMessage: 'Hide Others', | ||||||
|  |       }, | ||||||
|  |       unhide: { | ||||||
|  |         id: 'desktopTopbar.appMenu.unhide', | ||||||
|  |         defaultMessage: 'Show All', | ||||||
|  |       }, | ||||||
|  |       quitMac: { id: 'desktopTopbar.appMenu.quit', defaultMessage: 'Quit' }, | ||||||
|  |     }), | ||||||
|  |     escapeAmpersand = (message) => message.replace(/&/g, '&&'); | ||||||
|  |   __exports.setupSystemMenu = (locale) => { | ||||||
|  |     const intl = localizationHelper.createIntlShape(locale), | ||||||
|  |       fileMenu = { | ||||||
|  |         role: 'fileMenu', | ||||||
|  |         label: escapeAmpersand(intl.formatMessage(menuMessages.fileMenuTitle)), | ||||||
|  |         submenu: isMac | ||||||
|  |           ? [ | ||||||
|  |               { | ||||||
|  |                 label: escapeAmpersand( | ||||||
|  |                   intl.formatMessage(menuMessages.newWindow) | ||||||
|  |                 ), | ||||||
|  |                 accelerator: 'CmdOrCtrl+Shift+N', | ||||||
|  |                 click: () => createWindow.createWindow(), | ||||||
|  |               }, | ||||||
|  |               ...(tabsEnabled | ||||||
|  |                 ? [ | ||||||
|  |                     { | ||||||
|  |                       role: 'close', | ||||||
|  |                       label: escapeAmpersand( | ||||||
|  |                         intl.formatMessage(menuMessages.closeWindow) | ||||||
|  |                       ), | ||||||
|  |                     }, | ||||||
|  |                   ] | ||||||
|  |                 : []), | ||||||
|  |             ] | ||||||
|  |           : [ | ||||||
|  |               { | ||||||
|  |                 label: escapeAmpersand( | ||||||
|  |                   intl.formatMessage(menuMessages.newWindow) | ||||||
|  |                 ), | ||||||
|  |                 accelerator: 'CmdOrCtrl+Shift+N', | ||||||
|  |                 click: () => createWindow.createWindow(), | ||||||
|  |               }, | ||||||
|  |               ...(tabsEnabled | ||||||
|  |                 ? [ | ||||||
|  |                     { | ||||||
|  |                       role: 'quit', | ||||||
|  |                       label: escapeAmpersand( | ||||||
|  |                         intl.formatMessage(menuMessages.quit) | ||||||
|  |                       ), | ||||||
|  |                     }, | ||||||
|  |                   ] | ||||||
|  |                 : []), | ||||||
|  |             ], | ||||||
|  |       }, | ||||||
|  |       editMenu = { | ||||||
|  |         role: 'editMenu', | ||||||
|  |         label: escapeAmpersand(intl.formatMessage(menuMessages.editMenuTitle)), | ||||||
|  |         submenu: isMac | ||||||
|  |           ? [ | ||||||
|  |               { | ||||||
|  |                 role: 'undo', | ||||||
|  |                 label: escapeAmpersand(intl.formatMessage(menuMessages.undo)), | ||||||
|  |               }, | ||||||
|  |               { | ||||||
|  |                 role: 'redo', | ||||||
|  |                 label: escapeAmpersand(intl.formatMessage(menuMessages.redo)), | ||||||
|  |               }, | ||||||
|  |               { type: 'separator' }, | ||||||
|  |               { | ||||||
|  |                 role: 'cut', | ||||||
|  |                 label: escapeAmpersand(intl.formatMessage(menuMessages.cut)), | ||||||
|  |               }, | ||||||
|  |               { | ||||||
|  |                 role: 'copy', | ||||||
|  |                 label: escapeAmpersand(intl.formatMessage(menuMessages.copy)), | ||||||
|  |               }, | ||||||
|  |               { | ||||||
|  |                 role: 'paste', | ||||||
|  |                 label: escapeAmpersand(intl.formatMessage(menuMessages.paste)), | ||||||
|  |               }, | ||||||
|  |               { | ||||||
|  |                 role: 'selectAll', | ||||||
|  |                 label: escapeAmpersand( | ||||||
|  |                   intl.formatMessage(menuMessages.selectAll) | ||||||
|  |                 ), | ||||||
|  |               }, | ||||||
|  |               { type: 'separator' }, | ||||||
|  |               { | ||||||
|  |                 label: escapeAmpersand(intl.formatMessage(menuMessages.speech)), | ||||||
|  |                 submenu: [ | ||||||
|  |                   { | ||||||
|  |                     role: 'startSpeaking', | ||||||
|  |                     label: escapeAmpersand( | ||||||
|  |                       intl.formatMessage(menuMessages.startSpeaking) | ||||||
|  |                     ), | ||||||
|  |                   }, | ||||||
|  |                   { | ||||||
|  |                     role: 'stopSpeaking', | ||||||
|  |                     label: escapeAmpersand( | ||||||
|  |                       intl.formatMessage(menuMessages.stopSpeaking) | ||||||
|  |                     ), | ||||||
|  |                   }, | ||||||
|  |                 ], | ||||||
|  |               }, | ||||||
|  |             ] | ||||||
|  |           : [ | ||||||
|  |               { | ||||||
|  |                 role: 'undo', | ||||||
|  |                 label: escapeAmpersand(intl.formatMessage(menuMessages.undo)), | ||||||
|  |               }, | ||||||
|  |               { | ||||||
|  |                 role: 'redo', | ||||||
|  |                 label: escapeAmpersand(intl.formatMessage(menuMessages.redo)), | ||||||
|  |               }, | ||||||
|  |               { type: 'separator' }, | ||||||
|  |               { | ||||||
|  |                 role: 'cut', | ||||||
|  |                 label: escapeAmpersand(intl.formatMessage(menuMessages.cut)), | ||||||
|  |               }, | ||||||
|  |               { | ||||||
|  |                 role: 'copy', | ||||||
|  |                 label: escapeAmpersand(intl.formatMessage(menuMessages.copy)), | ||||||
|  |               }, | ||||||
|  |               { | ||||||
|  |                 role: 'paste', | ||||||
|  |                 label: escapeAmpersand(intl.formatMessage(menuMessages.paste)), | ||||||
|  |               }, | ||||||
|  |               { type: 'separator' }, | ||||||
|  |               { | ||||||
|  |                 role: 'selectAll', | ||||||
|  |                 label: escapeAmpersand( | ||||||
|  |                   intl.formatMessage(menuMessages.selectAll) | ||||||
|  |                 ), | ||||||
|  |               }, | ||||||
|  |             ], | ||||||
|  |       }, | ||||||
|  |       viewMenu = { | ||||||
|  |         role: 'viewMenu', | ||||||
|  |         label: escapeAmpersand(intl.formatMessage(menuMessages.viewMenuTitle)), | ||||||
|  |         submenu: [ | ||||||
|  |           { | ||||||
|  |             label: escapeAmpersand(intl.formatMessage(menuMessages.reload)), | ||||||
|  |             accelerator: 'CmdOrCtrl+R', | ||||||
|  |             click() { | ||||||
|  |               const focusedWebContents = electron.webContents.getFocusedWebContents(); | ||||||
|  |               if (focusedWebContents) { | ||||||
|  |                 if (focusedWebContents.hostWebContents) { | ||||||
|  |                   for (const webContentsInstance of electron.webContents.getAllWebContents()) { | ||||||
|  |                     if ( | ||||||
|  |                       webContentsInstance.hostWebContents === | ||||||
|  |                       focusedWebContents.hostWebContents | ||||||
|  |                     ) { | ||||||
|  |                       webContentsInstance.reload(); | ||||||
|  |                     } | ||||||
|  |                   } | ||||||
|  |                 } else { | ||||||
|  |                   focusedWebContents.reload(); | ||||||
|  |                 } | ||||||
|  |               } | ||||||
|  |             }, | ||||||
|  |           }, | ||||||
|  |           { | ||||||
|  |             label: escapeAmpersand( | ||||||
|  |               intl.formatMessage(menuMessages.toggleDevTools) | ||||||
|  |             ), | ||||||
|  |             accelerator: isMac ? 'Alt+Command+I' : 'Ctrl+Shift+I', | ||||||
|  |             click() { | ||||||
|  |               let focusedWebContents = electron.webContents.getFocusedWebContents(); | ||||||
|  |               if (focusedWebContents) { | ||||||
|  |                 const focusedWebContentsUrl = focusedWebContents.getURL(); | ||||||
|  |                 if ( | ||||||
|  |                   focusedWebContentsUrl.startsWith('file://') && | ||||||
|  |                   focusedWebContentsUrl.endsWith('/search.html') | ||||||
|  |                 ) { | ||||||
|  |                   const notionWebviewWebContents = electron.webContents | ||||||
|  |                     .getAllWebContents() | ||||||
|  |                     .find( | ||||||
|  |                       (webContentsInstance) => | ||||||
|  |                         webContentsInstance.hostWebContents === | ||||||
|  |                           focusedWebContents.hostWebContents && | ||||||
|  |                         webContentsInstance !== focusedWebContents | ||||||
|  |                     ); | ||||||
|  |                   if (notionWebviewWebContents) { | ||||||
|  |                     focusedWebContents = notionWebviewWebContents; | ||||||
|  |                   } | ||||||
|  |                 } | ||||||
|  |                 focusedWebContents.toggleDevTools(); | ||||||
|  |               } | ||||||
|  |             }, | ||||||
|  |           }, | ||||||
|  |           { | ||||||
|  |             label: escapeAmpersand( | ||||||
|  |               intl.formatMessage(menuMessages.toggleWindowDevTools) | ||||||
|  |             ), | ||||||
|  |             accelerator: isMac ? 'Shift+Alt+Command+I' : 'Alt+Ctrl+Shift+I', | ||||||
|  |             visible: false, | ||||||
|  |             click(menuItem, focusedWindow) { | ||||||
|  |               if (focusedWindow) { | ||||||
|  |                 focusedWindow.webContents.toggleDevTools(); | ||||||
|  |               } | ||||||
|  |             }, | ||||||
|  |           }, | ||||||
|  |           { type: 'separator' }, | ||||||
|  |           { | ||||||
|  |             role: 'togglefullscreen', | ||||||
|  |             label: escapeAmpersand( | ||||||
|  |               intl.formatMessage(menuMessages.togglefullscreen) | ||||||
|  |             ), | ||||||
|  |           }, | ||||||
|  |         ], | ||||||
|  |       }, | ||||||
|  |       windowMenu = { | ||||||
|  |         role: 'windowMenu', | ||||||
|  |         label: escapeAmpersand( | ||||||
|  |           intl.formatMessage(menuMessages.windowMenuTitle) | ||||||
|  |         ), | ||||||
|  |         submenu: isMac | ||||||
|  |           ? [ | ||||||
|  |               { | ||||||
|  |                 role: 'minimize', | ||||||
|  |                 label: escapeAmpersand( | ||||||
|  |                   intl.formatMessage(menuMessages.minimize) | ||||||
|  |                 ), | ||||||
|  |               }, | ||||||
|  |               { | ||||||
|  |                 role: 'zoom', | ||||||
|  |                 label: escapeAmpersand(intl.formatMessage(menuMessages.zoom)), | ||||||
|  |               }, | ||||||
|  |               { type: 'separator' }, | ||||||
|  |               { | ||||||
|  |                 role: 'front', | ||||||
|  |                 label: escapeAmpersand(intl.formatMessage(menuMessages.front)), | ||||||
|  |               }, | ||||||
|  |             ] | ||||||
|  |           : [ | ||||||
|  |               { | ||||||
|  |                 role: 'minimize', | ||||||
|  |                 label: escapeAmpersand( | ||||||
|  |                   intl.formatMessage(menuMessages.minimize) | ||||||
|  |                 ), | ||||||
|  |               }, | ||||||
|  |               { | ||||||
|  |                 label: escapeAmpersand( | ||||||
|  |                   intl.formatMessage(menuMessages.maximize) | ||||||
|  |                 ), | ||||||
|  |                 click(item, focusedWindow) { | ||||||
|  |                   if (focusedWindow) { | ||||||
|  |                     if (focusedWindow.isMaximized()) { | ||||||
|  |                       focusedWindow.unmaximize(); | ||||||
|  |                     } else { | ||||||
|  |                       focusedWindow.maximize(); | ||||||
|  |                     } | ||||||
|  |                   } | ||||||
|  |                 }, | ||||||
|  |               }, | ||||||
|  |               ...(tabsEnabled | ||||||
|  |                 ? [ | ||||||
|  |                     { | ||||||
|  |                       role: 'close', | ||||||
|  |                       label: escapeAmpersand( | ||||||
|  |                         intl.formatMessage(menuMessages.close) | ||||||
|  |                       ), | ||||||
|  |                     }, | ||||||
|  |                   ] | ||||||
|  |                 : []), | ||||||
|  |             ], | ||||||
|  |       }, | ||||||
|  |       helpMenu = { | ||||||
|  |         role: 'help', | ||||||
|  |         label: escapeAmpersand(intl.formatMessage(menuMessages.helpTitle)), | ||||||
|  |         submenu: [ | ||||||
|  |           { | ||||||
|  |             label: escapeAmpersand(intl.formatMessage(menuMessages.help)), | ||||||
|  |             click() { | ||||||
|  |               electron.shell.openExternal(config.default.baseURL + '/help'); | ||||||
|  |             }, | ||||||
|  |           }, | ||||||
|  |         ], | ||||||
|  |       }, | ||||||
|  |       appMenu = { | ||||||
|  |         role: 'appMenu', | ||||||
|  |         submenu: [ | ||||||
|  |           { | ||||||
|  |             role: 'about', | ||||||
|  |             label: escapeAmpersand(intl.formatMessage(menuMessages.about)), | ||||||
|  |           }, | ||||||
|  |           { type: 'separator' }, | ||||||
|  |           { | ||||||
|  |             label: escapeAmpersand(intl.formatMessage(menuMessages.reset)), | ||||||
|  |             async click(item, focusedWindow) { | ||||||
|  |               await fs.remove(electron.app.getPath('userData')); | ||||||
|  |               electron.app.relaunch(); | ||||||
|  |               electron.app.exit(); | ||||||
|  |             }, | ||||||
|  |           }, | ||||||
|  |           { type: 'separator' }, | ||||||
|  |           { | ||||||
|  |             role: 'services', | ||||||
|  |             label: escapeAmpersand(intl.formatMessage(menuMessages.services)), | ||||||
|  |           }, | ||||||
|  |           { type: 'separator' }, | ||||||
|  |           { | ||||||
|  |             role: 'hide', | ||||||
|  |             label: escapeAmpersand(intl.formatMessage(menuMessages.hide)), | ||||||
|  |           }, | ||||||
|  |           { | ||||||
|  |             role: 'hideOthers', | ||||||
|  |             label: escapeAmpersand(intl.formatMessage(menuMessages.hideOthers)), | ||||||
|  |           }, | ||||||
|  |           { | ||||||
|  |             role: 'unhide', | ||||||
|  |             label: escapeAmpersand(intl.formatMessage(menuMessages.unhide)), | ||||||
|  |           }, | ||||||
|  |           ...(tabsEnabled | ||||||
|  |             ? [ | ||||||
|  |                 { type: 'separator' }, | ||||||
|  |                 { | ||||||
|  |                   role: 'quit', | ||||||
|  |                   label: escapeAmpersand( | ||||||
|  |                     intl.formatMessage(menuMessages.quitMac) | ||||||
|  |                   ), | ||||||
|  |                 }, | ||||||
|  |               ] | ||||||
|  |             : []), | ||||||
|  |         ], | ||||||
|  |       }, | ||||||
|  |       template = [fileMenu, editMenu, viewMenu, windowMenu, helpMenu]; | ||||||
|  |     if (isMac) template.unshift(appMenu); | ||||||
|  |     const menu = electron.Menu.buildFromTemplate(template); | ||||||
|  |     electron.Menu.setApplicationMenu(menu); | ||||||
|  |   }; | ||||||
|  | }; | ||||||
| @ -17,6 +17,8 @@ module.exports = (store, __exports) => { | |||||||
|     helpers = require('../../pkg/helpers.js'); |     helpers = require('../../pkg/helpers.js'); | ||||||
| 
 | 
 | ||||||
|   electron.app.on('ready', () => { |   electron.app.on('ready', () => { | ||||||
|  |     // tray
 | ||||||
|  | 
 | ||||||
|     tray = new electron.Tray( |     tray = new electron.Tray( | ||||||
|       is_win |       is_win | ||||||
|         ? path.resolve(`${__dirname}/icons/windows.ico`) |         ? path.resolve(`${__dirname}/icons/windows.ico`) | ||||||
| @ -28,17 +30,27 @@ module.exports = (store, __exports) => { | |||||||
|           }) |           }) | ||||||
|     ); |     ); | ||||||
| 
 | 
 | ||||||
|     electron.ipcMain.on('enhancer:set-theme-vars', (event, arg) => { |     // menu
 | ||||||
|       if (!enhancer_menu) return; | 
 | ||||||
|       enhancer_menu.webContents.send('enhancer:set-theme-vars', arg); |     electron.ipcMain.on('enhancer:open-menu', (event, arg) => { | ||||||
|  |       openEnhancerMenu(); | ||||||
|     }); |     }); | ||||||
|     electron.ipcMain.on('enhancer:get-theme-vars', (event, arg) => { |     electron.ipcMain.on('enhancer:set-menu-theme', (event, arg) => { | ||||||
|  |       if (!enhancer_menu) return; | ||||||
|  |       enhancer_menu.webContents.send('enhancer:set-menu-theme', arg); | ||||||
|  |     }); | ||||||
|  |     electron.ipcMain.on('enhancer:get-menu-theme', (event, arg) => { | ||||||
|       electron.webContents |       electron.webContents | ||||||
|         .getAllWebContents() |         .getAllWebContents() | ||||||
|         .forEach((webContents) => |         .forEach((webContents) => | ||||||
|           webContents.send('enhancer:get-theme-vars', arg) |           webContents.send('enhancer:get-menu-theme', arg) | ||||||
|         ); |         ); | ||||||
|     }); |     }); | ||||||
|  |     electron.ipcMain.on('enhancer:close-tab', (event, target, tab) => { | ||||||
|  |       electron.webContents | ||||||
|  |         .fromId(target) | ||||||
|  |         .webContents.send('enhancer:close-tab', tab); | ||||||
|  |     }); | ||||||
| 
 | 
 | ||||||
|     function calculateWindowPos(width, height) { |     function calculateWindowPos(width, height) { | ||||||
|       const screen = electron.screen.getDisplayNearestPoint({ |       const screen = electron.screen.getDisplayNearestPoint({ | ||||||
| @ -74,13 +86,13 @@ module.exports = (store, __exports) => { | |||||||
|       }; |       }; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     function openExtensionMenu() { |     function openEnhancerMenu() { | ||||||
|       if (enhancer_menu) return enhancer_menu.show(); |       if (enhancer_menu) return enhancer_menu.show(); | ||||||
|       const window_state = require(`${helpers.__notion.replace( |       const window_state = require(`${helpers.__notion.replace( | ||||||
|         /\\/g, |         /\\/g, | ||||||
|         '/' |         '/' | ||||||
|       )}/app/node_modules/electron-window-state/index.js`)({
 |       )}/app/node_modules/electron-window-state/index.js`)({
 | ||||||
|         file: 'menu-windowstate.json', |         file: 'menu.windowstate.json', | ||||||
|         path: helpers.__data, |         path: helpers.__data, | ||||||
|         defaultWidth: 275, |         defaultWidth: 275, | ||||||
|         defaultHeight: 600, |         defaultHeight: 600, | ||||||
| @ -88,7 +100,7 @@ module.exports = (store, __exports) => { | |||||||
|       electron.shell.openExternal(JSON.stringify(window_state)); |       electron.shell.openExternal(JSON.stringify(window_state)); | ||||||
|       enhancer_menu = new electron.BrowserWindow({ |       enhancer_menu = new electron.BrowserWindow({ | ||||||
|         show: true, |         show: true, | ||||||
|         frame: false, |         frame: !store().frameless, | ||||||
|         titleBarStyle: 'hiddenInset', |         titleBarStyle: 'hiddenInset', | ||||||
|         x: |         x: | ||||||
|           window_state.x || |           window_state.x || | ||||||
| @ -99,7 +111,7 @@ module.exports = (store, __exports) => { | |||||||
|         width: window_state.width, |         width: window_state.width, | ||||||
|         height: window_state.height, |         height: window_state.height, | ||||||
|         webPreferences: { |         webPreferences: { | ||||||
|           preload: path.resolve(`${__dirname}/menu.js`), |           preload: path.resolve(`${__dirname}/enhancerMenu.js`), | ||||||
|           nodeIntegration: true, |           nodeIntegration: true, | ||||||
|           session: electron.session.fromPartition('persist:notion'), |           session: electron.session.fromPartition('persist:notion'), | ||||||
|         }, |         }, | ||||||
| @ -109,8 +121,11 @@ module.exports = (store, __exports) => { | |||||||
|         window_state.saveState(enhancer_menu); |         window_state.saveState(enhancer_menu); | ||||||
|         enhancer_menu = null; |         enhancer_menu = null; | ||||||
|       }); |       }); | ||||||
|  |       // enhancer_menu.webContents.openDevTools();
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     // tray
 | ||||||
|  | 
 | ||||||
|     const contextMenu = electron.Menu.buildFromTemplate([ |     const contextMenu = electron.Menu.buildFromTemplate([ | ||||||
|       { |       { | ||||||
|         type: 'normal', |         type: 'normal', | ||||||
| @ -156,13 +171,13 @@ module.exports = (store, __exports) => { | |||||||
|         type: 'normal', |         type: 'normal', | ||||||
|         label: 'Enhancements', |         label: 'Enhancements', | ||||||
|         accelerator: store().menu_toggle, |         accelerator: store().menu_toggle, | ||||||
|         click: openExtensionMenu, |         click: openEnhancerMenu, | ||||||
|       }, |       }, | ||||||
|       { |       { | ||||||
|         type: 'normal', |         type: 'normal', | ||||||
|         label: 'New Window', |         label: 'New Window', | ||||||
|         click: () => { |         click: () => { | ||||||
|           require('./create.js')( |           require('./createWindow.js')( | ||||||
|             store, |             store, | ||||||
|             require(path.resolve( |             require(path.resolve( | ||||||
|               `${helpers.__notion}/app/main/createWindow.js` |               `${helpers.__notion}/app/main/createWindow.js` | ||||||
| @ -185,6 +200,13 @@ module.exports = (store, __exports) => { | |||||||
|       { |       { | ||||||
|         type: 'separator', |         type: 'separator', | ||||||
|       }, |       }, | ||||||
|  |       { | ||||||
|  |         label: 'Relaunch', | ||||||
|  |         click: () => { | ||||||
|  |           electron.app.relaunch(); | ||||||
|  |           electron.app.quit(); | ||||||
|  |         }, | ||||||
|  |       }, | ||||||
|       { |       { | ||||||
|         label: 'Quit', |         label: 'Quit', | ||||||
|         role: 'quit', |         role: 'quit', | ||||||
| @ -193,16 +215,7 @@ module.exports = (store, __exports) => { | |||||||
|     tray.setContextMenu(contextMenu); |     tray.setContextMenu(contextMenu); | ||||||
|     tray.setToolTip('Notion'); |     tray.setToolTip('Notion'); | ||||||
| 
 | 
 | ||||||
|     electron.globalShortcut.register(store().menu_toggle, () => { |     // hotkey
 | ||||||
|       if ( |  | ||||||
|         electron.BrowserWindow.getAllWindows() |  | ||||||
|           .filter((win) => win.getTitle() !== 'notion-enhancer menu') |  | ||||||
|           .some((win) => win.isFocused()) |  | ||||||
|       ) { |  | ||||||
|         openExtensionMenu(); |  | ||||||
|       } else if (enhancer_menu && enhancer_menu.isFocused()) |  | ||||||
|         enhancer_menu.close(); |  | ||||||
|     }); |  | ||||||
| 
 | 
 | ||||||
|     function showWindows() { |     function showWindows() { | ||||||
|       const windows = electron.BrowserWindow.getAllWindows(); |       const windows = electron.BrowserWindow.getAllWindows(); | ||||||
|  | |||||||
| @ -12,8 +12,9 @@ module.exports = { | |||||||
|   id: 'b4b0aced-2059-43bf-8d1d-ccd757ee5ebb', |   id: 'b4b0aced-2059-43bf-8d1d-ccd757ee5ebb', | ||||||
|   tags: ['extension'], |   tags: ['extension'], | ||||||
|   name: 'custom inserts', |   name: 'custom inserts', | ||||||
|   desc: 'link files for small client-side tweaks.', |   desc: `link files for small client-side tweaks. (not sure how to do something? check out the
 | ||||||
|   version: '0.1.2', |       [tweaks](https://github.com/dragonwocky/notion-enhancer/blob/master/TWEAKS.md) collection.)`,
 | ||||||
|  |   version: '0.1.3', | ||||||
|   author: 'dragonwocky', |   author: 'dragonwocky', | ||||||
|   options: [ |   options: [ | ||||||
|     { |     { | ||||||
|  | |||||||
							
								
								
									
										18
									
								
								mods/dracula-theme/mod.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,18 @@ | |||||||
|  | /* | ||||||
|  |  * dracula-theme | ||||||
|  |  * (c) 2020 u/mimi-shahzad | ||||||
|  |  * (c) 2020 Dracula Theme | ||||||
|  |  * under the MIT license | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | 'use strict'; | ||||||
|  | 
 | ||||||
|  | module.exports = { | ||||||
|  |   id: '033bff54-50ba-4cec-bdc0-b2ca7e307086', | ||||||
|  |   tags: ['theme', 'dark'], | ||||||
|  |   name: 'dracula', | ||||||
|  |   desc: | ||||||
|  |     'a theme based on the popular dracula color palette originally by zeno rocha and friends. ', | ||||||
|  |   version: '0.1.0', | ||||||
|  |   author: 'mimi-shahzad', | ||||||
|  | }; | ||||||
							
								
								
									
										186
									
								
								mods/dracula-theme/styles.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,186 @@ | |||||||
|  | /* | ||||||
|  |  * dracula-theme | ||||||
|  |  * (c) 2020 u/mimi-shahzad | ||||||
|  |  * (c) 2020 Dracula Theme | ||||||
|  |  * under the MIT license | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | :root { | ||||||
|  |   --theme_dark--main: #282a36; | ||||||
|  |   --theme_dark--sidebar: #282a36; | ||||||
|  |   --theme_dark--overlay: #282a36; | ||||||
|  |   --theme_dark--dragarea: #282a36; | ||||||
|  | 
 | ||||||
|  |   --theme_dark--font_sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', | ||||||
|  |     Helvetica, 'Apple Color Emoji', Arial, sans-serif, 'Segoe UI Emoji', | ||||||
|  |     'Segoe UI Symbol'; | ||||||
|  | 
 | ||||||
|  |   --theme_dark--scrollbar: #282a36; | ||||||
|  |   --theme_dark--scrollbar_hover: #6272a4; | ||||||
|  | 
 | ||||||
|  |   --theme_dark--card: #6272a4; | ||||||
|  |   --theme_dark--gallery: #282a36; | ||||||
|  |   --theme_dark--table-border: #6272a4; | ||||||
|  |   --theme_dark--interactive_hover: #282a36; | ||||||
|  |   --theme_dark--button_close: #ff5555; | ||||||
|  | 
 | ||||||
|  |   --theme_dark--selected: #454158; | ||||||
|  |   --theme_dark--primary: #bd93f9; | ||||||
|  |   --theme_dark--primary_hover: #8be9fd; | ||||||
|  |   --theme_dark--primary_click: #bd93f9; | ||||||
|  |   --theme_dark--primary_indicator: #8be9fd; | ||||||
|  | 
 | ||||||
|  |   --theme_dark--option_active-background: var(--theme_dark--primary); | ||||||
|  |   --theme_dark--option_hover-background: var(--theme_dark--primary_hover); | ||||||
|  | 
 | ||||||
|  |   --theme_dark--danger_text: #ff5555; | ||||||
|  |   --theme_dark--danger_border: #ffb86c; | ||||||
|  | 
 | ||||||
|  |   --theme_dark--text: #f8f8f2; | ||||||
|  |   --theme_dark--text_ui: #f8f8f2; | ||||||
|  |   --theme_dark--text_ui_info: #f8f8f2; | ||||||
|  | 
 | ||||||
|  |   --theme_dark--text_gray: #454158; | ||||||
|  |   --theme_dark--text_brown: #6272a4; | ||||||
|  |   --theme_dark--text_orange: #ffb86c; | ||||||
|  |   --theme_dark--text_yellow: #f1fa8c; | ||||||
|  |   --theme_dark--text_green: #50fa7b; | ||||||
|  |   --theme_dark--text_blue: #8be9fd; | ||||||
|  |   --theme_dark--text_purple: #bd93f9; | ||||||
|  |   --theme_dark--text_pink: #ff79c6; | ||||||
|  |   --theme_dark--text_red: #ff5555; | ||||||
|  | 
 | ||||||
|  |   --theme_dark--select-text: #000000; | ||||||
|  |   --theme_dark--select_gray: #454158; | ||||||
|  |   --theme_dark--select_brown: #6272a4; | ||||||
|  |   --theme_dark--select_orange: #ffb86c; | ||||||
|  |   --theme_dark--select_yellow: #f1fa8c; | ||||||
|  |   --theme_dark--select_green: #50fa7b; | ||||||
|  |   --theme_dark--select_blue: #8be9fd; | ||||||
|  |   --theme_dark--select_purple: #bd93f9; | ||||||
|  |   --theme_dark--select_pink: #ff79c6; | ||||||
|  |   --theme_dark--select_red: #ff5555; | ||||||
|  | 
 | ||||||
|  |   --theme_dark--bg-text: var(--theme_dark--select-text); | ||||||
|  |   --theme_dark--bg_gray: var(--theme_dark--select_gray); | ||||||
|  |   --theme_dark--bg_brown: var(--theme_dark--select_brown); | ||||||
|  |   --theme_dark--bg_orange: var(--theme_dark--select_orange); | ||||||
|  |   --theme_dark--bg_yellow: var(--theme_dark--select_yellow); | ||||||
|  |   --theme_dark--bg_green: var(--theme_dark--select_green); | ||||||
|  |   --theme_dark--bg_blue: var(--theme_dark--select_blue); | ||||||
|  |   --theme_dark--bg_purple: var(--theme_dark--select_purple); | ||||||
|  |   --theme_dark--bg_pink: var(--theme_dark--select_pink); | ||||||
|  |   --theme_dark--bg_red: var(--theme_dark--select_red); | ||||||
|  | 
 | ||||||
|  |   --theme_dark--line-text: #000000; | ||||||
|  |   --theme_dark--line_gray: #454158; | ||||||
|  |   --theme_dark--line_brown: #6272a4; | ||||||
|  |   --theme_dark--line_orange: #ffb86c; | ||||||
|  |   --theme_dark--line_yellow: #f1fa8c; | ||||||
|  |   --theme_dark--line_green: #50fa7b; | ||||||
|  |   --theme_dark--line_blue: #8be9fd; | ||||||
|  |   --theme_dark--line_purple: #bd93f9; | ||||||
|  |   --theme_dark--line_pink: #ff79c6; | ||||||
|  |   --theme_dark--line_red: #ff5555; | ||||||
|  | 
 | ||||||
|  |   --theme_dark--callout-text: var(--theme_dark--line-text); | ||||||
|  |   --theme_dark--callout_gray: var(--theme_dark--line_gray); | ||||||
|  |   --theme_dark--callout_brown: var(--theme_dark--line_brown); | ||||||
|  |   --theme_dark--callout_orange: var(--theme_dark--line_orange); | ||||||
|  |   --theme_dark--callout_yellow: var(--theme_dark--line_yellow); | ||||||
|  |   --theme_dark--callout_green: var(--theme_dark--line_green); | ||||||
|  |   --theme_dark--callout_blue: var(--theme_dark--line_blue); | ||||||
|  |   --theme_dark--callout_purple: var(--theme_dark--line_purple); | ||||||
|  |   --theme_dark--callout_pink: var(--theme_dark--line_pink); | ||||||
|  |   --theme_dark--callout_red: var(--theme_dark--line_red); | ||||||
|  | 
 | ||||||
|  |   --theme_dark--code_inline-text: #50fa7b; | ||||||
|  |   --theme_dark--code_inline-background: #44475a; | ||||||
|  |   --theme_dark--code-text: var(--theme_dark--text); | ||||||
|  |   --theme_dark--code-background: #44475a; | ||||||
|  |   --theme_dark--code_function: var(--theme_dark--text_blue); | ||||||
|  |   --theme_dark--code_keyword: var(--theme_dark--text_pink); | ||||||
|  |   --theme_dark--code_tag: var(--theme_dark--text_pink); | ||||||
|  |   --theme_dark--code_operator: var(--theme_dark--text_yellow); | ||||||
|  |   --theme_dark--code_important: var(--theme_dark--text_yellow); | ||||||
|  |   --theme_dark--code_property: var(--theme_dark--text_pink); | ||||||
|  |   --theme_dark--code_builtin: var(--theme_dark--text_yellow); | ||||||
|  |   --theme_dark--code_attr-name: var(--theme_dark--text_yellow); | ||||||
|  |   --theme_dark--code_comment: var(--theme_dark--text_ui); | ||||||
|  |   --theme_dark--code_punctuation: var(--theme_dark--text_gray); | ||||||
|  |   --theme_dark--code_doctype: var(--theme_dark--text_gray); | ||||||
|  |   --theme_dark--code_number: var(--theme_dark--text_purple); | ||||||
|  |   --theme_dark--code_string: var(--theme_dark--text_orange); | ||||||
|  |   --theme_dark--code_attr-value: var(--theme_dark--text_orange); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .notion-dark-theme img[src*='/images/onboarding/use-case-note.png'], | ||||||
|  | .notion-dark-theme | ||||||
|  |   img[src*='/images/onboarding/team-features-illustration.png'] { | ||||||
|  |   filter: invert(1) !important; | ||||||
|  | } | ||||||
|  | .notion-dark-theme img[src*='/images/onboarding/checked.svg'] { | ||||||
|  |   filter: hue-rotate(45deg) !important; | ||||||
|  | } | ||||||
|  | .notion-dark-theme | ||||||
|  |   img[style*='display: block; object-fit: cover; border-radius: 100%; width: 90px; height: 90px;'], | ||||||
|  | .notion-dark-theme | ||||||
|  |   img[style*='display: block; object-fit: cover; border-radius: 3px; width: 56.832px; height: 56.832px; transition: opacity 100ms ease-out 0s;'] { | ||||||
|  |   transition: filter 0.4s ease !important; | ||||||
|  | } | ||||||
|  | .notion-dark-theme | ||||||
|  |   img[style*='display: block; object-fit: cover; border-radius: 100%; width: 90px; height: 90px;']:hover, | ||||||
|  | .notion-dark-theme | ||||||
|  |   img[style*='display: block; object-fit: cover; border-radius: 3px; width: 56.832px; height: 56.832px; transition: opacity 100ms ease-out 0s;']:hover { | ||||||
|  |   filter: brightness(1.2); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .notion-dark-theme | ||||||
|  |   [style*='font-family: Fira Code, Menlo, Courier, monospace;'] { | ||||||
|  |   filter: hue-rotate(170deg) !important; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .notion-dark-theme | ||||||
|  |   .notion-token-remove-button[role*='button'][tabindex*='0']:hover, | ||||||
|  | .notion-dark-theme .notion-record-icon { | ||||||
|  |   background: transparent !important; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .notion-dark-theme .notion-focusable:focus-within, | ||||||
|  | .notion-dark-theme .notion-to_do-block > div > div > div[style*='background:'], | ||||||
|  | .notion-dark-theme div[role='button'], | ||||||
|  | [style*='height: 4px;'] | ||||||
|  |   > .notion-selectable.notion-collection_view_page-block | ||||||
|  |   > *, | ||||||
|  | .notion-dark-theme .notion-calendar-view-day[style*='background: #282a36;'], | ||||||
|  | .DayPicker-Day--today, | ||||||
|  | .notion-dark-theme | ||||||
|  |   .DayPicker:not(.DayPicker--interactionDisabled) | ||||||
|  |   .DayPicker-Day--outside:hover, | ||||||
|  | .notion-dark-theme | ||||||
|  |   .DayPicker:not(.DayPicker--interactionDisabled) | ||||||
|  |   .DayPicker-Day:not(.DayPicker-Day--disabled):not(.DayPicker-Day--value) | ||||||
|  |   .DayPicker-Day.DayPicker-Day--start.DayPicker-Day--selected, | ||||||
|  | .notion-dark-theme .DayPicker-Day.DayPicker-Day--range.DayPicker-Day--start, | ||||||
|  | .notion-dark-theme .DayPicker-Day.DayPicker-Day--range.DayPicker-Day--end { | ||||||
|  |   transition: color 0.4s ease, background 0.4s ease, box-shadow 0.4s ease !important; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .notion-dark-theme [style*='background: #282a36;'], | ||||||
|  | .notion-dark-theme | ||||||
|  |   [style*='background: rgb(80, 85, 88);'][style*='color: rgba(255, 255, 255, 0.7)'], | ||||||
|  | .notion-dark-theme | ||||||
|  |   [style*='background: rgb(80, 85, 88);'][style*='width: 18px;'][style*='height: 18px;'], | ||||||
|  | .notion-dark-theme | ||||||
|  |   [style*='box-shadow: rgba(15, 15, 15, 0.1) 0px 0px 0px 1px, rgba(15, 15, 15, 0.2) 0px 5px 10px, rgba(15, 15, 15, 0.4) 0px 15px 40px;'], | ||||||
|  | .notion-dark-theme [style*='background: rgba(151, 154, 155, 0.5);'], | ||||||
|  | .notion-dark-theme [style*='background: rgba(147, 114, 100, 0.5)'], | ||||||
|  | .notion-dark-theme [style*='background: rgba(255, 163, 68, 0.5)'], | ||||||
|  | .notion-dark-theme [style*='background: rgba(255, 220, 73, 0.5)'], | ||||||
|  | .notion-dark-theme [style*='background: rgba(77, 171, 154, 0.5)'], | ||||||
|  | .notion-dark-theme [style*='background: rgba(82, 156, 202, 0.5)'], | ||||||
|  | .notion-dark-theme [style*='background: rgba(154, 109, 215, 0.5)'], | ||||||
|  | .notion-dark-theme [style*='background: rgba(226, 85, 161, 0.5)'], | ||||||
|  | .notion-dark-theme [style*='background: rgba(255, 115, 105, 0.5)'] { | ||||||
|  |   box-shadow: 0 2px 4px rgb(0 0 0 / 66%) !important; | ||||||
|  | } | ||||||
| @ -29,7 +29,6 @@ module.exports = { | |||||||
|         'joypixels', |         'joypixels', | ||||||
|         'openmoji', |         'openmoji', | ||||||
|         'emojidex', |         'emojidex', | ||||||
|         'messenger', |  | ||||||
|         'lg', |         'lg', | ||||||
|         'htc', |         'htc', | ||||||
|         'mozilla', |         'mozilla', | ||||||
| @ -109,6 +108,15 @@ module.exports = { | |||||||
|                     el.style.display = 'none'; |                     el.style.display = 'none'; | ||||||
|                     if (el.parentElement.getAttribute('contenteditable')) |                     if (el.parentElement.getAttribute('contenteditable')) | ||||||
|                       el.remove(); |                       el.remove(); | ||||||
|  |                   } else if ( | ||||||
|  |                     el.previousElementSibling.matches( | ||||||
|  |                       'span[role="image"][aria-label]' | ||||||
|  |                     ) | ||||||
|  |                   ) { | ||||||
|  |                     el.previousElementSibling.innerText = el.getAttribute( | ||||||
|  |                       'alt' | ||||||
|  |                     ); | ||||||
|  |                     el.setAttribute('aria-label', el.getAttribute('alt')); | ||||||
|                   } |                   } | ||||||
|                 }); |                 }); | ||||||
|               } else { |               } else { | ||||||
| @ -116,11 +124,11 @@ module.exports = { | |||||||
|                   el.parentElement |                   el.parentElement | ||||||
|                     .querySelectorAll('span[role="image"][aria-label]') |                     .querySelectorAll('span[role="image"][aria-label]') | ||||||
|                     .forEach((text) => text.remove()); |                     .forEach((text) => text.remove()); | ||||||
|  |                   el.style.display = 'inline-block'; | ||||||
|                   if (!el.style.background.includes(store().style)) { |                   if (!el.style.background.includes(store().style)) { | ||||||
|                     el.style.background = `url(https://emojicdn.elk.sh/${el.getAttribute( |                     el.style.background = `url(https://emojicdn.elk.sh/${el.getAttribute( | ||||||
|                       'aria-label' |                       'aria-label' | ||||||
|                     )}?style=${store().style})`;
 |                     )}?style=${store().style})`;
 | ||||||
|                     el.style.display = 'inline-block'; |  | ||||||
|                     el.style.backgroundSize = 'contain'; |                     el.style.backgroundSize = 'contain'; | ||||||
|                     el.style.backgroundRepeat = 'no-repeat'; |                     el.style.backgroundRepeat = 'no-repeat'; | ||||||
|                     el.style.opacity = 1; |                     el.style.opacity = 1; | ||||||
| @ -135,12 +143,3 @@ module.exports = { | |||||||
|     }, |     }, | ||||||
|   }, |   }, | ||||||
| }; | }; | ||||||
| // span[role="image"][aria-label]
 |  | ||||||
| /*  */ |  | ||||||
| 
 |  | ||||||
| // <div style="position: relative; width: 36px; height: 36px;">
 |  | ||||||
| //   <img class="notion-emoji" alt="😀" aria-label="😀" src="data:image/gif;base64,R0lGODlhAQABAIAAAP///wAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAOw==" style="width: 36px; height: 36px; background: url("/images/twitter-emoji-spritesheet-64.png") 53.5714% 62.5% / 5700% 5700%; opacity: 1; transition: opacity 100ms ease-out 0s;">
 |  | ||||||
| //   <img alt="😀" aria-label="😀" src="https://notion-emojis.s3-us-west-2.amazonaws.com/v0/svg-twitter/1f600.svg" style="position: absolute; top: 0px; left: 0px; opacity: 0; width: 36px; height: 36px;">
 |  | ||||||
| // </div>
 |  | ||||||
| 
 |  | ||||||
| //   <img class="notion-emoji" alt="✝" aria-label="✝" src="data:image/gif;base64,R0lGODlhAQABAIAAAP///wAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAOw==" style="width: 100%; height: 100%; background: url("/images/twitter-emoji-spritesheet-64.png") 98.2143% 25% / 5700% 5700%;">
 |  | ||||||
|  | |||||||
| @ -1,5 +0,0 @@ | |||||||
| .notion-emoji::after { |  | ||||||
|   content: attr(aria-label, ''); |  | ||||||
|   width: 1em; |  | ||||||
|   height: 1em; |  | ||||||
| } |  | ||||||
| @ -13,6 +13,6 @@ module.exports = { | |||||||
|   name: 'focus mode', |   name: 'focus mode', | ||||||
|   desc: |   desc: | ||||||
|     'hide the titlebar/menubar if the sidebar is closed (will be shown on hover).', |     'hide the titlebar/menubar if the sidebar is closed (will be shown on hover).', | ||||||
|   version: '0.1.0', |   version: '0.1.1', | ||||||
|   author: 'arecsu', |   author: 'arecsu', | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -5,6 +5,11 @@ | |||||||
|  * under the MIT license |  * under the MIT license | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
|  | /* add space at the bottom of the main frame when sidebar is hidden | ||||||
|  |   * -- matches space at top for titlebar */ | ||||||
|  | .notion-dark-theme .notion-frame { | ||||||
|  |   transition: height 100ms ease 0s; | ||||||
|  | } | ||||||
| .notion-sidebar-container[style*='width: 0px;'] + .notion-frame { | .notion-sidebar-container[style*='width: 0px;'] + .notion-frame { | ||||||
|   height: calc( |   height: calc( | ||||||
|     100% - (var(--configured--dragarea_height, 10px) + 45px) |     100% - (var(--configured--dragarea_height, 10px) + 45px) | ||||||
|  | |||||||
							
								
								
									
										16
									
								
								mods/material-ocean/mod.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,16 @@ | |||||||
|  | /* | ||||||
|  |  * material ocean | ||||||
|  |  * (c) 2020 Abubakar Yagoub <i@blacksuan19.me> (https://blacksuan19.tk)
 | ||||||
|  |  * under the MIT license | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | 'use strict'; | ||||||
|  | 
 | ||||||
|  | module.exports = { | ||||||
|  |   id: '69e7ccb2-4aef-484c-876d-3de1b433d2b9', | ||||||
|  |   tags: ['theme', 'dark'], | ||||||
|  |   name: 'material ocean', | ||||||
|  |   desc: 'an oceanic colour palette.', | ||||||
|  |   version: '0.1.0', | ||||||
|  |   author: 'blacksuan19', | ||||||
|  | }; | ||||||
							
								
								
									
										123
									
								
								mods/material-ocean/styles.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,123 @@ | |||||||
|  | /* | ||||||
|  |  * material ocean | ||||||
|  |  * (c) 2020 Abubakar Yagoub <i@blacksuan19.me> (https://blacksuan19.tk) | ||||||
|  |  * under the MIT license | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | :root { | ||||||
|  |   --ocean-main: #0f111a; | ||||||
|  |   --ocean-sec: #00010a; | ||||||
|  |   --ocean-accent: #ff4151; | ||||||
|  |   --ocean-gray: #e0e0e0; | ||||||
|  |   --ocean-brown: #d8b6a6; | ||||||
|  |   --ocean-orange: #fde3c0; | ||||||
|  |   --ocean-yellow: #ebcb8b; | ||||||
|  |   --ocean-green: #a3be8c; | ||||||
|  |   --ocean-blue: #81a1c1; | ||||||
|  |   --ocean-purple: #b48ead; | ||||||
|  |   --ocean-pink: #ffc0cb; | ||||||
|  |   --ocean-red: #bf616a; | ||||||
|  | 
 | ||||||
|  |   --theme_dark--main: var(--ocean-main); | ||||||
|  |   --theme_dark--sidebar: var(--ocean-sec); | ||||||
|  |   --theme_dark--overlay: var(--ocean-sec); | ||||||
|  |   --theme_dark--dragarea: var(--ocean-sec); | ||||||
|  | 
 | ||||||
|  |   --theme_dark--scrollbar: var(--ocean-sec); | ||||||
|  |   --theme_dark--scrollbar_hover: var(--ocean-accent); | ||||||
|  | 
 | ||||||
|  |   --theme_dark--card: var(--ocean-sec); | ||||||
|  |   --theme_dark--gallery: var(--ocean-sec); | ||||||
|  |   --theme_dark--table-border: rgba(255, 255, 255, 0.1); | ||||||
|  |   --theme_dark--interactive_hover: var(--ocean-main); | ||||||
|  |   --theme_dark--button_close: var(--ocean-accent); | ||||||
|  | 
 | ||||||
|  |   --theme_dark--selected: rgba(255, 65, 81, 0.2); | ||||||
|  |   --theme_dark--primary: var(--ocean-accent); | ||||||
|  |   --theme_dark--primary_hover: var(--ocean-accent); | ||||||
|  |   --theme_dark--primary_click: var(--ocean-sec); | ||||||
|  |   --theme_dark--primary_indicator: var(--ocean-accent); | ||||||
|  | 
 | ||||||
|  |   --theme_dark--option_active-background: var(--theme_dark--primary); | ||||||
|  |   --theme_dark--option_hover-background: var(--theme_dark--primary_hover); | ||||||
|  | 
 | ||||||
|  |   --theme_dark--danger_text: #eb5757; | ||||||
|  |   --theme_dark--danger_border: rgba(235, 87, 87, 0.5); | ||||||
|  | 
 | ||||||
|  |   --theme_dark--text: #ffffff; | ||||||
|  |   --theme_dark--text_ui: var(--ocean-gray); | ||||||
|  |   --theme_dark--text_ui_info: var(--ocean-gray); | ||||||
|  | 
 | ||||||
|  |   --theme_dark--text_gray: var(--ocean-gray); | ||||||
|  |   --theme_dark--text_brown: var(--ocean-brown); | ||||||
|  |   --theme_dark--text_orange: var(--ocean-orange); | ||||||
|  |   --theme_dark--text_yellow: var(--ocean-yellow); | ||||||
|  |   --theme_dark--text_green: var(--ocean-green); | ||||||
|  |   --theme_dark--text_blue: var(--ocean-blue); | ||||||
|  |   --theme_dark--text_purple: var(--ocean-purple); | ||||||
|  |   --theme_dark--text_pink: var(--ocean-pink); | ||||||
|  |   --theme_dark--text_red: var(--ocean-red); | ||||||
|  | 
 | ||||||
|  |   --theme_dark--select-text: var(--ocean-main); | ||||||
|  |   --theme_dark--select_gray: var(--ocean-gray); | ||||||
|  |   --theme_dark--select_brown: var(--ocean-brown); | ||||||
|  |   --theme_dark--select_orange: var(--ocean-orange); | ||||||
|  |   --theme_dark--select_yellow: var(--ocean-yellow); | ||||||
|  |   --theme_dark--select_green: var(--ocean-green); | ||||||
|  |   --theme_dark--select_blue: var(--ocean-blue); | ||||||
|  |   --theme_dark--select_purple: var(--ocean-purple); | ||||||
|  |   --theme_dark--select_pink: var(--ocean-pink); | ||||||
|  |   --theme_dark--select_red: var(--ocean-red); | ||||||
|  | 
 | ||||||
|  |   --theme_dark--line-text: var(--ocean-main); | ||||||
|  |   --theme_dark--line_gray: #e0e0e089; | ||||||
|  |   --theme_dark--line_brown: #d8b6a692; | ||||||
|  |   --theme_dark--line_orange: #fde3c09f; | ||||||
|  |   --theme_dark--line_yellow: #ffe6a6ad; | ||||||
|  |   --theme_dark--line_green: #a3be8ca3; | ||||||
|  |   --theme_dark--line_blue: #81a1c1a3; | ||||||
|  |   --theme_dark--line_purple: #b48eada8; | ||||||
|  |   --theme_dark--line_pink: #ffc0cbb1; | ||||||
|  |   --theme_dark--line_red: #bf616a9e; | ||||||
|  | 
 | ||||||
|  |   --theme_dark--bg-text: var(--theme_dark--select-text); | ||||||
|  |   --theme_dark--bg_gray: var(--theme_dark--select_gray); | ||||||
|  |   --theme_dark--bg_brown: var(--theme_dark--select_brown); | ||||||
|  |   --theme_dark--bg_orange: var(--theme_dark--select_orange); | ||||||
|  |   --theme_dark--bg_yellow: var(--theme_dark--select_yellow); | ||||||
|  |   --theme_dark--bg_green: var(--theme_dark--select_green); | ||||||
|  |   --theme_dark--bg_blue: var(--theme_dark--select_blue); | ||||||
|  |   --theme_dark--bg_purple: var(--theme_dark--select_purple); | ||||||
|  |   --theme_dark--bg_pink: var(--theme_dark--select_pink); | ||||||
|  |   --theme_dark--bg_red: var(--theme_dark--select_red); | ||||||
|  | 
 | ||||||
|  |   --theme_dark--callout-text: var(--theme_dark--line-text); | ||||||
|  |   --theme_dark--callout_gray: var(--theme_dark--line_gray); | ||||||
|  |   --theme_dark--callout_brown: var(--theme_dark--line_brown); | ||||||
|  |   --theme_dark--callout_orange: var(--theme_dark--line_orange); | ||||||
|  |   --theme_dark--callout_yellow: var(--theme_dark--line_yellow); | ||||||
|  |   --theme_dark--callout_green: var(--theme_dark--line_green); | ||||||
|  |   --theme_dark--callout_blue: var(--theme_dark--line_blue); | ||||||
|  |   --theme_dark--callout_purple: var(--theme_dark--line_purple); | ||||||
|  |   --theme_dark--callout_pink: var(--theme_dark--line_pink); | ||||||
|  |   --theme_dark--callout_red: var(--theme_dark--line_red); | ||||||
|  | 
 | ||||||
|  |   --theme_dark--code_inline-text: #b3f5c8; | ||||||
|  |   --theme_dark--code_inline-background: var(--ocean-sec); | ||||||
|  |   --theme_dark--code-text: var(--theme_dark--text); | ||||||
|  |   --theme_dark--code-background: var(--ocean-sec); | ||||||
|  |   --theme_dark--code_function: var(--theme_dark--text_blue); | ||||||
|  |   --theme_dark--code_keyword: var(--theme_dark--text_pink); | ||||||
|  |   --theme_dark--code_tag: var(--theme_dark--text_pink); | ||||||
|  |   --theme_dark--code_operator: var(--theme_dark--text_yellow); | ||||||
|  |   --theme_dark--code_important: var(--theme_dark--text_yellow); | ||||||
|  |   --theme_dark--code_property: var(--theme_dark--text_pink); | ||||||
|  |   --theme_dark--code_builtin: var(--theme_dark--text_yellow); | ||||||
|  |   --theme_dark--code_attr-name: var(--theme_dark--text_yellow); | ||||||
|  |   --theme_dark--code_comment: var(--theme_dark--text_gray); | ||||||
|  |   --theme_dark--code_punctuation: var(--theme_dark--text_gray); | ||||||
|  |   --theme_dark--code_doctype: var(--theme_dark--text_gray); | ||||||
|  |   --theme_dark--code_number: var(--theme_dark--text_purple); | ||||||
|  |   --theme_dark--code_string: var(--theme_dark--text_orange); | ||||||
|  |   --theme_dark--code_attr-value: var(--theme_dark--text_orange); | ||||||
|  | } | ||||||
| @ -12,7 +12,7 @@ module.exports = { | |||||||
|   tags: ['theme', 'dark'], |   tags: ['theme', 'dark'], | ||||||
|   name: 'neutral', |   name: 'neutral', | ||||||
|   desc: 'smoother colours and fonts, designed to be more pleasing to the eye.', |   desc: 'smoother colours and fonts, designed to be more pleasing to the eye.', | ||||||
|   version: '0.1.3', |   version: '0.1.4', | ||||||
|   author: 'arecsu', |   author: 'arecsu', | ||||||
|   fonts: [ |   fonts: [ | ||||||
|     'https://rsms.me/inter/inter.css', |     'https://rsms.me/inter/inter.css', | ||||||
|  | |||||||
| @ -143,17 +143,6 @@ | |||||||
|   padding-top: 5px !important; |   padding-top: 5px !important; | ||||||
| } */ | } */ | ||||||
| 
 | 
 | ||||||
| /* add space at the bottom of the main frame when sidebar is hidden |  | ||||||
|  * -- matches space at top for titlebar */ |  | ||||||
| .notion-dark-theme .notion-frame { |  | ||||||
|   transition: height 300ms ease 0s; |  | ||||||
| } |  | ||||||
| .notion-dark-theme |  | ||||||
|   .notion-sidebar-container[style*='width: 0px;'] |  | ||||||
|   + .notion-frame { |  | ||||||
|   height: calc(100vh - 40px) !important; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* hide sidebar "new page" button */ | /* hide sidebar "new page" button */ | ||||||
| .notion-dark-theme | .notion-dark-theme | ||||||
|   .notion-sidebar |   .notion-sidebar | ||||||
|  | |||||||
| @ -12,7 +12,7 @@ module.exports = { | |||||||
|   name: 'night shift', |   name: 'night shift', | ||||||
|   desc: |   desc: | ||||||
|     'sync dark/light theme with the system (overrides normal theme setting).', |     'sync dark/light theme with the system (overrides normal theme setting).', | ||||||
|   version: '0.1.0', |   version: '0.1.1', | ||||||
|   author: 'dragonwocky', |   author: 'dragonwocky', | ||||||
|   hacks: { |   hacks: { | ||||||
|     'renderer/preload.js'(store, __exports) { |     'renderer/preload.js'(store, __exports) { | ||||||
| @ -27,6 +27,7 @@ module.exports = { | |||||||
|           const observer = new MutationObserver(process); |           const observer = new MutationObserver(process); | ||||||
|           observer.observe(notion_elem, { |           observer.observe(notion_elem, { | ||||||
|             attributes: true, |             attributes: true, | ||||||
|  |             subtree: true, | ||||||
|           }); |           }); | ||||||
|           function process(list, observer) { |           function process(list, observer) { | ||||||
|             const mode = `notion-app-inner notion-${ |             const mode = `notion-app-inner notion-${ | ||||||
| @ -34,8 +35,7 @@ module.exports = { | |||||||
|                 ? 'dark' |                 ? 'dark' | ||||||
|                 : 'light' |                 : 'light' | ||||||
|             }-theme`;
 |             }-theme`;
 | ||||||
|             if (list[0].target.className !== mode) |             if (notion_elem.className !== mode) notion_elem.className = mode; | ||||||
|               list[0].target.className = mode; |  | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|       }); |       }); | ||||||
|  | |||||||
| @ -12,7 +12,7 @@ module.exports = { | |||||||
|   tags: ['extension'], |   tags: ['extension'], | ||||||
|   name: 'right-to-left', |   name: 'right-to-left', | ||||||
|   desc: 'enables auto rtl/ltr text direction detection.', |   desc: 'enables auto rtl/ltr text direction detection.', | ||||||
|   version: '1.4.0', |   version: '1.4.1', | ||||||
|   author: 'obahareth', |   author: 'obahareth', | ||||||
|   hacks: { |   hacks: { | ||||||
|     'renderer/preload.js'(store, __exports) { |     'renderer/preload.js'(store, __exports) { | ||||||
| @ -48,7 +48,9 @@ module.exports = { | |||||||
|         function autoAlignPageContent() { |         function autoAlignPageContent() { | ||||||
|           document |           document | ||||||
|             .querySelectorAll( |             .querySelectorAll( | ||||||
|               '.notion-page-content > div[data-block-id]:not([dir]), [placeholder="Untitled"]:not([dir])' |               `.notion-page-content > div[data-block-id]:not([dir]):not(.notion-column_list-block),
 | ||||||
|  |               [placeholder="Untitled"]:not([dir]), | ||||||
|  |               .notion-column-block > div[data-block-id]:not([dir])` | ||||||
|             ) |             ) | ||||||
|             .forEach((block) => block.setAttribute('dir', 'auto')); |             .forEach((block) => block.setAttribute('dir', 'auto')); | ||||||
|           document |           document | ||||||
|  | |||||||
							
								
								
									
										49
									
								
								mods/tabs/mod.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,49 @@ | |||||||
|  | /* | ||||||
|  |  * tabs | ||||||
|  |  * (c) 2020 dragonwocky <thedragonring.bod@gmail.com> (https://dragonwocky.me/)
 | ||||||
|  |  * under the MIT license | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | 'use strict'; | ||||||
|  | 
 | ||||||
|  | // this is just a pseudo mod to "separate" the options
 | ||||||
|  | // from the core module - the core still handles actually
 | ||||||
|  | // making it work.
 | ||||||
|  | module.exports = { | ||||||
|  |   id: 'e1692c29-475e-437b-b7ff-3eee872e1a42', | ||||||
|  |   tags: ['core', 'extension'], | ||||||
|  |   name: 'tabs', | ||||||
|  |   desc: 'have multiple notion pages open in a single window.', | ||||||
|  |   version: '0.1.0', | ||||||
|  |   author: 'dragonwocky', | ||||||
|  |   options: [ | ||||||
|  |     { | ||||||
|  |       key: 'select_modifier', | ||||||
|  |       label: | ||||||
|  |         'tab select modifier (key+1, +2, +3, ... +9 and key+left/right arrows):', | ||||||
|  |       type: 'select', | ||||||
|  |       value: [ | ||||||
|  |         'Alt', | ||||||
|  |         'Command', | ||||||
|  |         'Control', | ||||||
|  |         'Super', | ||||||
|  |         'Alt+Shift', | ||||||
|  |         'Command+Shift', | ||||||
|  |         'Control+Shift', | ||||||
|  |         'Super+Shift', | ||||||
|  |       ], | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       key: 'new_tab', | ||||||
|  |       label: 'new tab keybinding:', | ||||||
|  |       type: 'input', | ||||||
|  |       value: 'CommandOrControl+T', | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       key: 'close_tab', | ||||||
|  |       label: 'close tab keybinding:', | ||||||
|  |       type: 'input', | ||||||
|  |       value: 'CommandOrControl+W', | ||||||
|  |     }, | ||||||
|  |   ], | ||||||
|  | }; | ||||||
| @ -54,7 +54,7 @@ module.exports = { | |||||||
|         let queue = [], |         let queue = [], | ||||||
|           $page = document.getElementsByClassName('notion-page-content')[0]; |           $page = document.getElementsByClassName('notion-page-content')[0]; | ||||||
|         const DOCUMENT_OBSERVER = new MutationObserver((list, observer) => { |         const DOCUMENT_OBSERVER = new MutationObserver((list, observer) => { | ||||||
|             if (!queue.length) requestIdleCallback(() => process(queue)); |             if (!queue.length) requestIdleCallback(() => handle(queue)); | ||||||
|             queue.push(...list); |             queue.push(...list); | ||||||
|           }), |           }), | ||||||
|           PAGE_OBSERVER = new MutationObserver(showPageWordDetails); |           PAGE_OBSERVER = new MutationObserver(showPageWordDetails); | ||||||
| @ -62,7 +62,7 @@ module.exports = { | |||||||
|           childList: true, |           childList: true, | ||||||
|           subtree: true, |           subtree: true, | ||||||
|         }); |         }); | ||||||
|         function process(list) { |         function handle(list) { | ||||||
|           queue = []; |           queue = []; | ||||||
|           for (let { addedNodes } of list) { |           for (let { addedNodes } of list) { | ||||||
|             if ( |             if ( | ||||||
|  | |||||||
							
								
								
									
										198
									
								
								package-lock.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						| @ -0,0 +1,198 @@ | |||||||
|  | { | ||||||
|  |   "name": "notion-enhancer", | ||||||
|  |   "version": "0.9.1", | ||||||
|  |   "lockfileVersion": 1, | ||||||
|  |   "requires": true, | ||||||
|  |   "dependencies": { | ||||||
|  |     "@jsdevtools/file-path-filter": { | ||||||
|  |       "version": "3.0.2", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@jsdevtools/file-path-filter/-/file-path-filter-3.0.2.tgz", | ||||||
|  |       "integrity": "sha512-+SbZG6stIE/nRF2PpRnubtuzhh4pouDsk/hEWwM5mKsSKlFfr4ziAE5VMogGG/K++i9NHbUTxxW0y4vdM678ew==", | ||||||
|  |       "requires": { | ||||||
|  |         "glob-to-regexp": "^0.4.1" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "@jsdevtools/readdir-enhanced": { | ||||||
|  |       "version": "6.0.4", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@jsdevtools/readdir-enhanced/-/readdir-enhanced-6.0.4.tgz", | ||||||
|  |       "integrity": "sha512-I6D6Omu6C7XWHzvlVbXeCS0FSxYYQ13XzdrFuo1K30unnRSpdt9AxY2KyJZbYJyfI2uNNidqDkG9/K/y699AjA==", | ||||||
|  |       "requires": { | ||||||
|  |         "@jsdevtools/file-path-filter": "^3.0.2" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "@types/glob": { | ||||||
|  |       "version": "7.1.3", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.1.3.tgz", | ||||||
|  |       "integrity": "sha512-SEYeGAIQIQX8NN6LDKprLjbrd5dARM5EXsd8GI/A5l0apYI1fGMWgPHSe4ZKL4eozlAyI+doUE9XbYS4xCkQ1w==", | ||||||
|  |       "optional": true, | ||||||
|  |       "requires": { | ||||||
|  |         "@types/minimatch": "*", | ||||||
|  |         "@types/node": "*" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "@types/minimatch": { | ||||||
|  |       "version": "3.0.3", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-3.0.3.tgz", | ||||||
|  |       "integrity": "sha512-tHq6qdbT9U1IRSGf14CL0pUlULksvY9OZ+5eEgl1N7t+OA3tGvNpxJCzuKQlsNgCVwbAs670L1vcVQi8j9HjnA==", | ||||||
|  |       "optional": true | ||||||
|  |     }, | ||||||
|  |     "@types/node": { | ||||||
|  |       "version": "14.11.2", | ||||||
|  |       "resolved": "https://registry.npmjs.org/@types/node/-/node-14.11.2.tgz", | ||||||
|  |       "integrity": "sha512-jiE3QIxJ8JLNcb1Ps6rDbysDhN4xa8DJJvuC9prr6w+1tIh+QAbYyNF3tyiZNLDBIuBCf4KEcV2UvQm/V60xfA==", | ||||||
|  |       "optional": true | ||||||
|  |     }, | ||||||
|  |     "asar": { | ||||||
|  |       "version": "3.0.3", | ||||||
|  |       "resolved": "https://registry.npmjs.org/asar/-/asar-3.0.3.tgz", | ||||||
|  |       "integrity": "sha512-k7zd+KoR+n8pl71PvgElcoKHrVNiSXtw7odKbyNpmgKe7EGRF9Pnu3uLOukD37EvavKwVFxOUpqXTIZC5B5Pmw==", | ||||||
|  |       "requires": { | ||||||
|  |         "@types/glob": "^7.1.1", | ||||||
|  |         "chromium-pickle-js": "^0.2.0", | ||||||
|  |         "commander": "^5.0.0", | ||||||
|  |         "glob": "^7.1.6", | ||||||
|  |         "minimatch": "^3.0.4" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "at-least-node": { | ||||||
|  |       "version": "1.0.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/at-least-node/-/at-least-node-1.0.0.tgz", | ||||||
|  |       "integrity": "sha512-+q/t7Ekv1EDY2l6Gda6LLiX14rU9TV20Wa3ofeQmwPFZbOMo9DXrLbOjFaaclkXKWidIaopwAObQDqwWtGUjqg==" | ||||||
|  |     }, | ||||||
|  |     "balanced-match": { | ||||||
|  |       "version": "1.0.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", | ||||||
|  |       "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" | ||||||
|  |     }, | ||||||
|  |     "brace-expansion": { | ||||||
|  |       "version": "1.1.11", | ||||||
|  |       "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", | ||||||
|  |       "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", | ||||||
|  |       "requires": { | ||||||
|  |         "balanced-match": "^1.0.0", | ||||||
|  |         "concat-map": "0.0.1" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "cac": { | ||||||
|  |       "version": "6.6.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/cac/-/cac-6.6.1.tgz", | ||||||
|  |       "integrity": "sha512-uhki4T3Ax68hw7Dufi0bATVAF8ayBSwOKUEJHjObPrUN4tlQ8Lf7oljpTje/mArLxYN0D743c2zJt4C1bVTCqg==" | ||||||
|  |     }, | ||||||
|  |     "chromium-pickle-js": { | ||||||
|  |       "version": "0.2.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/chromium-pickle-js/-/chromium-pickle-js-0.2.0.tgz", | ||||||
|  |       "integrity": "sha1-BKEGZywYsIWrd02YPfo+oTjyIgU=" | ||||||
|  |     }, | ||||||
|  |     "commander": { | ||||||
|  |       "version": "5.1.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/commander/-/commander-5.1.0.tgz", | ||||||
|  |       "integrity": "sha512-P0CysNDQ7rtVw4QIQtm+MRxV66vKFSvlsQvGYXZWR3qFU0jlMKHZZZgw8e+8DSah4UDKMqnknRDQz+xuQXQ/Zg==" | ||||||
|  |     }, | ||||||
|  |     "concat-map": { | ||||||
|  |       "version": "0.0.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", | ||||||
|  |       "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" | ||||||
|  |     }, | ||||||
|  |     "fs-extra": { | ||||||
|  |       "version": "9.0.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-9.0.1.tgz", | ||||||
|  |       "integrity": "sha512-h2iAoN838FqAFJY2/qVpzFXy+EBxfVE220PalAqQLDVsFOHLJrZvut5puAbCdNv6WJk+B8ihI+k0c7JK5erwqQ==", | ||||||
|  |       "requires": { | ||||||
|  |         "at-least-node": "^1.0.0", | ||||||
|  |         "graceful-fs": "^4.2.0", | ||||||
|  |         "jsonfile": "^6.0.1", | ||||||
|  |         "universalify": "^1.0.0" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "fs.realpath": { | ||||||
|  |       "version": "1.0.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", | ||||||
|  |       "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" | ||||||
|  |     }, | ||||||
|  |     "glob": { | ||||||
|  |       "version": "7.1.6", | ||||||
|  |       "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", | ||||||
|  |       "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", | ||||||
|  |       "requires": { | ||||||
|  |         "fs.realpath": "^1.0.0", | ||||||
|  |         "inflight": "^1.0.4", | ||||||
|  |         "inherits": "2", | ||||||
|  |         "minimatch": "^3.0.4", | ||||||
|  |         "once": "^1.3.0", | ||||||
|  |         "path-is-absolute": "^1.0.0" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "glob-to-regexp": { | ||||||
|  |       "version": "0.4.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz", | ||||||
|  |       "integrity": "sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==" | ||||||
|  |     }, | ||||||
|  |     "graceful-fs": { | ||||||
|  |       "version": "4.2.4", | ||||||
|  |       "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.4.tgz", | ||||||
|  |       "integrity": "sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==" | ||||||
|  |     }, | ||||||
|  |     "inflight": { | ||||||
|  |       "version": "1.0.6", | ||||||
|  |       "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", | ||||||
|  |       "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", | ||||||
|  |       "requires": { | ||||||
|  |         "once": "^1.3.0", | ||||||
|  |         "wrappy": "1" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "inherits": { | ||||||
|  |       "version": "2.0.4", | ||||||
|  |       "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", | ||||||
|  |       "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" | ||||||
|  |     }, | ||||||
|  |     "jsonfile": { | ||||||
|  |       "version": "6.0.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-6.0.1.tgz", | ||||||
|  |       "integrity": "sha512-jR2b5v7d2vIOust+w3wtFKZIfpC2pnRmFAhAC/BuweZFQR8qZzxH1OyrQ10HmdVYiXWkYUqPVsz91cG7EL2FBg==", | ||||||
|  |       "requires": { | ||||||
|  |         "graceful-fs": "^4.1.6", | ||||||
|  |         "universalify": "^1.0.0" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "minimatch": { | ||||||
|  |       "version": "3.0.4", | ||||||
|  |       "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", | ||||||
|  |       "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", | ||||||
|  |       "requires": { | ||||||
|  |         "brace-expansion": "^1.1.7" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "once": { | ||||||
|  |       "version": "1.4.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", | ||||||
|  |       "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", | ||||||
|  |       "requires": { | ||||||
|  |         "wrappy": "1" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "path-is-absolute": { | ||||||
|  |       "version": "1.0.1", | ||||||
|  |       "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", | ||||||
|  |       "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" | ||||||
|  |     }, | ||||||
|  |     "readdir-enhanced": { | ||||||
|  |       "version": "6.0.4", | ||||||
|  |       "resolved": "https://registry.npmjs.org/readdir-enhanced/-/readdir-enhanced-6.0.4.tgz", | ||||||
|  |       "integrity": "sha512-MWY048D/nEpHwqdnsBiUxpqjJPkEw2i2RmY5gM2Gadn0rkHS/DhUBqrYTkOqKHF4RoUlYZZ8GnP4ymlRGuo30A==", | ||||||
|  |       "requires": { | ||||||
|  |         "@jsdevtools/readdir-enhanced": "6.0.4" | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |     "universalify": { | ||||||
|  |       "version": "1.0.0", | ||||||
|  |       "resolved": "https://registry.npmjs.org/universalify/-/universalify-1.0.0.tgz", | ||||||
|  |       "integrity": "sha512-rb6X1W158d7pRQBg5gkR8uPaSfiids68LTJQYOtEUhoJUWBdaQHsuT/EUduxXYxcrt4r5PJ4fuHW1MHT6p0qug==" | ||||||
|  |     }, | ||||||
|  |     "wrappy": { | ||||||
|  |       "version": "1.0.2", | ||||||
|  |       "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", | ||||||
|  |       "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
| @ -1,6 +1,6 @@ | |||||||
| { | { | ||||||
|   "name": "notion-enhancer", |   "name": "notion-enhancer", | ||||||
|   "version": "0.9.1", |   "version": "0.10.0-wip", | ||||||
|   "description": "an enhancer/customiser for the all-in-one productivity workspace notion.so", |   "description": "an enhancer/customiser for the all-in-one productivity workspace notion.so", | ||||||
|   "main": "index.js", |   "main": "index.js", | ||||||
|   "bin": { |   "bin": { | ||||||
| @ -36,6 +36,7 @@ | |||||||
|     "asar": "^3.0.3", |     "asar": "^3.0.3", | ||||||
|     "cac": "^6.5.12", |     "cac": "^6.5.12", | ||||||
|     "fs-extra": "^9.0.1", |     "fs-extra": "^9.0.1", | ||||||
|  |     "keyboardevent-from-electron-accelerator": "^2.0.0", | ||||||
|     "readdir-enhanced": "^6.0.3" |     "readdir-enhanced": "^6.0.3" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										54
									
								
								pkg/apply.js
									
									
									
									
									
								
							
							
						
						| @ -55,7 +55,7 @@ module.exports = async function ({ overwrite_version, friendly_errors } = {}) { | |||||||
|     console.info(' ...unpacking app.asar.'); |     console.info(' ...unpacking app.asar.'); | ||||||
|     const asar_app = path.resolve(`${helpers.__notion}/app.asar`); |     const asar_app = path.resolve(`${helpers.__notion}/app.asar`); | ||||||
|     extractAll(asar_app, `${path.resolve(`${helpers.__notion}/app`)}`); |     extractAll(asar_app, `${path.resolve(`${helpers.__notion}/app`)}`); | ||||||
|     fs.move(asar_app, path.resolve(`${helpers.__notion}/app.asar.bak`)); |     await fs.move(asar_app, path.resolve(`${helpers.__notion}/app.asar.bak`)); | ||||||
| 
 | 
 | ||||||
|     // patching launch script target of custom wrappers
 |     // patching launch script target of custom wrappers
 | ||||||
|     if ( |     if ( | ||||||
| @ -76,8 +76,8 @@ module.exports = async function ({ overwrite_version, friendly_errors } = {}) { | |||||||
|           await fs.outputFile( |           await fs.outputFile( | ||||||
|             bin_path, |             bin_path, | ||||||
|             bin_script |             bin_script | ||||||
|               .replace('electron app.asar\n', 'electron app\n') |               .replace('electron app.asar', 'electron app') | ||||||
|               .replace('electron6 app.asar\n', 'electron6 app\n') |               .replace('electron6 app.asar', 'electron6 app') | ||||||
|           ); |           ); | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
| @ -90,18 +90,40 @@ module.exports = async function ({ overwrite_version, friendly_errors } = {}) { | |||||||
|         filter: (stats) => stats.isFile() && stats.path.endsWith('.js'), |         filter: (stats) => stats.isFile() && stats.path.endsWith('.js'), | ||||||
|       } |       } | ||||||
|     )) { |     )) { | ||||||
|       insertion_target = path.resolve( |       const insertion_file = path.resolve( | ||||||
|         `${helpers.__notion}/app/${insertion_target}` |         `${helpers.__notion}/app/${insertion_target}` | ||||||
|       ); |       ); | ||||||
|  |       if (insertion_target === 'main/main.js') { | ||||||
|  |         // https://github.com/dragonwocky/notion-enhancer/issues/160
 | ||||||
|  |         // patch the notion:// url scheme/protocol to work on linux
 | ||||||
|  |         fs.readFile(insertion_file, 'utf8', (err, data) => { | ||||||
|  |           if (err) throw err; | ||||||
|  |           fs.writeFile( | ||||||
|  |             insertion_file, | ||||||
|  |             `${data.replace( | ||||||
|  |               /process.platform === "win32"/g, | ||||||
|  |               'process.platform === "win32" || process.platform === "linux"' | ||||||
|  |             )}\n\n//notion-enhancer\nrequire('${helpers.realpath(
 | ||||||
|  |               __dirname | ||||||
|  |             )}/loader.js')(__filename, exports);`,
 | ||||||
|  |             'utf8', | ||||||
|  |             (err) => { | ||||||
|  |               if (err) throw err; | ||||||
|  |             } | ||||||
|  |           ); | ||||||
|  |         }); | ||||||
|  |       } else { | ||||||
|         fs.appendFile( |         fs.appendFile( | ||||||
|         insertion_target, |           insertion_file, | ||||||
|           `\n\n//notion-enhancer\nrequire('${helpers.realpath( |           `\n\n//notion-enhancer\nrequire('${helpers.realpath( | ||||||
|             __dirname |             __dirname | ||||||
|           )}/loader.js')(__filename, exports);` |           )}/loader.js')(__filename, exports);` | ||||||
|         ); |         ); | ||||||
|       } |       } | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|     // not resolved, nothing depends on it so it's just a "let it do its thing"
 |     // not resolved, nothing else in application depends on it
 | ||||||
|  |     // so it's just a "let it do its thing"
 | ||||||
|     console.info(' ...recording enhancement version.'); |     console.info(' ...recording enhancement version.'); | ||||||
|     fs.outputFile( |     fs.outputFile( | ||||||
|       path.resolve(`${helpers.__notion}/app/ENHANCER_VERSION.txt`), |       path.resolve(`${helpers.__notion}/app/ENHANCER_VERSION.txt`), | ||||||
| @ -112,11 +134,25 @@ module.exports = async function ({ overwrite_version, friendly_errors } = {}) { | |||||||
|     return true; |     return true; | ||||||
|   } catch (err) { |   } catch (err) { | ||||||
|     console.error('### ERROR ###'); |     console.error('### ERROR ###'); | ||||||
|     if (err.toString().includes('EACCESS') && friendly_errors) { |     if (err.code === 'EACCES' && friendly_errors) { | ||||||
|       console.error( |       console.error( | ||||||
|         'file access forbidden: try again with sudo or in an elevated/admin prompt.' |         `file access forbidden - ${ | ||||||
|  |           process.platform === 'win32' | ||||||
|  |             ? 'make sure your user has elevated permissions.' | ||||||
|  |             : `try running "sudo chmod -R a+wr ${err.path.replace( | ||||||
|  |                 'Notion.app', | ||||||
|  |                 'Notion' | ||||||
|  |               )}" ${ | ||||||
|  |                 err.dest | ||||||
|  |                   ? `and/or "sudo chmod -R a+wr ${err.dest.replace( | ||||||
|  |                       'Notion.app', | ||||||
|  |                       'Notion' | ||||||
|  |                     )}"` | ||||||
|  |                   : '' | ||||||
|  |               }` | ||||||
|  |         }` | ||||||
|       ); |       ); | ||||||
|     } else if (err.toString().includes('EIO') && friendly_errors) { |     } else if (['EIO', 'EBUSY'].includes(err.code) && friendly_errors) { | ||||||
|       console.error('file access failed: is notion running?'); |       console.error('file access failed: is notion running?'); | ||||||
|     } else console.error(err); |     } else console.error(err); | ||||||
|     return false; |     return false; | ||||||
|  | |||||||
| @ -130,6 +130,11 @@ function getEnhancements() { | |||||||
|           )) |           )) | ||||||
|       ) |       ) | ||||||
|         throw Error; |         throw Error; | ||||||
|  |       mod.defaults = {}; | ||||||
|  |       for (let opt of mod.options || []) | ||||||
|  |         mod.defaults[opt.key] = Array.isArray(opt.value) | ||||||
|  |           ? opt.value[0] | ||||||
|  |           : opt.value; | ||||||
|       modules.IDs.push(mod.id); |       modules.IDs.push(mod.id); | ||||||
|       modules.loaded.push({ |       modules.loaded.push({ | ||||||
|         ...mod, |         ...mod, | ||||||
| @ -140,6 +145,17 @@ function getEnhancements() { | |||||||
|       modules.invalid.push(dir); |       modules.invalid.push(dir); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |   modules.loaded = modules.loaded.sort((a, b) => a.name.localeCompare(b.name)); | ||||||
|  |   const priority = require('./store.js')('mods', { priority: [] }).priority; | ||||||
|  |   modules.loaded = [ | ||||||
|  |     ...modules.loaded.filter((m) => m.tags.includes('core')), | ||||||
|  |     ...modules.loaded.filter( | ||||||
|  |       (m) => !m.tags.includes('core') && !priority.includes(m.id) | ||||||
|  |     ), | ||||||
|  |     ...priority | ||||||
|  |       .map((id) => modules.loaded.find((m) => m.id === id)) | ||||||
|  |       .filter((m) => m), | ||||||
|  |   ]; | ||||||
|   return modules; |   return modules; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -55,9 +55,12 @@ module.exports = function (__file, __exports) { | |||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   const modules = helpers.getEnhancements(); |   const modules = helpers.getEnhancements(); | ||||||
|   for (let mod of modules.loaded) { |   for (let mod of [ | ||||||
|  |     ...modules.loaded.filter((m) => m.tags.includes('core')), | ||||||
|  |     ...modules.loaded.filter((m) => !m.tags.includes('core')).reverse(), | ||||||
|  |   ]) { | ||||||
|     if ( |     if ( | ||||||
|       (mod.tags || []).includes('core') || |       mod.id === '0f0bf8b6-eae6-4273-b307-8fc43f2ee082' || | ||||||
|       store('mods', { [mod.id]: { enabled: false } })[mod.id].enabled |       store('mods', { [mod.id]: { enabled: false } })[mod.id].enabled | ||||||
|     ) { |     ) { | ||||||
|       if ( |       if ( | ||||||
| @ -81,20 +84,16 @@ module.exports = function (__file, __exports) { | |||||||
|         }); |         }); | ||||||
|       } |       } | ||||||
|       if (mod.hacks && mod.hacks[__file]) { |       if (mod.hacks && mod.hacks[__file]) { | ||||||
|         mod.defaults = {}; |         mod.hacks[__file]((...args) => { | ||||||
|         for (let opt of mod.options || []) |           if (!args.length) return store(mod.id, mod.defaults); | ||||||
|           mod.defaults[opt.key] = Array.isArray(opt.value) |           if (args.length === 1 && typeof args[0] === 'object') | ||||||
|             ? opt.value[0] |             return store(mod.id, { ...mod.defaults, ...args[0] }); | ||||||
|             : opt.value; |           const other_mod = modules.loaded.find((m) => m.id === args[0]); | ||||||
|         mod.hacks[__file]( |           return store(args[0], { | ||||||
|           (...args) => |             ...(other_mod ? other_mod.defaults : {}), | ||||||
|             !args.length |             ...args[1], | ||||||
|               ? store(mod.id, mod.defaults) |           }); | ||||||
|               : args.length === 1 |         }, __exports); | ||||||
|               ? store(mod.id, { ...mod.defaults, ...args[0] }) |  | ||||||
|               : store(args[0], { ...mod.defaults, ...args[1] }), |  | ||||||
|           __exports |  | ||||||
|         ); |  | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  | |||||||
| @ -103,8 +103,9 @@ module.exports = async function ({ | |||||||
|           await fs.outputFile( |           await fs.outputFile( | ||||||
|             bin_path, |             bin_path, | ||||||
|             bin_script |             bin_script | ||||||
|               .replace('electron app\n', 'electron app.asar\n') |               .replace('electron app', 'electron app.asar') | ||||||
|               .replace('electron6 app\n', 'electron6 app.asar\n') |               .replace('electron6 app', 'electron6 app.asar') | ||||||
|  |               .replace(/(.asar)+/g, '.asar') | ||||||
|           ); |           ); | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
| @ -114,11 +115,25 @@ module.exports = async function ({ | |||||||
|     return true; |     return true; | ||||||
|   } catch (err) { |   } catch (err) { | ||||||
|     console.error('### ERROR ###'); |     console.error('### ERROR ###'); | ||||||
|     if (err.toString().includes('EACCESS') && friendly_errors) { |     if (err.code === 'EACCES' && friendly_errors) { | ||||||
|       console.error( |       console.error( | ||||||
|         'file access forbidden: try again with sudo or in an elevated/admin prompt.' |         `file access forbidden - ${ | ||||||
|  |           process.platform === 'win32' | ||||||
|  |             ? 'make sure your user has elevated permissions.' | ||||||
|  |             : `try running "sudo chmod -R a+wr ${err.path.replace( | ||||||
|  |                 'Notion.app', | ||||||
|  |                 'Notion' | ||||||
|  |               )}" ${ | ||||||
|  |                 err.dest | ||||||
|  |                   ? `and/or "sudo chmod -R a+wr ${err.dest.replace( | ||||||
|  |                       'Notion.app', | ||||||
|  |                       'Notion' | ||||||
|  |                     )}"` | ||||||
|  |                   : '' | ||||||
|  |               }` | ||||||
|  |         }` | ||||||
|       ); |       ); | ||||||
|     } else if (err.toString().includes('EIO') && friendly_errors) { |     } else if (['EIO', 'EBUSY'].includes(err.code) && friendly_errors) { | ||||||
|       console.error('file access failed: is notion running?'); |       console.error('file access failed: is notion running?'); | ||||||
|     } else console.error(err); |     } else console.error(err); | ||||||
|     return false; |     return false; | ||||||
|  | |||||||
| @ -143,6 +143,11 @@ jsonfile@^6.0.1: | |||||||
|   optionalDependencies: |   optionalDependencies: | ||||||
|     graceful-fs "^4.1.6" |     graceful-fs "^4.1.6" | ||||||
| 
 | 
 | ||||||
|  | keyboardevent-from-electron-accelerator@^2.0.0: | ||||||
|  |   version "2.0.0" | ||||||
|  |   resolved "https://registry.yarnpkg.com/keyboardevent-from-electron-accelerator/-/keyboardevent-from-electron-accelerator-2.0.0.tgz#ace21b1aa4e47148815d160057f9edb66567c50c" | ||||||
|  |   integrity sha512-iQcmNA0M4ETMNi0kG/q0h/43wZk7rMeKYrXP7sqKIJbHkTU8Koowgzv+ieR/vWJbOwxx5nDC3UnudZ0aLSu4VA== | ||||||
|  | 
 | ||||||
| minimatch@^3.0.4: | minimatch@^3.0.4: | ||||||
|   version "3.0.4" |   version "3.0.4" | ||||||
|   resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" |   resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" | ||||||
|  | |||||||