more fancy pancy error component
This commit is contained in:
		
							parent
							
								
									da016f2e03
								
							
						
					
					
						commit
						597c7e4e0b
					
				
					 3 changed files with 35 additions and 8 deletions
				
			
		|  | @ -64,7 +64,7 @@ export default function Editor(props: ParentProps) { | ||||||
|             </nav> |             </nav> | ||||||
| 
 | 
 | ||||||
|             <section> |             <section> | ||||||
|                 <ErrorBoundary fallback={err => <ErrorComp error={err.message} />}> |                 <ErrorBoundary fallback={err => <ErrorComp error={err} />}> | ||||||
|                     <FilesProvider> |                     <FilesProvider> | ||||||
|                         {props.children} |                         {props.children} | ||||||
|                     </FilesProvider> |                     </FilesProvider> | ||||||
|  | @ -76,6 +76,14 @@ export default function Editor(props: ParentProps) { | ||||||
|     </MenuProvider> |     </MenuProvider> | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const ErrorComp: Component<{ error: string }> = (props) => { | const ErrorComp: Component<{ error: Error }> = (props) => { | ||||||
|     return <div class={css.error}>{props.error}</div> |     return <div class={css.error}> | ||||||
|  |         <b>{props.error.message}</b> | ||||||
|  | 
 | ||||||
|  |         <Show when={props.error.cause}>{ | ||||||
|  |             cause => <>{cause().description}</> | ||||||
|  |         }</Show> | ||||||
|  | 
 | ||||||
|  |         <a href="/">Return to start</a> | ||||||
|  |     </div>; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | @ -42,6 +42,19 @@ interface Entries extends Map<string, Record<string, { value: string, handle: Fi | ||||||
| export default function Edit(props: ParentProps) { | export default function Edit(props: ParentProps) { | ||||||
|     const filesContext = useFiles(); |     const filesContext = useFiles(); | ||||||
| 
 | 
 | ||||||
|  |     onMount(() => { | ||||||
|  |         if (!('showDirectoryPicker' in window)) { | ||||||
|  |             throw new Error('Unable to manage files', { | ||||||
|  |                 cause: { | ||||||
|  |                     description: <p> | ||||||
|  |                         The browser you are using does not support the File Access API.<br /> | ||||||
|  |                         This API is crutial for this app. | ||||||
|  |                     </p> | ||||||
|  |                 } | ||||||
|  |             }); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|     const open = createCommand('open folder', async () => { |     const open = createCommand('open folder', async () => { | ||||||
|         const directory = await window.showDirectoryPicker({ mode: 'readwrite' }); |         const directory = await window.showDirectoryPicker({ mode: 'readwrite' }); | ||||||
| 
 | 
 | ||||||
|  | @ -319,10 +332,6 @@ const Content: Component<{ directory: FileSystemDirectoryHandle, api?: Setter<Gr | ||||||
|     const [rows, setRows] = createSignal<Map<string, Record<string, string>>>(new Map); |     const [rows, setRows] = createSignal<Map<string, Record<string, string>>>(new Map); | ||||||
|     const [api, setApi] = createSignal<GridApi>(); |     const [api, setApi] = createSignal<GridApi>(); | ||||||
| 
 | 
 | ||||||
|     if (!isServer && !('showDirectoryPicker' in window)) { |  | ||||||
|         throw new Error('Unable to manage files'); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     createEffect(() => { |     createEffect(() => { | ||||||
|         props.entries?.(entries()); |         props.entries?.(entries()); | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
|  | @ -51,6 +51,11 @@ | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     & > section { |     & > section { | ||||||
|  |         display: grid; | ||||||
|  |         grid: 100% / 100%; | ||||||
|  |         inline-size: 100%; | ||||||
|  |         block-size: 100%; | ||||||
|  |         overflow: clip; | ||||||
|         view-transition-name: content; |         view-transition-name: content; | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | @ -59,7 +64,12 @@ | ||||||
|     display: grid; |     display: grid; | ||||||
|     place-content: center; |     place-content: center; | ||||||
| 
 | 
 | ||||||
|     background-color: color(from var(--fail) xyz x y z / .3); |     background: repeating-linear-gradient(-45deg, | ||||||
|  |             color(from var(--fail) xyz x y z / .05), | ||||||
|  |             color(from var(--fail) xyz x y z / .05) 10px, | ||||||
|  |             color(from var(--fail) xyz x y z / .25) 10px, | ||||||
|  |             color(from var(--fail) xyz x y z / .25) 12px, | ||||||
|  |             color(from var(--fail) xyz x y z / .05) 12px); | ||||||
|     color: var(--text-2); |     color: var(--text-2); | ||||||
|     border: 1px solid var(--fail); |     border: 1px solid var(--fail); | ||||||
|     border-radius: var(--radii-m); |     border-radius: var(--radii-m); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue