mirror of
				https://github.com/notion-enhancer/notion-enhancer.git
				synced 2025-10-26 11:48:08 +11:00 
			
		
		
		
	
		
			
				
	
	
		
			62 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | |
|  * notion-enhancer
 | |
|  * (c) 2023 dragonwocky <thedragonring.bod@gmail.com> (https://dragonwocky.me/)
 | |
|  * (https://notion-enhancer.github.io/) under the MIT license
 | |
|  */
 | |
| 
 | |
| "use strict";
 | |
| 
 | |
| import { Button } from "./Button.mjs";
 | |
| 
 | |
| function Footer({ categories, transitionDuration = 150 }) {
 | |
|   const { html, setState, useState, reloadApp } = globalThis.__enhancerApi,
 | |
|     $reload = html`<${Button}
 | |
|       class="ml-auto"
 | |
|       variant="primary"
 | |
|       icon="refresh-cw"
 | |
|       onclick=${reloadApp}
 | |
|       style="display: none"
 | |
|     >
 | |
|       Reload & Apply Changes
 | |
|     <//>`,
 | |
|     $categories = categories.map(({ id, title, mods }) => {
 | |
|       return [
 | |
|         mods.map((mod) => mod.id),
 | |
|         html`<${Button}
 | |
|           icon="chevron-left"
 | |
|           onclick=${() => setState({ transition: "slide-to-left", view: id })}
 | |
|         >
 | |
|           ${title}
 | |
|         <//>`,
 | |
|       ];
 | |
|     });
 | |
| 
 | |
|   useState(["view"], ([view]) => {
 | |
|     let [footerOpen] = useState(["databaseUpdated"]);
 | |
|     footerOpen ||= $categories.some(([ids]) => ids.some((id) => id === view));
 | |
|     setState({ footerOpen });
 | |
|     if (!footerOpen) return;
 | |
| 
 | |
|     // only toggle buttons if footer is open,
 | |
|     // otherwise leave as is during transition
 | |
|     for (const [ids, $btn] of $categories) {
 | |
|       const viewInCategory = ids.some((id) => id === view);
 | |
|       $btn.style.display = viewInCategory ? "" : "none";
 | |
|     }
 | |
|   });
 | |
|   useState(["databaseUpdated"], ([databaseUpdated]) => {
 | |
|     $reload.style.display = databaseUpdated ? "" : "none";
 | |
|     if (databaseUpdated) setState({ footerOpen: true });
 | |
|   });
 | |
| 
 | |
|   return html`<footer
 | |
|     class="notion-enhancer--menu-footer px-[60px] py-[16px]
 | |
|     flex w-full bg-[color:var(--theme--bg-primary)] h-[64px]
 | |
|     border-t-(& [color:var(--theme--fg-border)])"
 | |
|   >
 | |
|     ${$categories.map(([, $btn]) => $btn)}${$reload}
 | |
|   </footer>`;
 | |
| }
 | |
| 
 | |
| export { Footer };
 |