sprucing the app up a little
This commit is contained in:
		
							parent
							
								
									57ab2d9324
								
							
						
					
					
						commit
						13e5727497
					
				
					 20 changed files with 537 additions and 111 deletions
				
			
		|  | @ -1,4 +1,5 @@ | ||||||
| import { defineConfig } from '@solidjs/start/config'; | import { defineConfig } from '@solidjs/start/config'; | ||||||
|  | import solidSvg from 'vite-plugin-solid-svg' | ||||||
| // import { VitePWA } from 'vite-plugin-pwa'
 | // import { VitePWA } from 'vite-plugin-pwa'
 | ||||||
| 
 | 
 | ||||||
| export default defineConfig({ | export default defineConfig({ | ||||||
|  | @ -7,6 +8,7 @@ export default defineConfig({ | ||||||
|             cspNonce: 'KAAS_IS_AWESOME', |             cspNonce: 'KAAS_IS_AWESOME', | ||||||
|         }, |         }, | ||||||
|         plugins: [ |         plugins: [ | ||||||
|  |             solidSvg() | ||||||
|             // VitePWA({
 |             // VitePWA({
 | ||||||
|             //     strategies: 'injectManifest',
 |             //     strategies: 'injectManifest',
 | ||||||
|             //     registerType: 'autoUpdate',
 |             //     registerType: 'autoUpdate',
 | ||||||
|  |  | ||||||
							
								
								
									
										
											BIN
										
									
								
								bun.lockb
									
										
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								bun.lockb
									
										
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							|  | @ -32,6 +32,7 @@ | ||||||
|     "bun-types": "^1.1.34", |     "bun-types": "^1.1.34", | ||||||
|     "jsdom": "^25.0.1", |     "jsdom": "^25.0.1", | ||||||
|     "vite-plugin-pwa": "^0.21.0", |     "vite-plugin-pwa": "^0.21.0", | ||||||
|  |     "vite-plugin-solid-svg": "^0.8.1", | ||||||
|     "workbox-window": "^7.3.0" |     "workbox-window": "^7.3.0" | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | @ -1,7 +0,0 @@ | ||||||
| <?xml version="1.0" encoding="UTF-8"?> |  | ||||||
| <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="512px" height="512px" viewBox="0 0 512 512" version="1.1"> |  | ||||||
| <g id="surface1"> |  | ||||||
| <path style=" stroke:none;fill-rule:nonzero;fill:rgb(93.333334%,93.333334%,93.333334%);fill-opacity:1;" d="M 145.441406 214.847656 L 131.519531 256 L 96 256 L 155.585938 96 L 196.671875 96 L 256 256 L 218.65625 256 L 204.734375 214.847656 Z M 197.726562 191.296875 L 176 126.59375 L 174.433594 126.59375 L 152.703125 191.296875 L 197.761719 191.296875 Z M 197.726562 191.296875 "/> |  | ||||||
| <path style=" stroke:none;fill-rule:nonzero;fill:rgb(93.333334%,93.333334%,93.333334%);fill-opacity:1;" d="M 0 64 C 0 28.652344 28.652344 0 64 0 L 288 0 C 323.347656 0 352 28.652344 352 64 L 352 160 L 448 160 C 483.347656 160 512 188.652344 512 224 L 512 448 C 512 483.347656 483.347656 512 448 512 L 224 512 C 188.652344 512 160 483.347656 160 448 L 160 352 L 64 352 C 28.652344 352 0 323.347656 0 288 Z M 64 32 C 46.328125 32 32 46.328125 32 64 L 32 288 C 32 305.671875 46.328125 320 64 320 L 288 320 C 305.671875 320 320 305.671875 320 288 L 320 64 C 320 46.328125 305.671875 32 288 32 Z M 292.414062 351.839844 C 298.59375 361.472656 305.28125 370.496094 312.574219 378.910156 C 288.640625 397.3125 259.039062 410.945312 224 420.257812 C 229.695312 427.199219 238.433594 440.574219 241.761719 448 C 277.761719 436.511719 308.320312 420.992188 334.113281 400.191406 C 358.976562 421.472656 389.761719 437.472656 427.871094 447.296875 C 432.128906 439.167969 441.121094 425.761719 448 418.816406 C 412 410.71875 382.175781 396.609375 357.761719 377.726562 C 379.550781 353.824219 396.863281 324.894531 409.632812 289.503906 L 448 289.503906 L 448 256 L 352 256 L 352 289.503906 L 376.480469 289.503906 C 366.304688 316.511719 352.800781 338.976562 335.777344 357.664062 C 331.074219 352.65625 326.640625 347.398438 322.496094 341.921875 C 313.464844 347.710938 303.117188 351.121094 292.414062 351.839844 Z M 292.414062 351.839844 "/> |  | ||||||
| </g> |  | ||||||
| </svg> |  | ||||||
| Before Width: | Height: | Size: 2 KiB | 
|  | @ -1,7 +0,0 @@ | ||||||
| <?xml version="1.0" encoding="UTF-8"?> |  | ||||||
| <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="512px" height="512px" viewBox="0 0 512 512" version="1.1"> |  | ||||||
| <g id="surface1"> |  | ||||||
| <path style=" stroke:none;fill-rule:nonzero;fill:rgb(13.333334%,13.333334%,13.333334%);fill-opacity:1;" d="M 145.441406 214.847656 L 131.519531 256 L 96 256 L 155.585938 96 L 196.671875 96 L 256 256 L 218.65625 256 L 204.734375 214.847656 Z M 197.726562 191.296875 L 176 126.59375 L 174.433594 126.59375 L 152.703125 191.296875 L 197.761719 191.296875 Z M 197.726562 191.296875 "/> |  | ||||||
| <path style=" stroke:none;fill-rule:nonzero;fill:rgb(13.333334%,13.333334%,13.333334%);fill-opacity:1;" d="M 0 64 C 0 28.652344 28.652344 0 64 0 L 288 0 C 323.347656 0 352 28.652344 352 64 L 352 160 L 448 160 C 483.347656 160 512 188.652344 512 224 L 512 448 C 512 483.347656 483.347656 512 448 512 L 224 512 C 188.652344 512 160 483.347656 160 448 L 160 352 L 64 352 C 28.652344 352 0 323.347656 0 288 Z M 64 32 C 46.328125 32 32 46.328125 32 64 L 32 288 C 32 305.671875 46.328125 320 64 320 L 288 320 C 305.671875 320 320 305.671875 320 288 L 320 64 C 320 46.328125 305.671875 32 288 32 Z M 292.414062 351.839844 C 298.59375 361.472656 305.28125 370.496094 312.574219 378.910156 C 288.640625 397.3125 259.039062 410.945312 224 420.257812 C 229.695312 427.199219 238.433594 440.574219 241.761719 448 C 277.761719 436.511719 308.320312 420.992188 334.113281 400.191406 C 358.976562 421.472656 389.761719 437.472656 427.871094 447.296875 C 432.128906 439.167969 441.121094 425.761719 448 418.816406 C 412 410.71875 382.175781 396.609375 357.761719 377.726562 C 379.550781 353.824219 396.863281 324.894531 409.632812 289.503906 L 448 289.503906 L 448 256 L 352 256 L 352 289.503906 L 376.480469 289.503906 C 366.304688 316.511719 352.800781 338.976562 335.777344 357.664062 C 331.074219 352.65625 326.640625 347.398438 322.496094 341.921875 C 313.464844 347.710938 303.117188 351.121094 292.414062 351.839844 Z M 292.414062 351.839844 "/> |  | ||||||
| </g> |  | ||||||
| </svg> |  | ||||||
| Before Width: | Height: | Size: 2 KiB | 
							
								
								
									
										41
									
								
								src/app.css
									
										
									
									
									
								
							
							
						
						
									
										41
									
								
								src/app.css
									
										
									
									
									
								
							|  | @ -1,16 +1,28 @@ | ||||||
| @import url("https://fonts.googleapis.com/css2?family=Roboto+Flex:opsz,wght,GRAD@8..144,400,45;8..144,400,50;8..144,1000,0&family=Roboto+Serif:opsz,GRAD@8..144,71&display=swap"); | @import url("https://fonts.googleapis.com/css2?family=Roboto+Flex:opsz,wght,GRAD@8..144,400,45;8..144,400,50;8..144,1000,0&family=Roboto+Serif:opsz,GRAD@8..144,71&display=swap"); | ||||||
| 
 | 
 | ||||||
| :root { | :root { | ||||||
|   --surface-1: light-dark(#ddd, #222); |   --hue: 182.77deg; | ||||||
|   --surface-2: light-dark(#e8e8e8, #282828); |  | ||||||
|   --surface-3: light-dark(#eee, #333); |  | ||||||
|   --surface-4: light-dark(#f8f8f8, #383838); |  | ||||||
|   --surface-5: light-dark(#fff, #444); |  | ||||||
|   --text-1: light-dark(#222, #eee); |  | ||||||
|   --text-2: light-dark(#282828, #d8d8d8); |  | ||||||
| 
 | 
 | ||||||
|   --primary: light-dark(oklch(.7503 0.117 181.6deg), oklch(.8549 0.1149 182.77deg)); |   --primary-100: oklch(from var(--primary-500) .95 c h); | ||||||
|   --secondary: oklch(from var(--primary) l c calc(h - 180)); |   --primary-300: oklch(from var(--primary-500) .9 c h); | ||||||
|  |   --primary-500: light-dark(oklch(.7503 0.117 var(--hue)), oklch(.8549 0.1149 var(--hue))); | ||||||
|  |   --primary-700: oklch(from var(--primary-500) .7 c h); | ||||||
|  |   --primary-900: oklch(from var(--primary-500) .6 c h); | ||||||
|  | 
 | ||||||
|  |   --secondary-100: oklch(from var(--secondary-500) .95 c h); | ||||||
|  |   --secondary-300: oklch(from var(--secondary-500) .9 c h); | ||||||
|  |   --secondary-500: oklch(from var(--primary-500) l c calc(h - 180)); | ||||||
|  |   --secondary-700: oklch(from var(--secondary-500) .7 c h); | ||||||
|  |   --secondary-900: oklch(from var(--secondary-500) .6 c h); | ||||||
|  | 
 | ||||||
|  |   --surface-1: light-dark(oklch(from var(--secondary-500) .9 .02 h), oklch(from var(--secondary-500) .2 .02 h)); | ||||||
|  |   --surface-2: oklch(from var(--surface-1) calc(l + .025) c h); | ||||||
|  |   --surface-3: oklch(from var(--surface-2) calc(l + .025) c h); | ||||||
|  |   --surface-4: oklch(from var(--surface-3) calc(l + .025) c h); | ||||||
|  |   --surface-5: oklch(from var(--surface-4) calc(l + .025) c h); | ||||||
|  | 
 | ||||||
|  |   --text-1: light-dark(oklch(from var(--secondary-500) .2 .02 h), oklch(from var(--secondary-500) .9 .02 h)); | ||||||
|  |   --text-2: oklch(from var(--text-1) calc(l + .1) c h); | ||||||
| 
 | 
 | ||||||
|   --info: light-dark(oklch(.71 .17 249), oklch(.71 .17 249)); |   --info: light-dark(oklch(.71 .17 249), oklch(.71 .17 249)); | ||||||
|   --fail: light-dark(oklch(.64 .21 25.3), oklch(.64 .21 25.3)); |   --fail: light-dark(oklch(.64 .21 25.3), oklch(.64 .21 25.3)); | ||||||
|  | @ -30,6 +42,7 @@ | ||||||
|   --padding-s: .25em; |   --padding-s: .25em; | ||||||
|   --padding-m: .5em; |   --padding-m: .5em; | ||||||
|   --padding-l: 1em; |   --padding-l: 1em; | ||||||
|  |   --padding-xl: 1.5em; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| html { | html { | ||||||
|  | @ -49,7 +62,7 @@ body { | ||||||
| 
 | 
 | ||||||
|   background-color: var(--surface-1); |   background-color: var(--surface-1); | ||||||
|   color: var(--text-2); |   color: var(--text-2); | ||||||
|   accent-color: var(--primary); |   accent-color: var(--primary-500); | ||||||
| 
 | 
 | ||||||
|   margin: 0; |   margin: 0; | ||||||
| 
 | 
 | ||||||
|  | @ -65,7 +78,7 @@ body { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| a { | a { | ||||||
|   color: var(--primary); |   color: var(--primary-500); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| h1 { | h1 { | ||||||
|  | @ -87,3 +100,9 @@ code { | ||||||
|   border: 1px solid var(--surface-5); |   border: 1px solid var(--surface-5); | ||||||
|   border-radius: var(--radii-m); |   border-radius: var(--radii-m); | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | @property --hue { | ||||||
|  |   syntax: '<angle>'; | ||||||
|  |   inherits: false; | ||||||
|  |   initial-value: 0deg; | ||||||
|  | } | ||||||
|  | @ -3,13 +3,16 @@ import { Router } from "@solidjs/router"; | ||||||
| import { FileRoutes } from "@solidjs/start/router"; | import { FileRoutes } from "@solidjs/start/router"; | ||||||
| import { Suspense } from "solid-js"; | import { Suspense } from "solid-js"; | ||||||
| import "./app.css"; | import "./app.css"; | ||||||
|  | import { ThemeProvider } from "./components/colorschemepicker"; | ||||||
| 
 | 
 | ||||||
| export default function App() { | export default function App() { | ||||||
|   return ( |   return ( | ||||||
|     <Router |     <Router | ||||||
|       root={props => ( |       root={props => ( | ||||||
|         <MetaProvider> |         <MetaProvider> | ||||||
|           <Suspense>{props.children}</Suspense> |           <ThemeProvider> | ||||||
|  |             <Suspense>{props.children}</Suspense> | ||||||
|  |           </ThemeProvider> | ||||||
|         </MetaProvider> |         </MetaProvider> | ||||||
|       )} |       )} | ||||||
|     > |     > | ||||||
|  |  | ||||||
							
								
								
									
										104
									
								
								src/assets/edit-blank.svg
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										104
									
								
								src/assets/edit-blank.svg
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,104 @@ | ||||||
|  | <svg xmlns="http://www.w3.org/2000/svg" data-name="Layer 1" width="20em" height="12.3109243697em" | ||||||
|  |     viewBox="0 0 952 586" xmlns:xlink="http://www.w3.org/1999/xlink"> | ||||||
|  |     <path id="a163713d-a7fc-4807-a77b-111ad75719e9-799" data-name="Path 133" | ||||||
|  |         d="M170.63353,697.233a158.3937,158.3937,0,0,0,7.4,43.785c.1.329.211.653.319.982h27.613c-.029-.295-.059-.624-.088-.982-1.841-21.166,8.677-148.453,21.369-170.483C226.13454,572.322,168.49254,629.979,170.63353,697.233Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--surface-4)" /> | ||||||
|  |     <path id="a1d5a274-7181-45f3-aae5-db776f20014a-800" data-name="Path 134" | ||||||
|  |         d="M172.70558,741.018c.231.329.471.658.717.982h20.716c-.157-.28-.339-.609-.55-.982-3.422-6.176-13.551-24.642-22.953-43.785-10.1-20.572-19.374-41.924-18.593-49.652C151.80058,649.323,144.80861,702.457,172.70558,741.018Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--surface-4)" /> | ||||||
|  |     <path | ||||||
|  |         d="M775.29126,277.577a14.42246,14.42246,0,0,0,21.04127,6.80778l39.97977,32.06957,2.47488-26.51836-38.34489-26.38825a14.50066,14.50066,0,0,0-25.151,14.02926Z" | ||||||
|  |         transform="translate(-124 -157)" fill="#9f616a" /> | ||||||
|  |     <polygon | ||||||
|  |         points="713.205 130.446 698.283 119.903 681.358 139.458 701.046 151.126 713.205 130.446" | ||||||
|  |         fill="var(--primary-500)" /> | ||||||
|  |     <path | ||||||
|  |         d="M833.93681,280.29582l50.28691,19.349L932.63291,267.947a24.62075,24.62075,0,0,1,31.79547,37.06016l-.433.48083-74.454,39.9183-81.32649-37.15291Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--text-2)" /> | ||||||
|  |     <polygon points="695.76 583 171.76 583 190.76 212 272.76 212 348.374 265 714.76 265 695.76 583" | ||||||
|  |         fill="var(--surface-4)" /> | ||||||
|  |     <path | ||||||
|  |         d="M691.4891,626.86286,388.6242,502.13469a4.32609,4.32609,0,0,1-2.35009-5.64107L523.508,163.26232a4.3261,4.3261,0,0,1,5.64107-2.35009L832.014,285.6404a4.32609,4.32609,0,0,1,2.35009,5.64107L697.13017,624.51277A4.32609,4.32609,0,0,1,691.4891,626.86286Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--surface-5)" /> | ||||||
|  |     <path | ||||||
|  |         d="M691.4891,626.86286,388.6242,502.13469a4.32609,4.32609,0,0,1-2.35009-5.64107L523.508,163.26232a4.3261,4.3261,0,0,1,5.64107-2.35009L832.014,285.6404a4.32609,4.32609,0,0,1,2.35009,5.64107L697.13017,624.51277A4.32609,4.32609,0,0,1,691.4891,626.86286ZM528.49088,162.51046a2.59553,2.59553,0,0,0-3.38465,1.41006L387.87234,497.15182a2.59552,2.59552,0,0,0,1.41005,3.38464l302.8649,124.72817a2.59553,2.59553,0,0,0,3.38465-1.41L832.76583,290.62327a2.59552,2.59552,0,0,0-1.41005-3.38464Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--surface-3)" /> | ||||||
|  |     <path | ||||||
|  |         d="M614.03119,325.86654,538.9143,294.93132a4.32609,4.32609,0,0,1-2.35009-5.64107l30.93522-75.11689a4.3261,4.3261,0,0,1,5.64107-2.35009l75.11689,30.93522a4.3261,4.3261,0,0,1,2.35009,5.64107l-30.93522,75.11689A4.3261,4.3261,0,0,1,614.03119,325.86654ZM572.4823,213.4215a2.59553,2.59553,0,0,0-3.38464,1.41006l-30.93522,75.11689a2.59553,2.59553,0,0,0,1.41006,3.38464l75.11688,30.93522a2.59553,2.59553,0,0,0,3.38465-1.41006l30.93521-75.11689a2.59551,2.59551,0,0,0-1.41-3.38464Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--text-2)" /> | ||||||
|  |     <path | ||||||
|  |         d="M588.67043,326.17072,513.55354,295.2355a3.89342,3.89342,0,0,1-2.11508-5.077l30.93522-75.11689a3.89343,3.89343,0,0,1,5.077-2.11508l75.11688,30.93522a3.89341,3.89341,0,0,1,2.11508,5.077l-30.93522,75.11689A3.89341,3.89341,0,0,1,588.67043,326.17072Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--primary-500)" /> | ||||||
|  |     <path | ||||||
|  |         d="M733.35509,428.74966,498.415,331.99483a3.889,3.889,0,1,1,2.96189-7.192L736.317,421.55762a3.889,3.889,0,0,1-2.96188,7.192Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--text-1)" /> | ||||||
|  |     <path | ||||||
|  |         d="M666.41582,430.15629,488.213,356.76742a3.889,3.889,0,1,1,2.96188-7.192l178.20284,73.38887a3.889,3.889,0,1,1-2.96189,7.192Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--text-1)" /> | ||||||
|  |     <path | ||||||
|  |         d="M770.07315,337.32136,666.18809,294.53861a3.889,3.889,0,1,1,2.96189-7.192l103.885,42.78275a3.889,3.889,0,0,1-2.96188,7.192Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--text-1)" /> | ||||||
|  |     <path | ||||||
|  |         d="M733.94491,351.41683,655.98605,319.3112a3.889,3.889,0,1,1,2.96189-7.192l77.95886,32.10562a3.889,3.889,0,0,1-2.96189,7.192Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--text-1)" /> | ||||||
|  |     <path | ||||||
|  |         d="M712.951,478.29485,478.011,381.54a3.889,3.889,0,1,1,2.96188-7.192L715.91289,471.1028a3.889,3.889,0,0,1-2.96188,7.192Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--text-1)" /> | ||||||
|  |     <path | ||||||
|  |         d="M646.01174,479.70147,467.80891,406.3126a3.889,3.889,0,1,1,2.96188-7.192l178.20284,73.38887a3.889,3.889,0,1,1-2.96189,7.192Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--text-1)" /> | ||||||
|  |     <path | ||||||
|  |         d="M692.54693,527.84,457.60687,431.0852a3.889,3.889,0,0,1,2.96188-7.192L695.50881,520.648a3.889,3.889,0,0,1-2.96188,7.192Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--text-1)" /> | ||||||
|  |     <path | ||||||
|  |         d="M682.34489,552.61262,447.40483,455.85779a3.889,3.889,0,0,1,2.96188-7.192l234.94006,96.75484a3.889,3.889,0,0,1-2.96188,7.192Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--text-1)" /> | ||||||
|  |     <path | ||||||
|  |         d="M567.73018,550.77248a84.70308,84.70308,0,0,0,14.09436-.43c4.21238-.49243,8.60066-1.17049,12.29309-3.38536a11.6831,11.6831,0,0,0,5.8212-8.83535,8.2218,8.2218,0,0,0-4.975-8.33661,9.80892,9.80892,0,0,0-9.95124,1.3943,12.959,12.959,0,0,0-4.44981,10.35166c.194,8.00444,6.52716,15.90938,13.55947,19.23894,7.92082,3.75025,18.73754.56318,20.76617-8.67189.42194-1.92082-2.19428-2.58835-3.288-1.35411a8.72086,8.72086,0,0,0,12.17216,12.44835l-2.94431-1.21255a20.9902,20.9902,0,0,0,14.43752,15.24852,19.46991,19.46991,0,0,0,5.37174.81856c2.2119.00621,4.48428,1.11646,6.59962,1.80561l15.24432,4.96639c2.24232.73052,3.665-2.67332,1.40427-3.40985l-13.80618-4.49787c-2.30073-.74955-4.59586-1.51967-6.90308-2.24893-1.64936-.52133-3.45545-.23905-5.176-.54579a17.28811,17.28811,0,0,1-13.5191-12.64511,1.86584,1.86584,0,0,0-2.9443-1.21254,5.04821,5.04821,0,0,1-7.02188-7.25421l-3.288-1.35411c-1.30866,5.95754-8.576,8.19323-13.81358,6.47055-5.85748-1.92656-10.892-7.53271-12.639-13.4049a10.8108,10.8108,0,0,1,.7867-8.60233,6.443,6.443,0,0,1,6.75034-3.30637,4.62264,4.62264,0,0,1,3.95027,5.07015,8.26891,8.26891,0,0,1-4.60472,6.264c-3.29662,1.7695-7.24432,2.21012-10.90575,2.61181a78.79791,78.79791,0,0,1-12.57356.3577c-2.35393-.11867-2.82641,3.54144-.44763,3.66136Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--primary-500)" /> | ||||||
|  |     <polygon points="695.76 290 695.76 583 171.76 583 171.76 237 253.76 237 329.37 290 695.76 290" | ||||||
|  |         fill="var(--surface-5)" /> | ||||||
|  |     <rect x="203.75984" y="528" width="214" height="17" fill="var(--primary-500)" /> | ||||||
|  |     <rect x="203.75984" y="495" width="107" height="17" fill="var(--primary-500)" /> | ||||||
|  |     <path | ||||||
|  |         d="M820.75984,741h-526V393h83.31555l75.61414,53H820.75984Zm-524-2h522V448H453.05843l-75.61414-53H296.75984Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--surface-3)" /> | ||||||
|  |     <polygon | ||||||
|  |         points="909.144 548.636 891.414 554.972 858.535 489.598 884.704 480.246 909.144 548.636" | ||||||
|  |         fill="#9f616a" /> | ||||||
|  |     <path | ||||||
|  |         d="M986.63848,741.638l-.25872-.72291a23.659,23.659,0,0,1,14.30045-30.20571l34.91779-12.47929,8.21153,22.97656Z" | ||||||
|  |         transform="translate(-124 -157)" fill="oklch(from var(--text-2) calc(l - .1) c h)" /> | ||||||
|  |     <polygon | ||||||
|  |         points="793.848 566.172 775.019 566.172 766.062 493.546 793.851 493.547 793.848 566.172" | ||||||
|  |         fill="#9f616a" /> | ||||||
|  |     <path | ||||||
|  |         d="M922.64961,741.42424l-60.71214-.00225v-.76791A23.63085,23.63085,0,0,1,885.5687,717.0236h.0015l37.08053.0015Z" | ||||||
|  |         transform="translate(-124 -157)" fill="oklch(from var(--text-2) calc(l - .1) c h)" /> | ||||||
|  |     <path d="M960.75907,259.18645l-8.18861-16.18053s-30.50532,7.64282-33.27853,25.32289Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--primary-500)" /> | ||||||
|  |     <polygon | ||||||
|  |         points="870.547 287.198 848.278 411.467 907.407 516.036 872.083 529.858 812.186 428.494 804.507 400.849 799.899 545.216 768.042 544.249 753.435 409.445 776.862 284.127 870.547 287.198" | ||||||
|  |         fill="oklch(from var(--text-2) calc(l - .1) c h)" /> | ||||||
|  |     <path | ||||||
|  |         d="M989.9385,388.055l-.77018-72.87145c0-30.88384-20.32611-53.64707-23.14362-55.75276-1.32569-4.231-3.70431-7.15557-7.0678-8.68606-6.77553-3.07086-15.06191.61412-15.41273.77989L918.685,260.84434l-.11662.34118c-.26371.77988-25.3466,83.08812-31.64469,103.74554-.8968,2.96364-1.41327,4.6599-1.41327,4.6599s.09758,4.77688.27275,12.20538c.556,25.54152,1.87167,82.43492,2.39814,84.82336,0,0,45.91642,6.96052,64.09763,6.96052,32.70714,0,53.48166-6.25865,53.94958-6.36587l.75066-.156Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--text-2)" /> | ||||||
|  |     <circle cx="927.1367" cy="204.30312" r="33.60816" | ||||||
|  |         transform="translate(-108.38042 312.74381) rotate(-28.66301)" fill="#9f616a" /> | ||||||
|  |     <path | ||||||
|  |         d="M930.86135,372.63255l-45.07817,9.16379c-.17517-7.4285-.27275-12.20538-.27275-12.20538s.51647-1.69626,1.41327-4.6599Z" | ||||||
|  |         transform="translate(-124 -157)" opacity="0.2" /> | ||||||
|  |     <path | ||||||
|  |         d="M797.36935,363.02694a14.4225,14.4225,0,0,0,21.81522-3.63l50.24885,10.09416-9.99619-24.68652-46.18464-5.80088a14.50066,14.50066,0,0,0-15.88324,24.02326Z" | ||||||
|  |         transform="translate(-124 -157)" fill="#9f616a" /> | ||||||
|  |     <polygon points="732.887 186.321 714.788 183.82 708.751 208.968 731.599 210.276 732.887 186.321" | ||||||
|  |         fill="var(--primary-500)" /> | ||||||
|  |     <path | ||||||
|  |         d="M850.69724,338.47437l53.55238-5.94132,28.41215-50.40785a24.62075,24.62075,0,0,1,45.27595,18.28923l-.16338.62608-47.76016,69.68386-89.30252,4.40419Z" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--text-2)" /> | ||||||
|  |     <path | ||||||
|  |         d="M955.76343,233.48271l-27.895,1.00127c-1.70035.061-6.31513-18.28939-6.91921-22.09617a10.3896,10.3896,0,0,0-10.838-8.40483c-2.08811.19724-7.35359-3.70388-12.78705-8.32323-10.31547-8.76987-9.77883-25.241,1.55269-32.65157q.46458-.30381.91188-.55481c7.14855-4.00112,15.511-5.34475,23.70251-5.44721,7.42579-.09288,15.06209.84177,21.60406,4.35653,11.72836,6.30122,17.97016,20.07116,18.51843,33.37376s-3.71631,26.31011-8.55563,38.71336" | ||||||
|  |         transform="translate(-124 -157)" fill="var(--secondary-500)" /> | ||||||
|  |     <path d="M1075,743H125a1,1,0,0,1,0-2h950a1,1,0,0,1,0,2Z" transform="translate(-124 -157)" | ||||||
|  |         fill="var(--text-2)" /> | ||||||
|  | </svg> | ||||||
| After Width: | Height: | Size: 10 KiB | 
							
								
								
									
										150
									
								
								src/assets/landing.svg
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										150
									
								
								src/assets/landing.svg
									
										
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							| After Width: | Height: | Size: 27 KiB | 
|  | @ -20,3 +20,9 @@ | ||||||
|         border-color: var(--info); |         border-color: var(--info); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | .hue { | ||||||
|  |     display: flex; | ||||||
|  |     flex-flow: row; | ||||||
|  |     align-items: center; | ||||||
|  | } | ||||||
|  | @ -1,69 +1,115 @@ | ||||||
| import { Component, createEffect, createMemo, createResource, For, Setter } from "solid-js"; | import { Accessor, Component, createContext, createEffect, createMemo, createResource, For, ParentComponent, Setter, Show, Suspense, useContext } from "solid-js"; | ||||||
| import css from './colorschemepicker.module.css'; | import css from './colorschemepicker.module.css'; | ||||||
| import { CgDarkMode } from "solid-icons/cg"; | import { CgDarkMode } from "solid-icons/cg"; | ||||||
| import { action, cache, useAction } from "@solidjs/router"; | import { action, createAsyncStore, query, useAction } from "@solidjs/router"; | ||||||
| import { useSession } from "vinxi/http"; | import { useSession } from "vinxi/http"; | ||||||
|  | import { createStore, reconcile, ReconcileOptions, SetStoreFunction } from "solid-js/store"; | ||||||
| 
 | 
 | ||||||
| export enum ColorScheme { | export enum ColorScheme { | ||||||
|     Auto = 'light dark', |     Auto = 'light dark', | ||||||
|     Light = 'light', |     Light = 'light', | ||||||
|     Dark = 'dark', |     Dark = 'dark', | ||||||
| } | } | ||||||
| type ColorSchemeKey = keyof typeof ColorScheme; |  | ||||||
| 
 | 
 | ||||||
| const colorSchemeKeys: readonly ColorSchemeKey[] = ['Auto', 'Light', 'Dark'] as const; | const colorSchemes = Object.entries(ColorScheme) as readonly [keyof typeof ColorScheme, ColorScheme][]; | ||||||
| 
 | 
 | ||||||
| interface ColorSchemePickerProps { | export interface State { | ||||||
|     value?: Setter<ColorScheme>; |     colorScheme: ColorScheme; | ||||||
|  |     hue: number; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const getSession = async () => { | const getSession = async () => { | ||||||
|     'use server'; |     'use server'; | ||||||
| 
 | 
 | ||||||
|     console.log('what? why? how???', process.env.SESSION_SECRET); |     return useSession<State>({ | ||||||
| 
 |  | ||||||
|     return useSession<{ colorScheme: ColorSchemeKey }>({ |  | ||||||
|         password: process.env.SESSION_SECRET!, |         password: process.env.SESSION_SECRET!, | ||||||
|     }); |     }); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| export const getColorScheme = cache(async () => { | export const getState = query(async () => { | ||||||
|     'use server'; |     'use server'; | ||||||
| 
 | 
 | ||||||
|     const session = await getSession(); |     const session = await getSession(); | ||||||
| 
 | 
 | ||||||
|     return session.data.colorScheme; |     return session.data; | ||||||
| }, 'color-scheme'); | }, 'color-scheme'); | ||||||
| 
 | 
 | ||||||
| const setColorScheme = action(async (colorScheme: ColorSchemeKey) => { | const setState = action(async (state: State) => { | ||||||
|     'use server'; |     'use server'; | ||||||
| 
 | 
 | ||||||
|     const session = await getSession(); |     const session = await getSession(); | ||||||
|     await session.update({ colorScheme }); |     await session.update(state); | ||||||
| }, 'color-scheme'); | }, 'color-scheme'); | ||||||
| 
 | 
 | ||||||
| export const ColorSchemePicker: Component<ColorSchemePickerProps> = (props) => { | interface ThemeContextType { | ||||||
|     const [value, { mutate }] = createResource<ColorSchemeKey>(() => getColorScheme(), { initialValue: 'Auto' }); |     readonly theme: State; | ||||||
|     const updateStore = useAction(setColorScheme); |     setColorScheme(colorScheme: ColorScheme): void; | ||||||
|  |     setHue(hue: number): void; | ||||||
|  | } | ||||||
| 
 | 
 | ||||||
|     createEffect(() => { | const ThemeContext = createContext<ThemeContextType>(); | ||||||
|         props.value?.(ColorScheme[value()]); |  | ||||||
|     }); |  | ||||||
| 
 | 
 | ||||||
|     return <label class={css.picker} aria-label="Color scheme picker"> | const useStore = () => useContext(ThemeContext)!; | ||||||
|         <CgDarkMode /> |  | ||||||
| 
 | 
 | ||||||
|         <select name="color-scheme-picker" onInput={(e) => { | export const useTheme = () => { | ||||||
|             if (e.target.value !== value()) { |     const { theme } = useContext(ThemeContext) ?? {}; | ||||||
|                 const nextValue = (e.target.value ?? 'Auto') as ColorSchemeKey; |  | ||||||
| 
 | 
 | ||||||
|                 mutate(nextValue); |     if (theme === undefined) { | ||||||
|                 updateStore(nextValue); |         throw new Error('useColorScheme is called outside a <ColorSchemeProvider />'); | ||||||
|             } |     } | ||||||
|         }}> | 
 | ||||||
|             <For each={colorSchemeKeys}>{ |     return theme; | ||||||
|                 (v) => <option value={v} selected={v === value()}>{v}</option> | }; | ||||||
|             }</For> | 
 | ||||||
|         </select> | export const ThemeProvider: ParentComponent = (props) => { | ||||||
|     </label>; |     const [state, { mutate }] = createResource<State>(() => getState(), { deferStream: true, initialValue: { colorScheme: ColorScheme.Auto, hue: 0 } }); | ||||||
|  |     const updateState = useAction(setState); | ||||||
|  | 
 | ||||||
|  |     return <Suspense> | ||||||
|  |         <Show when={state()}>{state => { | ||||||
|  |             const [store, setStore] = createStore(state()); | ||||||
|  | 
 | ||||||
|  |             createEffect(() => { | ||||||
|  |                 setStore(state()); | ||||||
|  |             }); | ||||||
|  | 
 | ||||||
|  |             createEffect(() => { | ||||||
|  |                 console.log({ ...store }) | ||||||
|  |             }); | ||||||
|  | 
 | ||||||
|  |             return <ThemeContext.Provider value={{ | ||||||
|  |                 get theme() { return store; }, | ||||||
|  |                 setColorScheme(colorScheme: ColorScheme) { updateState(mutate(prev => ({ ...prev, colorScheme }))) }, | ||||||
|  |                 setHue(hue: number) { updateState(mutate(prev => ({ ...prev, hue }))) }, | ||||||
|  |             }}> | ||||||
|  |                 {props.children} | ||||||
|  |             </ThemeContext.Provider>; | ||||||
|  |         }}</Show> | ||||||
|  |     </Suspense>; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | export const ColorSchemePicker: Component = (props) => { | ||||||
|  |     const { theme, setColorScheme, setHue } = useStore(); | ||||||
|  | 
 | ||||||
|  |     return <> | ||||||
|  |         <label class={css.picker} aria-label="Color scheme picker"> | ||||||
|  |             <CgDarkMode /> | ||||||
|  | 
 | ||||||
|  |             <select name="color-scheme-picker" onInput={(e) => { | ||||||
|  |                 if (e.target.value !== theme.colorScheme) { | ||||||
|  |                     const nextValue = (e.target.value ?? ColorScheme.Auto) as ColorScheme; | ||||||
|  | 
 | ||||||
|  |                     setColorScheme(nextValue); | ||||||
|  |                 } | ||||||
|  |             }}> | ||||||
|  |                 <For each={colorSchemes}>{ | ||||||
|  |                     ([label, value]) => <option value={value} selected={value === theme.colorScheme}>{label}</option> | ||||||
|  |                 }</For> | ||||||
|  |             </select> | ||||||
|  |         </label> | ||||||
|  | 
 | ||||||
|  |         <label class={css.hue} aria-label="Hue slider"> | ||||||
|  |             <input type="range" min="0" max="360" value={theme.hue} onInput={e => setHue(e.target.valueAsNumber)} /> | ||||||
|  |         </label> | ||||||
|  |     </>; | ||||||
| }; | }; | ||||||
|  | @ -1,23 +1,26 @@ | ||||||
| import { Link, Meta, Title } from "@solidjs/meta"; | import { Link, Meta, Style, Title } from "@solidjs/meta"; | ||||||
| import { Component, createMemo, createSignal, ErrorBoundary, ParentProps, Show } from "solid-js"; | import { Component, createEffect, createMemo, createSignal, ErrorBoundary, ParentProps, Show } from "solid-js"; | ||||||
| import { BsTranslate } from "solid-icons/bs"; |  | ||||||
| import { FilesProvider } from "~/features/file"; | import { FilesProvider } from "~/features/file"; | ||||||
| import { CommandPalette, CommandPaletteApi, Menu, MenuProvider } from "~/features/menu"; | import { CommandPalette, CommandPaletteApi, Menu, MenuProvider } from "~/features/menu"; | ||||||
| import { A, createAsync, useBeforeLeave } from "@solidjs/router"; | import { A, RouteDefinition, useBeforeLeave } from "@solidjs/router"; | ||||||
| import { createCommand, Modifier } from "~/features/command"; | import { createCommand, Modifier } from "~/features/command"; | ||||||
| import { ColorScheme, ColorSchemePicker, getColorScheme } from "~/components/colorschemepicker"; | import { ColorScheme, ColorSchemePicker, getState, useTheme } from "~/components/colorschemepicker"; | ||||||
| import css from "./editor.module.css"; | import css from "./editor.module.css"; | ||||||
| 
 | 
 | ||||||
|  | export const route: RouteDefinition = { | ||||||
|  |     preload: () => getState(), | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| export default function Editor(props: ParentProps) { | export default function Editor(props: ParentProps) { | ||||||
|     const storedColorScheme = createAsync<keyof typeof ColorScheme>(() => getColorScheme(), { initialValue: 'Auto' }); |     const theme = useTheme(); | ||||||
| 
 | 
 | ||||||
|     const [commandPalette, setCommandPalette] = createSignal<CommandPaletteApi>(); |     const [commandPalette, setCommandPalette] = createSignal<CommandPaletteApi>(); | ||||||
|     const colorScheme = createMemo(() => ColorScheme[storedColorScheme()]); | 
 | ||||||
|     const color = createMemo(() => ({ |     const color = createMemo(() => ({ | ||||||
|         [ColorScheme.Auto]: undefined, |         [ColorScheme.Auto]: undefined, | ||||||
|         [ColorScheme.Light]: '#eee', |         [ColorScheme.Light]: '#eee', | ||||||
|         [ColorScheme.Dark]: '#333', |         [ColorScheme.Dark]: '#333', | ||||||
|     }[ColorScheme[storedColorScheme()]])); |     }[theme.colorScheme])); | ||||||
| 
 | 
 | ||||||
|     const commands = [ |     const commands = [ | ||||||
|         createCommand('open command palette', () => { |         createCommand('open command palette', () => { | ||||||
|  | @ -32,7 +35,7 @@ export default function Editor(props: ParentProps) { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     useBeforeLeave((e) => { |     useBeforeLeave((e) => { | ||||||
|         e.preventDefault() |         e.preventDefault(); | ||||||
| 
 | 
 | ||||||
|         transition(() => { e.retry(true) }) |         transition(() => { e.retry(true) }) | ||||||
|     }); |     }); | ||||||
|  | @ -40,14 +43,18 @@ export default function Editor(props: ParentProps) { | ||||||
|     return <MenuProvider commands={commands}> |     return <MenuProvider commands={commands}> | ||||||
|         <Title>Calque</Title> |         <Title>Calque</Title> | ||||||
| 
 | 
 | ||||||
|         <Meta id="theme-scheme" name="color-scheme" content={colorScheme()} /> |         <Meta id="theme-scheme" name="color-scheme" content={theme.colorScheme} /> | ||||||
|         <Meta id="theme-color" name="theme-color" content={color()} /> |         <Show when={color() === undefined} fallback={<Meta id="theme-color" name="theme-color" content={color()} />}> | ||||||
| 
 |  | ||||||
|         <Show when={color() === undefined}> |  | ||||||
|             <Meta id="theme-auto-light" name="theme-color" media="(prefers-color-scheme: light)" content="#eee" /> |             <Meta id="theme-auto-light" name="theme-color" media="(prefers-color-scheme: light)" content="#eee" /> | ||||||
|             <Meta id="theme-auto-dark" name="theme-color" media="(prefers-color-scheme: dark)" content="#333" /> |             <Meta id="theme-auto-dark" name="theme-color" media="(prefers-color-scheme: dark)" content="#333" /> | ||||||
|         </Show> |         </Show> | ||||||
| 
 | 
 | ||||||
|  |         <Style>{` | ||||||
|  |             :root { | ||||||
|  |                 --hue: ${theme.hue}deg !important; | ||||||
|  |             } | ||||||
|  |         `}</Style>
 | ||||||
|  | 
 | ||||||
|         <Link rel="icon" href="/images/favicon.dark.svg" media="screen and (prefers-color-scheme: dark)" /> |         <Link rel="icon" href="/images/favicon.dark.svg" media="screen and (prefers-color-scheme: dark)" /> | ||||||
|         <Link rel="icon" href="/images/favicon.light.svg" media="screen and (prefers-color-scheme: light)" /> |         <Link rel="icon" href="/images/favicon.light.svg" media="screen and (prefers-color-scheme: light)" /> | ||||||
|         <Link rel="manifest" href="/manifest.json" /> |         <Link rel="manifest" href="/manifest.json" /> | ||||||
|  | @ -66,6 +73,7 @@ export default function Editor(props: ParentProps) { | ||||||
| 
 | 
 | ||||||
|                 <section class={css.right}> |                 <section class={css.right}> | ||||||
|                     <ColorSchemePicker /> |                     <ColorSchemePicker /> | ||||||
|  | 
 | ||||||
|                 </section> |                 </section> | ||||||
|             </nav> |             </nav> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -27,9 +27,25 @@ | ||||||
| 
 | 
 | ||||||
| .blank { | .blank { | ||||||
|     display: grid; |     display: grid; | ||||||
|     grid: 100% / 100%; |     place-content: center; | ||||||
|  |     place-items: center; | ||||||
|  |     grid-auto-flow: column; | ||||||
|  |     gap: var(--padding-l); | ||||||
|     inline-size: 100%; |     inline-size: 100%; | ||||||
|     block-size: 100%; |     block-size: 100%; | ||||||
| 
 | 
 | ||||||
|     place-items: center; |     & > svg { | ||||||
|  |         padding-inline-end: 3em; | ||||||
|  |         margin-inline-end: 3em; | ||||||
|  |         border-inline-end: 2px solid var(--surface-5); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     & > button { | ||||||
|  |         background-color: var(--surface-4); | ||||||
|  |         color: var(--text-1); | ||||||
|  |         padding: var(--padding-l) var(--padding-xl); | ||||||
|  |         border: none; | ||||||
|  |         border-radius: var(--radii-m); | ||||||
|  |         cursor: pointer; | ||||||
|  |     } | ||||||
| } | } | ||||||
|  | @ -7,9 +7,10 @@ import { Grid, load, useFiles } from "~/features/file"; | ||||||
| import { Command, CommandType, Context, createCommand, Modifier, noop, useCommands } from "~/features/command"; | import { Command, CommandType, Context, createCommand, Modifier, noop, useCommands } from "~/features/command"; | ||||||
| import { GridApi } from "~/features/file/grid"; | import { GridApi } from "~/features/file/grid"; | ||||||
| import { Tab, Tabs } from "~/components/tabs"; | import { Tab, Tabs } from "~/components/tabs"; | ||||||
| import css from "./edit.module.css"; |  | ||||||
| import { isServer } from "solid-js/web"; | import { isServer } from "solid-js/web"; | ||||||
| import { Prompt, PromptApi } from "~/components/prompt"; | import { Prompt, PromptApi } from "~/components/prompt"; | ||||||
|  | import EditBlankImage from '~/assets/edit-blank.svg' | ||||||
|  | import css from "./edit.module.css"; | ||||||
| 
 | 
 | ||||||
| const isInstalledPWA = !isServer && window.matchMedia('(display-mode: standalone)').matches; | const isInstalledPWA = !isServer && window.matchMedia('(display-mode: standalone)').matches; | ||||||
| 
 | 
 | ||||||
|  | @ -269,6 +270,10 @@ const Editor: Component<{ root: FileSystemDirectoryHandle }> = (props) => { | ||||||
|                 <Menu.Item command={commands.open} /> |                 <Menu.Item command={commands.open} /> | ||||||
| 
 | 
 | ||||||
|                 <Menu.Item command={commands.save} /> |                 <Menu.Item command={commands.save} /> | ||||||
|  | 
 | ||||||
|  |                 <Menu.Separator /> | ||||||
|  | 
 | ||||||
|  |                 <Menu.Item command={commands.close} /> | ||||||
|             </Menu.Item> |             </Menu.Item> | ||||||
| 
 | 
 | ||||||
|             <Menu.Item label="edit"> |             <Menu.Item label="edit"> | ||||||
|  | @ -385,6 +390,8 @@ const Content: Component<{ directory: FileSystemDirectoryHandle, api?: Setter<Gr | ||||||
| 
 | 
 | ||||||
| const Blank: Component<{ open: CommandType }> = (props) => { | const Blank: Component<{ open: CommandType }> = (props) => { | ||||||
|     return <div class={css.blank}> |     return <div class={css.blank}> | ||||||
|  |         <EditBlankImage /> | ||||||
|  | 
 | ||||||
|         <button onpointerdown={() => props.open()}>open a folder</button> |         <button onpointerdown={() => props.open()}>open a folder</button> | ||||||
|     </div> |     </div> | ||||||
| }; | }; | ||||||
|  | @ -3,6 +3,11 @@ | ||||||
|     place-content: center; |     place-content: center; | ||||||
|     gap: var(--padding-m); |     gap: var(--padding-m); | ||||||
| 
 | 
 | ||||||
|  |     & > :is(.primary, .secondary) { | ||||||
|  |         display: grid; | ||||||
|  |         grid: 3em / repeat(5, 3em); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     ul { |     ul { | ||||||
|         display: flex; |         display: flex; | ||||||
|         flex-flow: column; |         flex-flow: column; | ||||||
|  |  | ||||||
|  | @ -1,46 +1,13 @@ | ||||||
| import { Component, createEffect, createMemo, createResource, createSignal, For, onMount, Show } from "solid-js"; |  | ||||||
| import { useFiles } from "~/features/file"; |  | ||||||
| import { AiFillFile, AiFillFolder, AiFillFolderOpen } from "solid-icons/ai"; |  | ||||||
| import { A } from "@solidjs/router"; | import { A } from "@solidjs/router"; | ||||||
|  | import LandingImage from '../../assets/landing.svg' | ||||||
| import css from "./index.module.css"; | import css from "./index.module.css"; | ||||||
| 
 | 
 | ||||||
| interface FileEntry { |  | ||||||
|   name: string; |  | ||||||
|   kind: 'file'; |  | ||||||
|   meta: File; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| interface FolderEntry { |  | ||||||
|   name: string; |  | ||||||
|   kind: 'folder'; |  | ||||||
|   entries: Entry[]; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| type Entry = FileEntry | FolderEntry; |  | ||||||
| 
 |  | ||||||
| async function* walk(directory: FileSystemDirectoryHandle, filters: RegExp[] = [], depth = 0): AsyncGenerator<Entry, void, never> { |  | ||||||
|   if (depth === 10) { |  | ||||||
|     return; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   for await (const handle of directory.values()) { |  | ||||||
| 
 |  | ||||||
|     if (filters.some(f => f.test(handle.name))) { |  | ||||||
|       continue; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     if (handle.kind === 'file') { |  | ||||||
|       yield { name: handle.name, kind: 'file', meta: await handle.getFile() }; |  | ||||||
|     } |  | ||||||
|     else { |  | ||||||
|       yield { name: handle.name, kind: 'folder', entries: await Array.fromAsync(walk(handle, filters, depth + 1)) }; |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| export default function Index() { | export default function Index() { | ||||||
|   return ( |   return ( | ||||||
|     <main class={css.main}> |     <main class={css.main}> | ||||||
|  |       <LandingImage /> | ||||||
|  | 
 | ||||||
|       <h1>Hi, welcome!</h1> |       <h1>Hi, welcome!</h1> | ||||||
|       <b>Lets get started</b> |       <b>Lets get started</b> | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
							
								
								
									
										66
									
								
								src/routes/(editor)/test.module.css
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								src/routes/(editor)/test.module.css
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,66 @@ | ||||||
|  | .main { | ||||||
|  |     display: grid; | ||||||
|  |     place-content: center; | ||||||
|  |     gap: var(--padding-m); | ||||||
|  | 
 | ||||||
|  |     & > svg { | ||||||
|  |         inline-size: 100%; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     & > :is(.primary, .secondary) { | ||||||
|  |         display: grid; | ||||||
|  |         grid: 3em / repeat(5, 3em); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     & > .primary { | ||||||
|  |         & > :nth-child(1) { | ||||||
|  |             background-color: var(--primary-100); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         & > :nth-child(2) { | ||||||
|  |             background-color: var(--primary-300); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         & > :nth-child(3) { | ||||||
|  |             background-color: var(--primary-500); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         & > :nth-child(4) { | ||||||
|  |             background-color: var(--primary-700); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         & > :nth-child(5) { | ||||||
|  |             background-color: var(--primary-900); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     & > .secondary { | ||||||
|  |         & > :nth-child(1) { | ||||||
|  |             background-color: var(--secondary-100); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         & > :nth-child(2) { | ||||||
|  |             background-color: var(--secondary-300); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         & > :nth-child(3) { | ||||||
|  |             background-color: var(--secondary-500); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         & > :nth-child(4) { | ||||||
|  |             background-color: var(--secondary-700); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         & > :nth-child(5) { | ||||||
|  |             background-color: var(--secondary-900); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     ul { | ||||||
|  |         display: flex; | ||||||
|  |         flex-flow: column; | ||||||
|  |         gap: var(--padding-s); | ||||||
|  |         padding-inline-start: var(--padding-l); | ||||||
|  |         margin: 0; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										38
									
								
								src/routes/(editor)/test.tsx
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								src/routes/(editor)/test.tsx
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,38 @@ | ||||||
|  | import { A } from "@solidjs/router"; | ||||||
|  | import LandingImage from '../../assets/landing.svg' | ||||||
|  | import css from "./test.module.css"; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | export default function Index() { | ||||||
|  |   return ( | ||||||
|  |     <main class={css.main}> | ||||||
|  |       <LandingImage /> | ||||||
|  | 
 | ||||||
|  |       <h1>Hi, welcome!</h1> | ||||||
|  |       <b>Lets get started</b> | ||||||
|  | 
 | ||||||
|  |       <div class={css.primary}> | ||||||
|  |         <span /> | ||||||
|  |         <span /> | ||||||
|  |         <span /> | ||||||
|  |         <span /> | ||||||
|  |         <span /> | ||||||
|  |       </div> | ||||||
|  | 
 | ||||||
|  |       <div class={css.secondary}> | ||||||
|  |         <span /> | ||||||
|  |         <span /> | ||||||
|  |         <span /> | ||||||
|  |         <span /> | ||||||
|  |         <span /> | ||||||
|  |       </div> | ||||||
|  | 
 | ||||||
|  |       <ul> | ||||||
|  |         <li><A href="/edit">Start editing</A></li> | ||||||
|  |         {/* <li><A href="/experimental">Try new features</A></li> */} | ||||||
|  |         <li><A href="/instructions">Read the instructions</A></li> | ||||||
|  |         <li><A href="/about">About this app</A></li> | ||||||
|  |       </ul> | ||||||
|  |     </main> | ||||||
|  |   ); | ||||||
|  | } | ||||||
|  | @ -50,6 +50,7 @@ | ||||||
| 
 | 
 | ||||||
|         & .right { |         & .right { | ||||||
|             display: grid; |             display: grid; | ||||||
|  |             grid-auto-flow: column; | ||||||
|             align-content: center; |             align-content: center; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | @ -15,6 +15,7 @@ | ||||||
|       "@testing-library/jest-dom", |       "@testing-library/jest-dom", | ||||||
|       "@types/wicg-file-system-access", |       "@types/wicg-file-system-access", | ||||||
|       "vinxi/types/client", |       "vinxi/types/client", | ||||||
|  |       "vite-plugin-solid-svg/types-component-solid", | ||||||
|       "vite-plugin-pwa/solid", |       "vite-plugin-pwa/solid", | ||||||
|       "bun-types" |       "bun-types" | ||||||
|     ], |     ], | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue