|  |  | @ -1,11 +1,8 @@ | 
			
		
	
		
		
			
				
					
					|  |  |  | <script> |  |  |  | <script> | 
			
		
	
		
		
			
				
					
					|  |  |  |   import { push, link } from 'svelte-spa-router'; |  |  |  |   import { link } from 'svelte-spa-router'; | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |   import Validator from 'Validator'; |  |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |   import { onMount } from 'svelte'; |  |  |  |   import { onMount } from 'svelte'; | 
			
		
	
		
		
			
				
					
					|  |  |  |   import Layout from '$/client/Layout.svelte'; |  |  |  |   import Layout from '$/client/Layout.svelte'; | 
			
		
	
		
		
			
				
					
					|  |  |  |   import Icon from '$/client/components/Icon.svelte'; |  |  |  |   import Icon from '$/client/components/Icon.svelte'; | 
			
		
	
		
		
			
				
					
					|  |  |  |   import Markdown from '$/client/components/Markdown.svelte'; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   import Blockstart from "$/client/components/Blockstart.svelte"; |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   import Code from "$/client/components/Code.svelte"; |  |  |  |   import Code from "$/client/components/Code.svelte"; | 
			
		
	
		
		
			
				
					
					|  |  |  |   import api from "$/client/api.js"; |  |  |  |   import api from "$/client/api.js"; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -14,13 +11,21 @@ | 
			
		
	
		
		
			
				
					
					|  |  |  |   let url; |  |  |  |   let url; | 
			
		
	
		
		
			
				
					
					|  |  |  |   export let params; |  |  |  |   export let params; | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   const jump = (id) => { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     let node = document.getElementById(id); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     if(node) node.scrollIntoView(); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   const jump_top = () => { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     jump("top-scroll"); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   const load_docs = async (to_load) => { |  |  |  |   const load_docs = async (to_load) => { | 
			
		
	
		
		
			
				
					
					|  |  |  |     const [status, data] = await api.get(`/docs/api/${to_load}.json`); |  |  |  |     const [status, data] = await api.get(`/docs/api/${to_load}.json`); | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     docs_data = status === 200 ? data : {}; |  |  |  |     docs_data = status === 200 ? data : {}; | 
			
		
	
		
		
			
				
					
					|  |  |  |     url = to_load; |  |  |  |     url = to_load; | 
			
		
	
		
		
			
				
					
					|  |  |  |     console.log(docs_data); |  |  |  |     jump_top(); | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     window.scrollTo(0, 0); |  |  |  |  | 
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   const load_index = async () => { |  |  |  |   const load_index = async () => { | 
			
		
	
	
		
		
			
				
					|  |  | @ -30,8 +35,8 @@ | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   const type_to_syntax = { |  |  |  |   const type_to_syntax = { | 
			
		
	
		
		
			
				
					
					|  |  |  |     callexpression: "()", |  |  |  |     "callexpression": "()", | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     objectexpression: "{}", |  |  |  |     "objectexpression": "{}", | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     "function": "()", |  |  |  |     "function": "()", | 
			
		
	
		
		
			
				
					
					|  |  |  |     "class": "{}", |  |  |  |     "class": "{}", | 
			
		
	
		
		
			
				
					
					|  |  |  |     "method": "()" |  |  |  |     "method": "()" | 
			
		
	
	
		
		
			
				
					|  |  | @ -46,7 +51,6 @@ | 
			
		
	
		
		
			
				
					
					|  |  |  |   $: if(params.wild && params.wild !== url) { |  |  |  |   $: if(params.wild && params.wild !== url) { | 
			
		
	
		
		
			
				
					
					|  |  |  |     load_docs(params.wild); |  |  |  |     load_docs(params.wild); | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | </script> |  |  |  | </script> | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | <style> |  |  |  | <style> | 
			
		
	
	
		
		
			
				
					|  |  | @ -137,6 +141,18 @@ | 
			
		
	
		
		
			
				
					
					|  |  |  |     background-color: var(--color-bg-inverted); |  |  |  |     background-color: var(--color-bg-inverted); | 
			
		
	
		
		
			
				
					
					|  |  |  |     color: var(--color-text-inverted); |  |  |  |     color: var(--color-text-inverted); | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   toc { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     display: grid; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     grid-template-columns: repeat(6, 1fr); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   toc span { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     border: 1px solid black; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     padding: 0.5rem; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     text-align: center; | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     background-color: var(--value3); | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | </style> |  |  |  | </style> | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -151,19 +167,34 @@ | 
			
		
	
		
		
			
				
					
					|  |  |  |   </sidebar> |  |  |  |   </sidebar> | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   <right> |  |  |  |   <right> | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       <scroll-sucks id="top-scroll"></scroll-sucks> | 
			
		
	
		
		
			
				
					
					|  |  |  |       {#if docs_data} |  |  |  |       {#if docs_data} | 
			
		
	
		
		
			
				
					
					|  |  |  |         <module-header> |  |  |  |         <module-header> | 
			
		
	
		
		
			
				
					
					|  |  |  |         <h1>{ url }</h1> |  |  |  |         <h1>{ url }</h1> | 
			
		
	
		
		
			
				
					
					|  |  |  |         {#if docs_data.comment} |  |  |  |         {#if docs_data.comment} | 
			
		
	
		
		
			
				
					
					|  |  |  |           {@html docs_data.comment} |  |  |  |           {@html docs_data.comment} | 
			
		
	
		
		
			
				
					
					|  |  |  |         {/if} |  |  |  |         {/if} | 
			
		
	
		
		
			
				
					
					|  |  |  |       </module-header> |  |  |  | 
 | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         <toc> | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |           {#each docs_data.exports as exp} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             {#if exp.isa == "class"} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |               <span on:click={ () => jump(exp.slug) }>{ exp.name }</span> | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |               {#each exp.methods as member} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                 <span on:click={ () => jump(member.slug) }>.{ member.name }</span> | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |               {/each} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             {:else} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |               <span on:click={ () => jump(exp.slug) }>{ exp.name }</span> | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             {/if} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |           {/each} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         </toc> | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |         </module-header> | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |       {#each docs_data.exports as exp} |  |  |  |       {#each docs_data.exports as exp} | 
			
		
	
		
		
			
				
					
					|  |  |  |         {#if exp.isa === "class"} |  |  |  |         {#if exp.isa === "class"} | 
			
		
	
		
		
			
				
					
					|  |  |  |           <export class="class-def"> |  |  |  |           <export class="class-def"> | 
			
		
	
		
		
			
				
					
					|  |  |  |           <heading> |  |  |  |           <heading> | 
			
		
	
		
		
			
				
					
					|  |  |  |             <h2>class { exp.name }</h2> |  |  |  |           <h2 on:click={ () => jump_top() } id={ exp.slug }>class { exp.name }</h2> | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |             <Code content={ exp.code } language="javascript" /> |  |  |  |             <Code content={ exp.code } language="javascript" /> | 
			
		
	
		
		
			
				
					
					|  |  |  |           </heading> |  |  |  |           </heading> | 
			
		
	
		
		
			
				
					
					|  |  |  |           <comment> |  |  |  |           <comment> | 
			
		
	
	
		
		
			
				
					|  |  | @ -176,7 +207,8 @@ | 
			
		
	
		
		
			
				
					
					|  |  |  |           {#each exp.methods as member} |  |  |  |           {#each exp.methods as member} | 
			
		
	
		
		
			
				
					
					|  |  |  |             <export class="member"> |  |  |  |             <export class="member"> | 
			
		
	
		
		
			
				
					
					|  |  |  |               <heading> |  |  |  |               <heading> | 
			
		
	
		
		
			
				
					
					|  |  |  |                 <h4>.{member.name}{ type_to_syntax[member.isa] || "" }</h4> |  |  |  |               <h4 id={ member.slug } on:click={ () => jump(exp.slug) }>.{member.name}{ type_to_syntax[member.isa] || "" } | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |               </h4> | 
			
		
	
		
		
			
				
					
					|  |  |  |                 <meta-data> |  |  |  |                 <meta-data> | 
			
		
	
		
		
			
				
					
					|  |  |  |                   {docs_data.source}:{ member.line_start } |  |  |  |                   {docs_data.source}:{ member.line_start } | 
			
		
	
		
		
			
				
					
					|  |  |  |                   <em>{ member.isa } of { exp.name }</em> |  |  |  |                   <em>{ member.isa } of { exp.name }</em> | 
			
		
	
	
		
		
			
				
					|  |  | @ -198,15 +230,17 @@ | 
			
		
	
		
		
			
				
					
					|  |  |  |         {:else} |  |  |  |         {:else} | 
			
		
	
		
		
			
				
					
					|  |  |  |           <export> |  |  |  |           <export> | 
			
		
	
		
		
			
				
					
					|  |  |  |             <heading> |  |  |  |             <heading> | 
			
		
	
		
		
			
				
					
					|  |  |  |               <h4>{exp.name}{ type_to_syntax[exp.isa] || "" }</h4> |  |  |  |               <h4 on:click={ () => jump_top() } | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                   id={ exp.slug }>{exp.name}{ type_to_syntax[exp.isa] || "" } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |               </h4> | 
			
		
	
		
		
			
				
					
					|  |  |  |               <meta-data> |  |  |  |               <meta-data> | 
			
		
	
		
		
			
				
					
					|  |  |  |                 {docs_data.source}:{ exp.line_start } |  |  |  |                 {docs_data.source}:{ exp.line_start } | 
			
		
	
		
		
			
				
					
					|  |  |  |                 <em>{ exp.isa }</em> |  |  |  |                 <em>{ exp.isa }</em> | 
			
		
	
		
		
			
				
					
					|  |  |  |                 {#if exp.static}<b>static</b>{/if} |  |  |  |                 {#if exp.static}<b>static</b>{/if} | 
			
		
	
		
		
			
				
					
					|  |  |  |                 {#if exp.async}<b>async</b>{/if} |  |  |  |                 {#if exp.async}<b>async</b>{/if} | 
			
		
	
		
		
			
				
					
					|  |  |  |                 {#if exp.generator}<b>generator</b>{/if} |  |  |  |                 {#if exp.generator}<b>generator</b>{/if} | 
			
		
	
		
		
			
				
					
					|  |  |  |                 </meta-data> |  |  |  |               </meta-data> | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |               </heading> |  |  |  |             </heading> | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |             <info> |  |  |  |             <info> | 
			
		
	
		
		
			
				
					
					|  |  |  |               {#if exp.comment} |  |  |  |               {#if exp.comment} | 
			
		
	
		
		
			
				
					
					|  |  |  |                 <comment> |  |  |  |                 <comment> | 
			
		
	
	
		
		
			
				
					|  |  | 
 |