mirror of
				https://github.com/notion-enhancer/notion-enhancer.git
				synced 2025-11-04 08:08:08 +11:00 
			
		
		
		
	Merge remote-tracking branch 'ori/master' into master
This commit is contained in:
		
						commit
						2b96b183fb
					
				
							
								
								
									
										12
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								CHANGELOG.md
									
									
									
									
									
								
							@ -6,6 +6,18 @@
 | 
			
		||||
- [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)
 | 
			
		||||
- [advanced math editor](https://github.com/Manueloccorso/NotionMathEditor_BrowserExtension)
 | 
			
		||||
- re-orderable extensions
 | 
			
		||||
 | 
			
		||||
### v0.9.1 (2020-09-26)
 | 
			
		||||
 | 
			
		||||
- bugfix: font chooser will continue iterating through fonts after encountering a blank option.
 | 
			
		||||
- bugfix: block indents are no longer overriden.
 | 
			
		||||
- bugfix: neutral does not force full width pages.
 | 
			
		||||
- bugfix: bypass preview extension works with the back/forward arrows.
 | 
			
		||||
- bugfix: check all views on a page for a weekly calendar.
 | 
			
		||||
- bugfix: emoji sets no longer modifies the user agent = doesn't break hotkeys.
 | 
			
		||||
 | 
			
		||||
> 📥 `npm i -g notion-enhancer@0.9.1`
 | 
			
		||||
 | 
			
		||||
### v0.9.0 (2020-09-20)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -30,6 +30,7 @@ download:
 | 
			
		||||
```sh
 | 
			
		||||
git clone https://github.com/dragonwocky/notion-enhancer
 | 
			
		||||
cd notion-enhancer
 | 
			
		||||
git checkout dev
 | 
			
		||||
npm link
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
@ -52,6 +53,12 @@ to keep a consistent informative code style it is preferred to name variables wi
 | 
			
		||||
`snake_case`, functions/methods with `camelCase`, and classes with `PascalCase`.
 | 
			
		||||
if a variable is a reference to a DOM element, it may be helpful to prefix it with a `$`.
 | 
			
		||||
 | 
			
		||||
some variables beginning with a double underscore are `__folder` paths and `ALL_CAPS` variables
 | 
			
		||||
are constant. this is not required, but these styles should not be used for any other purpose.
 | 
			
		||||
 | 
			
		||||
the master branch is kept consistent with the current release,
 | 
			
		||||
so all changes should be made to the dev branch.
 | 
			
		||||
 | 
			
		||||
## review
 | 
			
		||||
 | 
			
		||||
active core devs will manually look through each pull request and communicate with contributors before merging to
 | 
			
		||||
 | 
			
		||||
@ -19,23 +19,48 @@ module.exports = {
 | 
			
		||||
        if (document.readyState !== 'complete') return false;
 | 
			
		||||
        const attempt_interval = setInterval(enhance, 500);
 | 
			
		||||
        function enhance() {
 | 
			
		||||
          const notion_elem = document.querySelector(
 | 
			
		||||
            '.notion-default-overlay-container'
 | 
			
		||||
          );
 | 
			
		||||
          const notion_elem = document.querySelector('.notion-app-inner');
 | 
			
		||||
          if (!notion_elem) return;
 | 
			
		||||
          clearInterval(attempt_interval);
 | 
			
		||||
 | 
			
		||||
          process();
 | 
			
		||||
          const observer = new MutationObserver(process);
 | 
			
		||||
          const observer = new MutationObserver(handle);
 | 
			
		||||
          observer.observe(notion_elem, {
 | 
			
		||||
            childList: true,
 | 
			
		||||
            subtree: true,
 | 
			
		||||
          });
 | 
			
		||||
          function process(list, observer) {
 | 
			
		||||
            let preview = document.querySelector(
 | 
			
		||||
              '.notion-peek-renderer [style*="height: 45px;"] a'
 | 
			
		||||
            );
 | 
			
		||||
            if (preview) preview.click();
 | 
			
		||||
 | 
			
		||||
          let pageHistory = [];
 | 
			
		||||
          handle();
 | 
			
		||||
          function handle(list, observer) {
 | 
			
		||||
            const pageID = (location.search
 | 
			
		||||
                .slice(1)
 | 
			
		||||
                .split('&')
 | 
			
		||||
                .map((opt) => opt.split('='))
 | 
			
		||||
                .find((opt) => opt[0] === 'p') || [
 | 
			
		||||
                '',
 | 
			
		||||
                ...location.pathname.split(/(-|\/)/g).reverse(),
 | 
			
		||||
              ])[1],
 | 
			
		||||
              preview = document.querySelector(
 | 
			
		||||
                '.notion-peek-renderer [style*="height: 45px;"] a'
 | 
			
		||||
              );
 | 
			
		||||
            if (
 | 
			
		||||
              pageID &&
 | 
			
		||||
              (!pageHistory[0] ||
 | 
			
		||||
                pageHistory[0][0] !== pageID ||
 | 
			
		||||
                pageHistory[0][1] !== !!preview)
 | 
			
		||||
            ) {
 | 
			
		||||
              if (preview) {
 | 
			
		||||
                if (
 | 
			
		||||
                  pageHistory[1] &&
 | 
			
		||||
                  pageHistory[0][0] === pageID &&
 | 
			
		||||
                  pageHistory[1][0] === pageID &&
 | 
			
		||||
                  pageHistory[1][1]
 | 
			
		||||
                ) {
 | 
			
		||||
                  document.querySelector('.notion-history-back-button').click();
 | 
			
		||||
                } else preview.click();
 | 
			
		||||
              }
 | 
			
		||||
              // most recent is at start for easier access
 | 
			
		||||
              pageHistory.unshift([pageID, !!preview]);
 | 
			
		||||
            }
 | 
			
		||||
          }
 | 
			
		||||
        }
 | 
			
		||||
      });
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										9
									
								
								mods/bypass-preview/styles.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								mods/bypass-preview/styles.css
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,9 @@
 | 
			
		||||
/*
 | 
			
		||||
 * bypass preview
 | 
			
		||||
 * (c) 2020 dragonwocky <thedragonring.bod@gmail.com> (https://dragonwocky.me/)
 | 
			
		||||
 * under the MIT license
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
.notion-peek-renderer {
 | 
			
		||||
  opacity: 0;
 | 
			
		||||
}
 | 
			
		||||
@ -55,13 +55,13 @@ module.exports = {
 | 
			
		||||
            );
 | 
			
		||||
          });
 | 
			
		||||
 | 
			
		||||
          process();
 | 
			
		||||
          const observer = new MutationObserver(process);
 | 
			
		||||
          handle();
 | 
			
		||||
          const observer = new MutationObserver(handle);
 | 
			
		||||
          observer.observe(notion_elem, {
 | 
			
		||||
            childList: true,
 | 
			
		||||
            subtree: true,
 | 
			
		||||
          });
 | 
			
		||||
          function process(list, observer) {
 | 
			
		||||
          function handle(list, observer) {
 | 
			
		||||
            if (document.querySelector('#calendar-scroll-to-week')) return;
 | 
			
		||||
            const arrow = document.querySelector(
 | 
			
		||||
              '.notion-selectable.notion-collection_view_page-block .chevronLeft'
 | 
			
		||||
 | 
			
		||||
@ -52,7 +52,6 @@
 | 
			
		||||
  [style*='pointer-events:'][style*='max-width: 100%; width: 100%'] {
 | 
			
		||||
  width: var(--theme--page_full-width) !important;
 | 
			
		||||
}
 | 
			
		||||
.notion-text-block [style*='padding-left: 1.5em'],
 | 
			
		||||
.notion-frame .notion-scroller [style*='padding-left: 136.5px;'] {
 | 
			
		||||
  padding-left: 0 !important;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@ -11,7 +11,7 @@ module.exports = {
 | 
			
		||||
  tags: ['extension'],
 | 
			
		||||
  name: 'emoji sets',
 | 
			
		||||
  desc: 'pick from a variety of emoji styles to use.',
 | 
			
		||||
  version: '0.2.0',
 | 
			
		||||
  version: '0.3.0',
 | 
			
		||||
  author: 'dragonwocky',
 | 
			
		||||
  options: [
 | 
			
		||||
    {
 | 
			
		||||
@ -38,58 +38,109 @@ module.exports = {
 | 
			
		||||
  ],
 | 
			
		||||
  hacks: {
 | 
			
		||||
    'renderer/preload.js'(store, __exports) {
 | 
			
		||||
      const useNative =
 | 
			
		||||
        (store().style === 'microsoft' && process.platform === 'win32') ||
 | 
			
		||||
        (store().style === 'apple' && process.platform === 'darwin');
 | 
			
		||||
      let tweaked = false;
 | 
			
		||||
 | 
			
		||||
      Object.defineProperty(navigator, 'userAgent', {
 | 
			
		||||
        get: function () {
 | 
			
		||||
          // macOS useragent uses system emojis instead of images
 | 
			
		||||
          // = no need to download
 | 
			
		||||
          return useNative
 | 
			
		||||
            ? 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_14_6) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/13.0.3 Safari/605.1.15 Notion/2.0.9 Electron/6.1.5'
 | 
			
		||||
            : 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Notion/2.0.9 Chrome/76.0.3809.146 Electron/6.1.5 Safari/537.36';
 | 
			
		||||
        },
 | 
			
		||||
      });
 | 
			
		||||
 | 
			
		||||
      if (!useNative) {
 | 
			
		||||
        let tweaked = false;
 | 
			
		||||
 | 
			
		||||
        document.addEventListener('readystatechange', (event) => {
 | 
			
		||||
          if (document.readyState !== 'complete') return false;
 | 
			
		||||
          let queue = [];
 | 
			
		||||
          const observer = new MutationObserver((list, observer) => {
 | 
			
		||||
            if (!queue.length) requestAnimationFrame(process);
 | 
			
		||||
            queue.push(...list);
 | 
			
		||||
          });
 | 
			
		||||
          observer.observe(document.body, {
 | 
			
		||||
            childList: true,
 | 
			
		||||
            subtree: true,
 | 
			
		||||
            characterData: true,
 | 
			
		||||
          });
 | 
			
		||||
          function process() {
 | 
			
		||||
            queue = [];
 | 
			
		||||
            if (store().style !== 'twitter' || tweaked) {
 | 
			
		||||
      document.addEventListener('readystatechange', (event) => {
 | 
			
		||||
        if (document.readyState !== 'complete') return false;
 | 
			
		||||
        let queue = [];
 | 
			
		||||
        const observer = new MutationObserver((list, observer) => {
 | 
			
		||||
          if (!queue.length) requestAnimationFrame(handle);
 | 
			
		||||
          queue.push(...list);
 | 
			
		||||
        });
 | 
			
		||||
        observer.observe(document.body, {
 | 
			
		||||
          childList: true,
 | 
			
		||||
          subtree: true,
 | 
			
		||||
          characterData: true,
 | 
			
		||||
        });
 | 
			
		||||
        function handle() {
 | 
			
		||||
          queue = [];
 | 
			
		||||
          const isMac = process.platform === 'darwin',
 | 
			
		||||
            native =
 | 
			
		||||
              (store().style === 'microsoft' && process.platform === 'win32') ||
 | 
			
		||||
              (store().style === 'apple' && isMac);
 | 
			
		||||
          if (store().style !== (isMac ? 'apple' : 'twitter') || tweaked) {
 | 
			
		||||
            if (isMac) {
 | 
			
		||||
              if (native) {
 | 
			
		||||
                document
 | 
			
		||||
                  .querySelectorAll('span[role="image"][aria-label]')
 | 
			
		||||
                  .forEach((el) => {
 | 
			
		||||
                    el.style.background = '';
 | 
			
		||||
                    el.style.color = 'currentColor';
 | 
			
		||||
                  });
 | 
			
		||||
              } else {
 | 
			
		||||
                document
 | 
			
		||||
                  .querySelectorAll('span[role="image"][aria-label]')
 | 
			
		||||
                  .forEach((el) => {
 | 
			
		||||
                    if (!el.style.background.includes(store().style)) {
 | 
			
		||||
                      el.style.background = `url(https://emojicdn.elk.sh/${el.getAttribute(
 | 
			
		||||
                        'aria-label'
 | 
			
		||||
                      )}?style=${store().style})`;
 | 
			
		||||
                      el.style.width = el.parentElement.style.fontSize;
 | 
			
		||||
                      el.style.backgroundSize = 'contain';
 | 
			
		||||
                      el.style.backgroundRepeat = 'no-repeat';
 | 
			
		||||
                      el.style.color = 'transparent';
 | 
			
		||||
                    }
 | 
			
		||||
                  });
 | 
			
		||||
              }
 | 
			
		||||
            } else {
 | 
			
		||||
              document
 | 
			
		||||
                .querySelectorAll(
 | 
			
		||||
                  '[src*="notion-emojis.s3"]:not(.notion-emoji)'
 | 
			
		||||
                )
 | 
			
		||||
                .forEach((el) => el.remove());
 | 
			
		||||
              document.querySelectorAll('.notion-emoji').forEach((el) => {
 | 
			
		||||
                el.style.setProperty(
 | 
			
		||||
                  'background',
 | 
			
		||||
                  `url(https://emojicdn.elk.sh/${el.getAttribute(
 | 
			
		||||
                    'alt'
 | 
			
		||||
                  )}?style=${store().style})`
 | 
			
		||||
                );
 | 
			
		||||
                el.style.setProperty('background-size', 'contain');
 | 
			
		||||
                el.style.setProperty('opacity', '1');
 | 
			
		||||
              });
 | 
			
		||||
              tweaked = true;
 | 
			
		||||
              if (native) {
 | 
			
		||||
                document.querySelectorAll('.notion-emoji').forEach((el) => {
 | 
			
		||||
                  if (
 | 
			
		||||
                    el.parentElement.querySelectorAll(
 | 
			
		||||
                      'span[role="image"][aria-label]'
 | 
			
		||||
                    ).length !==
 | 
			
		||||
                    el.parentElement.querySelectorAll('.notion-emoji').length
 | 
			
		||||
                  ) {
 | 
			
		||||
                    el.insertAdjacentHTML(
 | 
			
		||||
                      'beforebegin',
 | 
			
		||||
                      `<span
 | 
			
		||||
                        role="image"
 | 
			
		||||
                        aria-label="${el.getAttribute('alt')}"
 | 
			
		||||
                        style='font-family: "Apple Color Emoji", "Segoe UI Emoji",
 | 
			
		||||
                        NotoColorEmoji, "Noto Color Emoji", "Segoe UI Symbol",
 | 
			
		||||
                        "Android Emoji", EmojiSymbols; line-height: 1em;'
 | 
			
		||||
                      >${el.getAttribute('alt')}</span>`
 | 
			
		||||
                    );
 | 
			
		||||
                    el.style.display = 'none';
 | 
			
		||||
                    if (el.parentElement.getAttribute('contenteditable'))
 | 
			
		||||
                      el.remove();
 | 
			
		||||
                  }
 | 
			
		||||
                });
 | 
			
		||||
              } else {
 | 
			
		||||
                document.querySelectorAll('.notion-emoji').forEach((el) => {
 | 
			
		||||
                  el.parentElement
 | 
			
		||||
                    .querySelectorAll('span[role="image"][aria-label]')
 | 
			
		||||
                    .forEach((text) => text.remove());
 | 
			
		||||
                  if (!el.style.background.includes(store().style)) {
 | 
			
		||||
                    el.style.background = `url(https://emojicdn.elk.sh/${el.getAttribute(
 | 
			
		||||
                      'aria-label'
 | 
			
		||||
                    )}?style=${store().style})`;
 | 
			
		||||
                    el.style.display = 'inline-block';
 | 
			
		||||
                    el.style.backgroundSize = 'contain';
 | 
			
		||||
                    el.style.backgroundRepeat = 'no-repeat';
 | 
			
		||||
                    el.style.opacity = 1;
 | 
			
		||||
                  }
 | 
			
		||||
                });
 | 
			
		||||
              }
 | 
			
		||||
            }
 | 
			
		||||
            tweaked = true;
 | 
			
		||||
          }
 | 
			
		||||
        });
 | 
			
		||||
      }
 | 
			
		||||
        }
 | 
			
		||||
      });
 | 
			
		||||
    },
 | 
			
		||||
  },
 | 
			
		||||
};
 | 
			
		||||
// span[role="image"][aria-label]
 | 
			
		||||
/*  */
 | 
			
		||||
 | 
			
		||||
// <div style="position: relative; width: 36px; height: 36px;">
 | 
			
		||||
//   <img class="notion-emoji" alt="😀" aria-label="😀" src="" 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="" style="width: 100%; height: 100%; background: url("/images/twitter-emoji-spritesheet-64.png") 98.2143% 25% / 5700% 5700%;">
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										5
									
								
								mods/emoji-sets/styles.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								mods/emoji-sets/styles.css
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,5 @@
 | 
			
		||||
.notion-emoji::after {
 | 
			
		||||
  content: attr(aria-label, '');
 | 
			
		||||
  width: 1em;
 | 
			
		||||
  height: 1em;
 | 
			
		||||
}
 | 
			
		||||
@ -12,7 +12,6 @@
 | 
			
		||||
  --theme_dark--sidebar: #171717;
 | 
			
		||||
  --theme_dark--overlay: rgba(15, 15, 15, 0.6);
 | 
			
		||||
  --theme_dark--dragarea: #111111;
 | 
			
		||||
  --theme_dark--page_normal-width: 100%;
 | 
			
		||||
 | 
			
		||||
  --theme_dark--font_sans: 'Inter', -apple-system, BlinkMacSystemFont,
 | 
			
		||||
    'Segoe UI', Helvetica, 'Apple Color Emoji', Arial, sans-serif,
 | 
			
		||||
 | 
			
		||||
@ -30,23 +30,24 @@ module.exports = {
 | 
			
		||||
            subtree: true,
 | 
			
		||||
          });
 | 
			
		||||
          function process(list, observer) {
 | 
			
		||||
            const collection_view = document.querySelector(
 | 
			
		||||
              '.notion-collection-view-select'
 | 
			
		||||
            );
 | 
			
		||||
            if (!collection_view || collection_view.innerText != 'weekly')
 | 
			
		||||
              return;
 | 
			
		||||
            const days = collection_view.parentElement.parentElement.parentElement.parentElement.getElementsByClassName(
 | 
			
		||||
                'notion-calendar-view-day'
 | 
			
		||||
              ),
 | 
			
		||||
              today = [...days].find((day) => day.style.background),
 | 
			
		||||
              height = today
 | 
			
		||||
                ? getComputedStyle(
 | 
			
		||||
                    today.parentElement.parentElement
 | 
			
		||||
                  ).getPropertyValue('height')
 | 
			
		||||
                : 0;
 | 
			
		||||
            for (let day of days)
 | 
			
		||||
              day.parentElement.parentElement.style.height = 0;
 | 
			
		||||
            if (today) today.parentElement.parentElement.style.height = height;
 | 
			
		||||
            document
 | 
			
		||||
              .querySelectorAll('.notion-collection-view-select')
 | 
			
		||||
              .forEach((collection_view) => {
 | 
			
		||||
                if (collection_view.innerText != 'weekly') return;
 | 
			
		||||
                const days = collection_view.parentElement.parentElement.parentElement.parentElement.getElementsByClassName(
 | 
			
		||||
                    'notion-calendar-view-day'
 | 
			
		||||
                  ),
 | 
			
		||||
                  today = [...days].find((day) => day.style.background),
 | 
			
		||||
                  height = today
 | 
			
		||||
                    ? getComputedStyle(
 | 
			
		||||
                        today.parentElement.parentElement
 | 
			
		||||
                      ).getPropertyValue('height')
 | 
			
		||||
                    : 0;
 | 
			
		||||
                for (let day of days)
 | 
			
		||||
                  day.parentElement.parentElement.style.height = 0;
 | 
			
		||||
                if (today)
 | 
			
		||||
                  today.parentElement.parentElement.style.height = height;
 | 
			
		||||
              });
 | 
			
		||||
          }
 | 
			
		||||
        }
 | 
			
		||||
      });
 | 
			
		||||
 | 
			
		||||
@ -119,6 +119,7 @@ module.exports = {
 | 
			
		||||
              ''
 | 
			
		||||
            )}`;
 | 
			
		||||
          $page.previousElementSibling.children[0].appendChild($container);
 | 
			
		||||
          if (!$container.offsetParent) return;
 | 
			
		||||
          $container.offsetParent.appendChild($tooltip);
 | 
			
		||||
          $container
 | 
			
		||||
            .querySelectorAll('p')
 | 
			
		||||
@ -130,7 +131,6 @@ module.exports = {
 | 
			
		||||
          $container.querySelectorAll('[data-tooltip]').forEach((el) => {
 | 
			
		||||
            el.addEventListener('mouseenter', (e) => {
 | 
			
		||||
              $tooltip.innerText = el.getAttribute('data-tooltip');
 | 
			
		||||
              console.log(e.target);
 | 
			
		||||
              $tooltip.style.top = el.parentElement.offsetTop + 2.5 + 'px';
 | 
			
		||||
              $tooltip.style.left =
 | 
			
		||||
                el.parentElement.offsetLeft +
 | 
			
		||||
 | 
			
		||||
@ -1,6 +1,6 @@
 | 
			
		||||
{
 | 
			
		||||
  "name": "notion-enhancer",
 | 
			
		||||
  "version": "0.9.0",
 | 
			
		||||
  "version": "0.9.1",
 | 
			
		||||
  "description": "an enhancer/customiser for the all-in-one productivity workspace notion.so",
 | 
			
		||||
  "main": "index.js",
 | 
			
		||||
  "bin": {
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user