mirror of
				https://github.com/notion-enhancer/notion-enhancer.git
				synced 2025-10-25 11:18:08 +11:00 
			
		
		
		
	mod toggling, first extension: bracketed links
This commit is contained in:
		
							parent
							
								
									e0bc581b41
								
							
						
					
					
						commit
						583e6f9adf
					
				| @ -53,16 +53,16 @@ module.exports = { | |||||||
| }; | }; | ||||||
| ``` | ``` | ||||||
| 
 | 
 | ||||||
| | key     | value                                                                                              | type              | | | key     | value                                                                                           | type              | | ||||||
| | ------- | -------------------------------------------------------------------------------------------------- | ----------------- | | | ------- | ----------------------------------------------------------------------------------------------- | ----------------- | | ||||||
| | id      | **required:** uuidv4                                                                               | _string_          | | | id      | **required:** uuidv4                                                                            | _string_          | | ||||||
| | name    | **required:** short name (e.g. 'frameless window')                                                 | _string_          | | | name    | **required:** short name (e.g. 'frameless window')                                              | _string_          | | ||||||
| | tags    | **required:** categories/type (e.g. 'extension', 'theme', 'light', 'dark')                         | _array\<string\>_ | | | tags    | **required:** categories/type (e.g. 'extension', 'theme', 'light', 'dark')                      | _array\<string\>_ | | ||||||
| | desc    | **optional:** 1-3 sentence description of what the module is/does, with basic markdown formatting. | _string_          | | | desc    | **optional:** 1-3 sentence description of what the module is/does, with basic markdown support. | _string_          | | ||||||
| | version | **required:** semver (e.g. '0.3.7')                                                                | _string_          | | | version | **required:** semver (e.g. '0.3.7')                                                             | _string_          | | ||||||
| | author  | **required:** github username                                                                      | _string_          | | | author  | **required:** github username                                                                   | _string_          | | ||||||
| | options | **optional:** see below: options made available in the enhancer menu (accessible from the tray)    | _array\<object\>_ | | | options | **optional:** see below: options made available in the enhancer menu (accessible from the tray) | _array\<object\>_ | | ||||||
| | hacks   | **optional:** see below: code inserted at various points                                           | _object_          | | | hacks   | **optional:** see below: code inserted at various points                                        | _object_          | | ||||||
| 
 | 
 | ||||||
| #### options | #### options | ||||||
| 
 | 
 | ||||||
| @ -86,7 +86,7 @@ each "hack" is a function taking 2 arguments. | |||||||
| 
 | 
 | ||||||
| 1. the **`store`** argument, which allows access to the module | 1. the **`store`** argument, which allows access to the module | ||||||
|    settings/options defined in `mod.js` (those set in the menu, or used internally by the module). |    settings/options defined in `mod.js` (those set in the menu, or used internally by the module). | ||||||
|    each module store is saved to + automatically syncs with `~/.notion-enhancer/id.json`. |    each module store is automatically saved to + loaded from `~/.notion-enhancer/id.json`. | ||||||
|    it can be initialised with `const settings = store({ defaults })`, then used as if it were a normal object. |    it can be initialised with `const settings = store({ defaults })`, then used as if it were a normal object. | ||||||
| 2. the **`__exports`** argument, which is the `module.exports` of the file being modded. | 2. the **`__exports`** argument, which is the `module.exports` of the file being modded. | ||||||
|    this can be used to call or replace functions from notion. |    this can be used to call or replace functions from notion. | ||||||
|  | |||||||
							
								
								
									
										16
									
								
								mods/bracketed-links/mod.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								mods/bracketed-links/mod.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,16 @@ | |||||||
|  | /* | ||||||
|  |  * notion-enhancer | ||||||
|  |  * (c) 2020 dragonwocky <thedragonring.bod@gmail.com> | ||||||
|  |  * (https://dragonwocky.me/) under the MIT license
 | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | 'use strict'; | ||||||
|  | 
 | ||||||
|  | module.exports = { | ||||||
|  |   id: '60e14feb-a81d-4ffb-9b12-7585d346bad8', | ||||||
|  |   tags: ['extension'], | ||||||
|  |   name: 'bracketed links', | ||||||
|  |   desc: 'render links surrounded with [brackets] instead of __underlined__.', | ||||||
|  |   version: '0.0.1', | ||||||
|  |   author: 'arecsu', | ||||||
|  | }; | ||||||
							
								
								
									
										206
									
								
								mods/core/css/localised.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										206
									
								
								mods/core/css/localised.css
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,206 @@ | |||||||
|  | /* | ||||||
|  |  * notion-enhancer | ||||||
|  |  * (c) 2020 dragonwocky <thedragonring.bod@gmail.com> | ||||||
|  |  * (https://dragonwocky.me/) under the MIT license | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | @import './variables.css'; | ||||||
|  | 
 | ||||||
|  | .notion-dark-theme { | ||||||
|  |   --theme_local--main: var(--theme_dark--main); | ||||||
|  |   --theme_local--sidebar: var(--theme_dark--sidebar); | ||||||
|  |   --theme_local--overlay: var(--theme_dark--overlay); | ||||||
|  |   --theme_local--dragarea: var(--theme_dark--dragarea); | ||||||
|  |   --theme_local--preview-width: var(--theme_dark--preview-width); | ||||||
|  |   --theme_local--preview_banner-height: var( | ||||||
|  |     --theme_dark--preview_banner-height | ||||||
|  |   ); | ||||||
|  |   --theme_local--page_banner-height: var(--theme_dark--page_banner-height); | ||||||
|  | 
 | ||||||
|  |   --theme_local--font_sans: var(--theme_dark--font_sans); | ||||||
|  |   --theme_local--font_serif: var(--theme_dark--font_serif); | ||||||
|  |   --theme_local--font_mono: var(--theme_dark--font_mono); | ||||||
|  |   --theme_local--font_code: var(--theme_dark--font_code); | ||||||
|  | 
 | ||||||
|  |   --theme_local--scrollbar: var(--theme_dark--scrollbar); | ||||||
|  |   --theme_local--scrollbar-border: var(--theme_dark--scrollbar-border); | ||||||
|  |   --theme_local--scrollbar_hover: var(--theme_dark--scrollbar_hover); | ||||||
|  | 
 | ||||||
|  |   --theme_local--card: var(--theme_dark--card); | ||||||
|  |   --theme_local--card-border: var(--theme_dark--card-border); | ||||||
|  |   --theme_local--table-border: var(--theme_dark--table-border); | ||||||
|  |   --theme_local--button_hover: var(--theme_dark--button_hover); | ||||||
|  |   --theme_local--button_hover-border: var(--theme_dark--button_hover-border); | ||||||
|  |   --theme_local--button_close: var(--theme_dark--button_close); | ||||||
|  |   --theme_local--button_close-fill: var(--theme_dark--button_close-fill); | ||||||
|  | 
 | ||||||
|  |   --theme_local--selected: var(--theme_dark--selected); | ||||||
|  |   --theme_local--primary: var(--theme_dark--primary); | ||||||
|  |   --theme_local--primary_hover: var(--theme_dark--primary_hover); | ||||||
|  |   --theme_local--primary_click: var(--theme_dark--primary_click); | ||||||
|  |   --theme_local--primary_indicator: var(--theme_dark--primary_indicator); | ||||||
|  | 
 | ||||||
|  |   --theme_local--todo_empty-border: var(--theme_dark--todo_empty-border); | ||||||
|  |   --theme_local--todo_ticked: var(--theme_dark--todo_ticked); | ||||||
|  |   --theme_local--todo_ticked-fill: var(--theme_dark--todo_ticked-fill); | ||||||
|  |   --theme_local--todo_ticked-background: var( | ||||||
|  |     --theme_dark--todo_ticked-background | ||||||
|  |   ); | ||||||
|  |   --theme_local--todo_hover-background: var( | ||||||
|  |     --theme_dark--todo_hover-background | ||||||
|  |   ); | ||||||
|  | 
 | ||||||
|  |   --theme_local--danger_text: var(--theme_dark--danger_text); | ||||||
|  |   --theme_local--danger_border: var(--theme_dark--danger_border); | ||||||
|  | 
 | ||||||
|  |   --theme_local--text: var(--theme_dark--text); | ||||||
|  |   --theme_local--text_ui: var(--theme_dark--text_ui); | ||||||
|  |   --theme_local--text_ui_info: var(--theme_dark--text_ui_info); | ||||||
|  | 
 | ||||||
|  |   --theme_local--text_gray: var(--theme_dark--text_gray); | ||||||
|  |   --theme_local--text_brown: var(--theme_dark--text_brown); | ||||||
|  |   --theme_local--text_orange: var(--theme_dark--text_orange); | ||||||
|  |   --theme_local--text_yellow: var(--theme_dark--text_yellow); | ||||||
|  |   --theme_local--text_green: var(--theme_dark--text_green); | ||||||
|  |   --theme_local--text_blue: var(--theme_dark--text_blue); | ||||||
|  |   --theme_local--text_purple: var(--theme_dark--text_purple); | ||||||
|  |   --theme_local--text_pink: var(--theme_dark--text_pink); | ||||||
|  |   --theme_local--text_red: var(--theme_dark--text_red); | ||||||
|  |   --theme_local--bg_gray: var(--theme_dark--bg_gray); | ||||||
|  |   --theme_local--bg_brown: var(--theme_dark--bg_brown); | ||||||
|  |   --theme_local--bg_orange: var(--theme_dark--bg_orange); | ||||||
|  |   --theme_local--bg_yellow: var(--theme_dark--bg_yellow); | ||||||
|  |   --theme_local--bg_green: var(--theme_dark--bg_green); | ||||||
|  |   --theme_local--bg_blue: var(--theme_dark--bg_blue); | ||||||
|  |   --theme_local--bg_purple: var(--theme_dark--bg_purple); | ||||||
|  |   --theme_local--bg_pink: var(--theme_dark--bg_pink); | ||||||
|  |   --theme_local--bg_red: var(--theme_dark--bg_red); | ||||||
|  |   --theme_local--line_gray: var(--theme_dark--line_gray); | ||||||
|  |   --theme_local--line_brown: var(--theme_dark--line_brown); | ||||||
|  |   --theme_local--line_orange: var(--theme_dark--line_orange); | ||||||
|  |   --theme_local--line_yellow: var(--theme_dark--line_yellow); | ||||||
|  |   --theme_local--line_green: var(--theme_dark--line_green); | ||||||
|  |   --theme_local--line_blue: var(--theme_dark--line_blue); | ||||||
|  |   --theme_local--line_purple: var(--theme_dark--line_purple); | ||||||
|  |   --theme_local--line_pink: var(--theme_dark--line_pink); | ||||||
|  |   --theme_local--line_red: var(--theme_dark--line_red); | ||||||
|  | 
 | ||||||
|  |   --theme_local--code_inline-text: var(--theme_dark--code_inline-text); | ||||||
|  |   --theme_local--code_inline-background: var( | ||||||
|  |     --theme_dark--code_inline-background | ||||||
|  |   ); | ||||||
|  |   --theme_local--code_text: var(--theme_dark--code_text); | ||||||
|  |   --theme_local--code-background: var(--theme_dark--code-background); | ||||||
|  |   --theme_local--code_function: var(--theme_dark--code_function); | ||||||
|  |   --theme_local--code_keyword: var(--theme_dark--code_keyword); | ||||||
|  |   --theme_local--code_tag: var(--theme_dark--code_tag); | ||||||
|  |   --theme_local--code_operator: var(--theme_dark--code_operator); | ||||||
|  |   --theme_local--code_property: var(--theme_dark--code_property); | ||||||
|  |   --theme_local--code_builtin: var(--theme_dark--code_builtin); | ||||||
|  |   --theme_local--code_attr-name: var(--theme_dark--code_attr-name); | ||||||
|  |   --theme_local--code_comment: var(--theme_dark--code_comment); | ||||||
|  |   --theme_local--code_punctuation: var(--theme_dark--code_punctuation); | ||||||
|  |   --theme_local--code_doctype: var(--theme_dark--code_doctype); | ||||||
|  |   --theme_local--code_number: var(--theme_dark--code_number); | ||||||
|  |   --theme_local--code_string: var(--theme_dark--code_string); | ||||||
|  |   --theme_local--code_attr-value: var(--theme_dark--code_attr-value); | ||||||
|  | } | ||||||
|  | .notion-light-theme { | ||||||
|  |   --theme_local--main: var(--theme_light--main); | ||||||
|  |   --theme_local--sidebar: var(--theme_light--sidebar); | ||||||
|  |   --theme_local--overlay: var(--theme_light--overlay); | ||||||
|  |   --theme_local--dragarea: var(--theme_light--dragarea); | ||||||
|  |   --theme_local--preview-width: var(--theme_light--preview-width); | ||||||
|  |   --theme_local--preview_banner-height: var( | ||||||
|  |     --theme_light--preview_banner-height | ||||||
|  |   ); | ||||||
|  |   --theme_local--page_banner-height: var(--theme_light--page_banner-height); | ||||||
|  | 
 | ||||||
|  |   --theme_local--font_sans: var(--theme_light--font_sans); | ||||||
|  |   --theme_local--font_serif: var(--theme_light--font_serif); | ||||||
|  |   --theme_local--font_mono: var(--theme_light--font_mono); | ||||||
|  |   --theme_local--font_code: var(--theme_light--font_code); | ||||||
|  | 
 | ||||||
|  |   --theme_local--scrollbar: var(--theme_light--scrollbar); | ||||||
|  |   --theme_local--scrollbar-border: var(--theme_light--scrollbar-border); | ||||||
|  |   --theme_local--scrollbar_hover: var(--theme_light--scrollbar_hover); | ||||||
|  | 
 | ||||||
|  |   --theme_local--card: var(--theme_light--card); | ||||||
|  |   --theme_local--card-border: var(--theme_light--card-border); | ||||||
|  |   --theme_local--table-border: var(--theme_light--table-border); | ||||||
|  |   --theme_local--button_hover: var(--theme_light--button_hover); | ||||||
|  |   --theme_local--button_hover-border: var(--theme_light--button_hover-border); | ||||||
|  |   --theme_local--button_close: var(--theme_light--button_close); | ||||||
|  |   --theme_local--button_close-fill: var(--theme_light--button_close-fill); | ||||||
|  | 
 | ||||||
|  |   --theme_local--selected: var(--theme_light--selected); | ||||||
|  |   --theme_local--primary: var(--theme_light--primary); | ||||||
|  |   --theme_local--primary_hover: var(--theme_light--primary_hover); | ||||||
|  |   --theme_local--primary_click: var(--theme_light--primary_click); | ||||||
|  |   --theme_local--primary_indicator: var(--theme_light--primary_indicator); | ||||||
|  | 
 | ||||||
|  |   --theme_local--todo_empty-border: var(--theme_light--todo_empty-border); | ||||||
|  |   --theme_local--todo_ticked: var(--theme_light--todo_ticked); | ||||||
|  |   --theme_local--todo_ticked-fill: var(--theme_light--todo_ticked-fill); | ||||||
|  |   --theme_local--todo_ticked-background: var( | ||||||
|  |     --theme_light--todo_ticked-background | ||||||
|  |   ); | ||||||
|  |   --theme_local--todo_hover-background: var( | ||||||
|  |     --theme_light--todo_hover-background | ||||||
|  |   ); | ||||||
|  | 
 | ||||||
|  |   --theme_local--danger_text: var(--theme_light--danger_text); | ||||||
|  |   --theme_local--danger_border: var(--theme_light--danger_border); | ||||||
|  | 
 | ||||||
|  |   --theme_local--text: var(--theme_light--text); | ||||||
|  |   --theme_local--text_ui: var(--theme_light--text_ui); | ||||||
|  |   --theme_local--text_ui_info: var(--theme_light--text_ui_info); | ||||||
|  | 
 | ||||||
|  |   --theme_local--text_gray: var(--theme_light--text_gray); | ||||||
|  |   --theme_local--text_brown: var(--theme_light--text_brown); | ||||||
|  |   --theme_local--text_orange: var(--theme_light--text_orange); | ||||||
|  |   --theme_local--text_yellow: var(--theme_light--text_yellow); | ||||||
|  |   --theme_local--text_green: var(--theme_light--text_green); | ||||||
|  |   --theme_local--text_blue: var(--theme_light--text_blue); | ||||||
|  |   --theme_local--text_purple: var(--theme_light--text_purple); | ||||||
|  |   --theme_local--text_pink: var(--theme_light--text_pink); | ||||||
|  |   --theme_local--text_red: var(--theme_light--text_red); | ||||||
|  |   --theme_local--bg_gray: var(--theme_light--bg_gray); | ||||||
|  |   --theme_local--bg_brown: var(--theme_light--bg_brown); | ||||||
|  |   --theme_local--bg_orange: var(--theme_light--bg_orange); | ||||||
|  |   --theme_local--bg_yellow: var(--theme_light--bg_yellow); | ||||||
|  |   --theme_local--bg_green: var(--theme_light--bg_green); | ||||||
|  |   --theme_local--bg_blue: var(--theme_light--bg_blue); | ||||||
|  |   --theme_local--bg_purple: var(--theme_light--bg_purple); | ||||||
|  |   --theme_local--bg_pink: var(--theme_light--bg_pink); | ||||||
|  |   --theme_local--bg_red: var(--theme_light--bg_red); | ||||||
|  |   --theme_local--line_gray: var(--theme_light--line_gray); | ||||||
|  |   --theme_local--line_brown: var(--theme_light--line_brown); | ||||||
|  |   --theme_local--line_orange: var(--theme_light--line_orange); | ||||||
|  |   --theme_local--line_yellow: var(--theme_light--line_yellow); | ||||||
|  |   --theme_local--line_green: var(--theme_light--line_green); | ||||||
|  |   --theme_local--line_blue: var(--theme_light--line_blue); | ||||||
|  |   --theme_local--line_purple: var(--theme_light--line_purple); | ||||||
|  |   --theme_local--line_pink: var(--theme_light--line_pink); | ||||||
|  |   --theme_local--line_red: var(--theme_light--line_red); | ||||||
|  | 
 | ||||||
|  |   --theme_local--code_inline-text: var(--theme_light--code_inline-text); | ||||||
|  |   --theme_local--code_inline-background: var( | ||||||
|  |     --theme_light--code_inline-background | ||||||
|  |   ); | ||||||
|  |   --theme_local--code_text: var(--theme_light--code_text); | ||||||
|  |   --theme_local--code-background: var(--theme_light--code-background); | ||||||
|  |   --theme_local--code_function: var(--theme_light--code_function); | ||||||
|  |   --theme_local--code_keyword: var(--theme_light--code_keyword); | ||||||
|  |   --theme_local--code_tag: var(--theme_light--code_tag); | ||||||
|  |   --theme_local--code_operator: var(--theme_light--code_operator); | ||||||
|  |   --theme_local--code_property: var(--theme_light--code_property); | ||||||
|  |   --theme_local--code_builtin: var(--theme_light--code_builtin); | ||||||
|  |   --theme_local--code_attr-name: var(--theme_light--code_attr-name); | ||||||
|  |   --theme_local--code_comment: var(--theme_light--code_comment); | ||||||
|  |   --theme_local--code_punctuation: var(--theme_light--code_punctuation); | ||||||
|  |   --theme_local--code_doctype: var(--theme_light--code_doctype); | ||||||
|  |   --theme_local--code_number: var(--theme_light--code_number); | ||||||
|  |   --theme_local--code_string: var(--theme_light--code_string); | ||||||
|  |   --theme_local--code_attr-value: var(--theme_light--code_attr-value); | ||||||
|  | } | ||||||
| @ -6,6 +6,7 @@ | |||||||
| 
 | 
 | ||||||
| @import './buttons.css'; | @import './buttons.css'; | ||||||
| @import './scrollbars.css'; | @import './scrollbars.css'; | ||||||
|  | @import './localised.css'; | ||||||
| 
 | 
 | ||||||
| @keyframes spin { | @keyframes spin { | ||||||
|   from { |   from { | ||||||
| @ -21,6 +22,10 @@ | |||||||
|   word-break: break-word; |   word-break: break-word; | ||||||
|   text-decoration: none; |   text-decoration: none; | ||||||
|   text-size-adjust: 100%; |   text-size-adjust: 100%; | ||||||
|  |   outline-color: var(--theme_local--card-border); | ||||||
|  | } | ||||||
|  | *:active { | ||||||
|  |   outline: none; | ||||||
| } | } | ||||||
| html, | html, | ||||||
| body { | body { | ||||||
| @ -29,6 +34,7 @@ body { | |||||||
|   margin: 0; |   margin: 0; | ||||||
|   padding: 0; |   padding: 0; | ||||||
|   overflow: hidden; |   overflow: hidden; | ||||||
|  |   background: var(--theme_local--main); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| body:not([style]) > * { | body:not([style]) > * { | ||||||
| @ -47,29 +53,11 @@ body:not([style])::after { | |||||||
|   animation: spin 0.8s linear infinite; |   animation: spin 0.8s linear infinite; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .notion-dark-theme * { |  | ||||||
|   outline-color: var(--theme_dark--card-border); |  | ||||||
| } |  | ||||||
| .notion-light-theme * { |  | ||||||
|   outline-color: var(--theme_light--card-border); |  | ||||||
| } |  | ||||||
| *:active { |  | ||||||
|   outline: none; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .notion-dark-theme { |  | ||||||
|   background: var(--theme_dark--main); |  | ||||||
| } |  | ||||||
| .notion-light-theme { |  | ||||||
|   background: var(--theme_light--main); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| main { | main { | ||||||
|   padding: 1em; |   padding: 1em 1em 2.9em 1em; | ||||||
|   height: 100%; |   height: 100%; | ||||||
|   overflow: auto; |   overflow: auto; | ||||||
| } | } | ||||||
| 
 |  | ||||||
| main section { | main section { | ||||||
|   border-radius: 2px; |   border-radius: 2px; | ||||||
|   padding: 0.75em; |   padding: 0.75em; | ||||||
| @ -78,36 +66,24 @@ main section { | |||||||
| 
 | 
 | ||||||
| /* inline formatting */ | /* inline formatting */ | ||||||
| 
 | 
 | ||||||
|  | body, | ||||||
|  | button { | ||||||
|  |   color: var(--theme_local--text); | ||||||
|  |   font-family: var(--theme_local--font_sans); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| code { | code { | ||||||
|   border-radius: 0.1em; |   border-radius: 0.1em; | ||||||
|   padding: 0.2em 0.4em; |   padding: 0.2em 0.4em; | ||||||
| } |   font: 0.85em var(--theme_local--font_code); | ||||||
| .notion-dark-theme code { |   /* color: var(--theme_local--code_inline-text); */ | ||||||
|   font: 0.85em var(--theme_dark--font_code); |   background: var(--theme_local--code_inline-background); | ||||||
|   /* color: var(--theme_dark--code_inline-text); */ |  | ||||||
|   background: var(--theme_dark--code_inline-background); |  | ||||||
| } |  | ||||||
| .notion-light-theme code { |  | ||||||
|   font: 0.85em var(--theme_light--font_code); |  | ||||||
|   /* color: var(--theme_light--code_inline-text); */ |  | ||||||
|   background: var(--theme_light--code_inline-background); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| u { | u { | ||||||
|   text-decoration: underline; |   text-decoration: underline; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .notion-dark-theme, |  | ||||||
| .notion-dark-theme button { |  | ||||||
|   color: var(--theme_dark--text); |  | ||||||
|   font-family: var(--theme_dark--font_sans); |  | ||||||
| } |  | ||||||
| .notion-light-theme, |  | ||||||
| .notion-light-theme button { |  | ||||||
|   color: var(--theme_light--text); |  | ||||||
|   font-family: var(--theme_light--font_sans); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* titlebar */ | /* titlebar */ | ||||||
| 
 | 
 | ||||||
| #menu-titlebar::before { | #menu-titlebar::before { | ||||||
| @ -131,11 +107,8 @@ u { | |||||||
| #menu-titlebar :first-child { | #menu-titlebar :first-child { | ||||||
|   margin-left: auto; |   margin-left: auto; | ||||||
| } | } | ||||||
| .notion-dark-theme #menu-titlebar { | #menu-titlebar { | ||||||
|   background: var(--theme_dark--dragarea); |   background: var(--theme_local--dragarea); | ||||||
| } |  | ||||||
| .notion-light-theme #menu-titlebar { |  | ||||||
|   background: var(--theme_light--dragarea); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| /* alerts */ | /* alerts */ | ||||||
| @ -155,13 +128,40 @@ u { | |||||||
|   font-size: 1rem; |   font-size: 1rem; | ||||||
|   margin: auto 0; |   margin: auto 0; | ||||||
|   padding-left: 0.5em; |   padding-left: 0.5em; | ||||||
|  |   color: var(--theme_local--text_ui); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .notion-dark-theme #alerts [role='alert'] p { | #alerts .error::before { | ||||||
|   color: var(--theme_dark--text_ui); |   color: var(--theme_local--bg_red); | ||||||
| } | } | ||||||
| .notion-light-theme #alerts [role='alert'] p { | #alerts .error { | ||||||
|   color: var(--theme_light--text_ui); |   border: 1px solid var(--theme_local--bg_red); | ||||||
|  |   background: var(--theme_local--line_red); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #alerts .warning::before { | ||||||
|  |   color: var(--theme_local--bg_yellow); | ||||||
|  | } | ||||||
|  | #alerts .warning { | ||||||
|  |   border: 1px solid var(--theme_local--bg_yellow); | ||||||
|  |   background: var(--theme_local--line_yellow); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #alerts .info::before { | ||||||
|  |   color: var(--theme_local--bg_blue); | ||||||
|  | } | ||||||
|  | #alerts .info { | ||||||
|  |   border: 1px solid var(--theme_local--bg_blue); | ||||||
|  |   background: var(--theme_local--line_blue); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #alerts .success::before { | ||||||
|  |   content: '✓'; | ||||||
|  |   color: var(--theme_local--bg_green); | ||||||
|  | } | ||||||
|  | #alerts .success { | ||||||
|  |   border: 1px solid var(--theme_local--bg_green); | ||||||
|  |   background: var(--theme_local--line_green); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .notion-light-theme #alerts [role='alert']::before { | .notion-light-theme #alerts [role='alert']::before { | ||||||
| @ -171,62 +171,11 @@ u { | |||||||
|   border: 1px solid rgba(0, 0, 0, 0.1); |   border: 1px solid rgba(0, 0, 0, 0.1); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .notion-dark-theme #alerts .error { | /* module meta */ | ||||||
|   border: 1px solid var(--theme_dark--bg_red); |  | ||||||
|   background: var(--theme_dark--line_red); |  | ||||||
| } |  | ||||||
| .notion-dark-theme #alerts .error::before { |  | ||||||
|   color: var(--theme_dark--bg_red); |  | ||||||
| } |  | ||||||
| .notion-light-theme #alerts .error { |  | ||||||
|   background: var(--theme_light--line_red); |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| .notion-dark-theme #alerts .warning { | #modules section { | ||||||
|   border: 1px solid var(--theme_dark--bg_yellow); |   background: var(--theme_local--sidebar); | ||||||
|   background: var(--theme_dark--line_yellow); |   border: 1px solid var(--theme_local--table-border); | ||||||
| } |  | ||||||
| .notion-dark-theme #alerts .warning::before { |  | ||||||
|   color: var(--theme_dark--bg_yellow); |  | ||||||
| } |  | ||||||
| .notion-light-theme #alerts .warning { |  | ||||||
|   background: var(--theme_light--line_yellow); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .notion-dark-theme #alerts .info { |  | ||||||
|   border: 1px solid var(--theme_dark--bg_blue); |  | ||||||
|   background: var(--theme_dark--line_blue); |  | ||||||
| } |  | ||||||
| .notion-dark-theme #alerts .info::before { |  | ||||||
|   color: var(--theme_dark--bg_blue); |  | ||||||
| } |  | ||||||
| .notion-light-theme #alerts .info { |  | ||||||
|   background: var(--theme_light--line_blue); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| #alerts .success::before { |  | ||||||
|   content: '✓'; |  | ||||||
| } |  | ||||||
| .notion-dark-theme #alerts .success { |  | ||||||
|   border: 1px solid var(--theme_dark--bg_green); |  | ||||||
|   background: var(--theme_dark--line_green); |  | ||||||
| } |  | ||||||
| .notion-dark-theme #alerts .success::before { |  | ||||||
|   color: var(--theme_dark--bg_green); |  | ||||||
| } |  | ||||||
| .notion-light-theme #alerts .success { |  | ||||||
|   background: var(--theme_light--line_green); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /* modules */ |  | ||||||
| 
 |  | ||||||
| .notion-dark-theme #modules section { |  | ||||||
|   background: var(--theme_dark--sidebar); |  | ||||||
|   border: 1px solid var(--theme_dark--table-border); |  | ||||||
| } |  | ||||||
| .notion-light-theme #modules section { |  | ||||||
|   background: var(--theme_light--sidebar); |  | ||||||
|   border: 1px solid var(--theme_light--card-border); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| #modules section h3, | #modules section h3, | ||||||
| @ -272,12 +221,54 @@ u { | |||||||
| #modules section .tags, | #modules section .tags, | ||||||
| #modules section .version { | #modules section .version { | ||||||
|   font-size: 0.85em; |   font-size: 0.85em; | ||||||
|  |   color: var(--theme_local--text_ui); | ||||||
| } | } | ||||||
| .notion-dark-theme #modules section .tags, | 
 | ||||||
| .notion-dark-theme #modules section .version { | /* module options */ | ||||||
|   color: var(--theme_dark--text_ui); | 
 | ||||||
|  | .toggle * { | ||||||
|  |   cursor: pointer; | ||||||
| } | } | ||||||
| .notion-light-theme #modules section .tags, | .toggle input { | ||||||
| .notion-light-theme #modules section .version { |   display: none; | ||||||
|   color: var(--theme_light--text_ui); | } | ||||||
|  | .toggle input + label .switch { | ||||||
|  |   position: relative; | ||||||
|  |   margin-top: 0.5em; | ||||||
|  |   float: right; | ||||||
|  |   height: 0.65em; | ||||||
|  |   width: 2em; | ||||||
|  |   background: var(--theme_local--card); | ||||||
|  |   border-radius: 5px; | ||||||
|  | } | ||||||
|  | .toggle input + label .switch:before { | ||||||
|  |   content: ''; | ||||||
|  |   position: absolute; | ||||||
|  |   left: 0; | ||||||
|  |   top: 0; | ||||||
|  |   right: 0; | ||||||
|  |   bottom: 0; | ||||||
|  |   border-radius: inherit; | ||||||
|  |   background: linear-gradient( | ||||||
|  |     90deg, | ||||||
|  |     var(--theme_local--primary), | ||||||
|  |     var(--theme_local--primary_click) | ||||||
|  |   ); | ||||||
|  |   opacity: var(--menu--toggle_opacity, 0); | ||||||
|  |   transition: opacity 300ms; | ||||||
|  | } | ||||||
|  | .toggle input + label .switch .dot { | ||||||
|  |   position: absolute; | ||||||
|  |   width: 1em; | ||||||
|  |   height: 1em; | ||||||
|  |   top: -0.15em; | ||||||
|  |   border-radius: 50%; | ||||||
|  |   transform: translateX(var(--menu--toggle_offset, 0)); | ||||||
|  |   transition: transform 350ms, box-shadow 350ms; | ||||||
|  |   background: var(--theme_local--todo_ticked-fill); | ||||||
|  |   box-shadow: 2px 1px 4px var(--theme_local--table-border); | ||||||
|  | } | ||||||
|  | .toggle input:checked + label { | ||||||
|  |   --menu--toggle_offset: 1em; | ||||||
|  |   --menu--toggle_opacity: 1; | ||||||
| } | } | ||||||
|  | |||||||
| @ -18,10 +18,7 @@ window['__start'] = async () => { | |||||||
| 
 | 
 | ||||||
|   document.defaultView.addEventListener('keyup', (event) => { |   document.defaultView.addEventListener('keyup', (event) => { | ||||||
|     if (event.code === 'F5') window.reload(); |     if (event.code === 'F5') window.reload(); | ||||||
|     if (event.key === 'e' && (event.ctrlKey || event.metaKey)) { |     if (event.key === 'e' && (event.ctrlKey || event.metaKey)) browser.close(); | ||||||
|       electron.remote.BrowserWindow.getAllWindows()[0].show(); |  | ||||||
|       browser.close(); |  | ||||||
|     } |  | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|   electron.ipcRenderer.on('enhancer:set-theme', (event, theme) => { |   electron.ipcRenderer.on('enhancer:set-theme', (event, theme) => { | ||||||
| @ -113,28 +110,69 @@ window['__start'] = async () => { | |||||||
| 
 | 
 | ||||||
|   // mod options
 |   // mod options
 | ||||||
|   function markdown(string) { |   function markdown(string) { | ||||||
|     return snarkdown( |     return string | ||||||
|       string |       .split('\n') | ||||||
|         .split('\n') |       .map((line) => | ||||||
|         .map((line) => line.trim()) |         line | ||||||
|         .join('<br>') |           // todo: stop e.g. whole chunk of ~~thin~~g~~ being selected
 | ||||||
|     ).replace(/([^\\])?~~([^\n]*[^\\])~~/g, '$1<s>$2</s>'); |           .trim() | ||||||
|  |           // ~~strikethrough~~
 | ||||||
|  |           .replace(/([^\\])?~~([^\n]*[^\\])~~/g, '$1<s>$2</s>') | ||||||
|  |           // __underline__
 | ||||||
|  |           .replace(/([^\\])?__([^\n]*[^\\])__/g, '$1<u>$2</u>') | ||||||
|  |           // **bold**
 | ||||||
|  |           .replace(/([^\\])?\*\*([^\n]*[^\\])\*\*/g, '$1<b>$2</b>') | ||||||
|  |           // *italic*
 | ||||||
|  |           .replace(/([^\\])?\*([^\n]*[^\\])\*/g, '$1<i>$2</i>') | ||||||
|  |           // _italic_
 | ||||||
|  |           .replace(/([^\\])?_([^\n]*[^\\])_/g, '$1<i>$2</i>') | ||||||
|  |           // `code`
 | ||||||
|  |           .replace(/([^\\])?`([^\n]*[^\\])`/g, '$1<code>$2</code>') | ||||||
|  |           // 
 | ||||||
|  |           .replace( | ||||||
|  |             /([^\\])?\!\[([^\n]*[^\\]?)\]\(([^\n]*[^\\])\)/g, | ||||||
|  |             '$1<img alt="" src="$3">$2</a>' | ||||||
|  |           ) | ||||||
|  |           // [link](destination)
 | ||||||
|  |           .replace( | ||||||
|  |             /([^\\])?\[([^\n]*[^\\])\]\(([^\n]*[^\\])\)/g, | ||||||
|  |             '$1<a href="$3">$2</a>' | ||||||
|  |           ) | ||||||
|  |       ) | ||||||
|  |       .join('<br>'); | ||||||
|   } |   } | ||||||
|   const $modules = document.querySelector('#modules'); |   const $modules = document.querySelector('#modules'); | ||||||
|   for (let mod of modules.loaded.sort((a, b) => |   for (let mod of modules.loaded.sort((a, b) => { | ||||||
|     store('mods', { [mod.id]: { pinned: false } }).pinned |     return a.tags.includes('core') || | ||||||
|  |       store('mods', { [a.id]: { pinned: false } }).pinned | ||||||
|  |       ? -1 | ||||||
|  |       : b.tags.includes('core') || | ||||||
|  |         store('mods', { [b.id]: { pinned: false } }).pinned | ||||||
|       ? 1 |       ? 1 | ||||||
|       : a.name.localeCompare(b.name) |       : a.name.localeCompare(b.name); | ||||||
|   )) { |   })) { | ||||||
|     $modules.append( |     const menuStore = store('mods', { [mod.id]: { enabled: false } }); | ||||||
|       createElement(` |     mod.store = store(mod.id); | ||||||
|  |     mod.elem = createElement(` | ||||||
|       <section class="${ |       <section class="${ | ||||||
|         mod.type === 'core' || |         mod.tags.includes('core') || menuStore[mod.id].enabled | ||||||
|         store('mods', { [mod.id]: { enabled: false } }).enabled |  | ||||||
|           ? 'enabled' |           ? 'enabled' | ||||||
|           : 'disabled' |           : 'disabled' | ||||||
|       }" id="${mod.id}"> |       }" id="${mod.id}"> | ||||||
|         <h3>${mod.name}</h3> |         <h3 ${ | ||||||
|  |           mod.tags.includes('core') | ||||||
|  |             ? `>${mod.name}` | ||||||
|  |             : `class="toggle">
 | ||||||
|  |           <input type="checkbox" id="enable_${mod.id}" ${ | ||||||
|  |                 menuStore[mod.id].enabled ? 'checked' : '' | ||||||
|  |               } /> | ||||||
|  |           <label for="enable_${mod.id}"> | ||||||
|  |             ${mod.name} | ||||||
|  |             <div class="switch"> | ||||||
|  |               <div class="dot"></div> | ||||||
|  |             </div> | ||||||
|  |           </label>` | ||||||
|  |         }</h3> | ||||||
|         <p class="tags">${mod.tags |         <p class="tags">${mod.tags | ||||||
|           .map((tag) => (tag.startsWith('#') ? tag : `#${tag}`)) |           .map((tag) => (tag.startsWith('#') ? tag : `#${tag}`)) | ||||||
|           .join(' ')}</p> |           .join(' ')}</p> | ||||||
| @ -147,7 +185,12 @@ window['__start'] = async () => { | |||||||
|           <span class="version">v${mod.version}</span> |           <span class="version">v${mod.version}</span> | ||||||
|         </p> |         </p> | ||||||
|       </section> |       </section> | ||||||
|     `)
 |     `);
 | ||||||
|     ); |     const $enable = mod.elem.querySelector(`#enable_${mod.id}`); | ||||||
|  |     if ($enable) | ||||||
|  |       $enable.addEventListener('click', (event) => { | ||||||
|  |         menuStore[mod.id].enabled = $enable.checked; | ||||||
|  |       }); | ||||||
|  |     $modules.append(mod.elem); | ||||||
|   } |   } | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -20,12 +20,10 @@ module.exports = { | |||||||
|   id: '0f0bf8b6-eae6-4273-b307-8fc43f2ee082', |   id: '0f0bf8b6-eae6-4273-b307-8fc43f2ee082', | ||||||
|   tags: ['core', 'extension'], |   tags: ['core', 'extension'], | ||||||
|   name: 'notion-enhancer core', |   name: 'notion-enhancer core', | ||||||
|   desc: `the **modloader** itself, _including_: the [CLI](https://github.com), the menu, and ~~enabling/disabling/insertion/updating of~~ mods.
 |   desc: `the **modloader** itself, _including_: the [CLI](https://github.com), the \`menu\`, and ~~enabling/disabling/insertion/updating of~~ mods.
 | ||||||
|     `,
 |     `,
 | ||||||
|   version: require('../../package.json').version, |   version: require('../../package.json').version, | ||||||
|   author: 'dragonwocky', |   author: 'dragonwocky', | ||||||
|   thumb: |  | ||||||
|     'https://camo.githubusercontent.com/5c5bca9e987d986b8cc7e51066f90c6f8a84af08/68747470733a2f2f63646e2e646973636f72646170702e636f6d2f6174746163686d656e74732f3733313634373938343332333931393933332f3733313732373235393239353032333132342f494d475f323137302e6a7067', |  | ||||||
|   options: [], |   options: [], | ||||||
|   hacks: { |   hacks: { | ||||||
|     'main/main.js': require('./tray.js')(defaults), |     'main/main.js': require('./tray.js')(defaults), | ||||||
|  | |||||||
| @ -35,23 +35,23 @@ 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) { | ||||||
|     if ( |     if ( | ||||||
|       __file === 'renderer/preload.js' && |       (mod.tags || []).includes('core') || | ||||||
|       fs.pathExistsSync( |       store('mods', { [mod.id]: { enabled: false } })[mod.id].enabled | ||||||
|         path.resolve(`${__dirname}/../mods/${mod.dir}/styles.css`) |  | ||||||
|       ) |  | ||||||
|     ) { |  | ||||||
|       document.addEventListener('readystatechange', (event) => { |  | ||||||
|         if (document.readyState !== 'complete') return false; |  | ||||||
|         const style = document.createElement('link'); |  | ||||||
|         style.rel = 'stylesheet'; |  | ||||||
|         style.href = `enhancement://${mod.dir}/styles.css`; |  | ||||||
|         document.querySelector('head').appendChild(style); |  | ||||||
|       }); |  | ||||||
|     } |  | ||||||
|     if ( |  | ||||||
|       mod.type === 'core' || |  | ||||||
|       store('mods', { [mod.id]: { enabled: false } })[mod.id] |  | ||||||
|     ) { |     ) { | ||||||
|  |       if ( | ||||||
|  |         __file === 'renderer/preload.js' && | ||||||
|  |         fs.pathExistsSync( | ||||||
|  |           path.resolve(`${__dirname}/../mods/${mod.dir}/styles.css`) | ||||||
|  |         ) | ||||||
|  |       ) { | ||||||
|  |         document.addEventListener('readystatechange', (event) => { | ||||||
|  |           if (document.readyState !== 'complete') return false; | ||||||
|  |           const style = document.createElement('link'); | ||||||
|  |           style.rel = 'stylesheet'; | ||||||
|  |           style.href = `enhancement://${mod.dir}/styles.css`; | ||||||
|  |           document.querySelector('head').appendChild(style); | ||||||
|  |         }); | ||||||
|  |       } | ||||||
|       if (mod.hacks && mod.hacks[__file]) |       if (mod.hacks && mod.hacks[__file]) | ||||||
|         mod.hacks[__file]( |         mod.hacks[__file]( | ||||||
|           (...args) => |           (...args) => | ||||||
|  | |||||||
							
								
								
									
										36
									
								
								pkg/store.js
									
									
									
									
									
								
							
							
						
						
									
										36
									
								
								pkg/store.js
									
									
									
									
									
								
							| @ -15,19 +15,25 @@ module.exports = (namespace, defaults = {}) => { | |||||||
|   namespace = path.resolve(`${data_folder}/${namespace}.json`); |   namespace = path.resolve(`${data_folder}/${namespace}.json`); | ||||||
|   fs.ensureDirSync(data_folder); |   fs.ensureDirSync(data_folder); | ||||||
| 
 | 
 | ||||||
|   const getData = () => ({ ...defaults, ...getJSON(namespace) }); |   let data; | ||||||
|   // fs.writeJsonSync(namespace, getData());
 |   const saveData = () => fs.writeJsonSync(namespace, data), | ||||||
| 
 |     handler = { | ||||||
|   return new Proxy(defaults, { |       get(obj, prop) { | ||||||
|     get(obj, prop) { |         if (prop === 'isProxy') return true; | ||||||
|       obj = getData(); |         if ( | ||||||
|       return obj[prop]; |           typeof obj[prop] === 'object' && | ||||||
|     }, |           obj[prop] !== null && | ||||||
|     set(obj, prop, val) { |           !obj[prop].isProxy | ||||||
|       obj = getData(); |         ) | ||||||
|       obj[prop] = val; |           obj[prop] = new Proxy(obj[prop], handler); | ||||||
|       fs.writeJsonSync(namespace, obj); |         return obj[prop]; | ||||||
|       return true; |       }, | ||||||
|     }, |       set(obj, prop, val) { | ||||||
|   }); |         obj[prop] = val; | ||||||
|  |         saveData(); | ||||||
|  |         return true; | ||||||
|  |       }, | ||||||
|  |     }; | ||||||
|  |   data = new Proxy({ ...defaults, ...getJSON(namespace) }, handler); | ||||||
|  |   return data; | ||||||
| }; | }; | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user