mirror of
https://github.com/cupcakearmy/nicco.io.git
synced 2025-01-02 21:36:26 +00:00
commit
3c54aa7874
530
package-lock.json
generated
530
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
48
src/components/Loading.svelte
Normal file
48
src/components/Loading.svelte
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
<script>
|
||||||
|
import { spring } from 'svelte/motion'
|
||||||
|
|
||||||
|
import { scroll } from '../lib/scroll'
|
||||||
|
|
||||||
|
let el
|
||||||
|
const springed = spring(
|
||||||
|
{ scroll: 0 },
|
||||||
|
{
|
||||||
|
stiffness: 0.02,
|
||||||
|
damping: 0.75,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
function updateState(value) {
|
||||||
|
const R = 50
|
||||||
|
let alpha = (360 / 1) * value
|
||||||
|
if (alpha === 360) alpha = 359.99999
|
||||||
|
const a = ((90 - alpha) * Math.PI) / 180
|
||||||
|
const x = R + R * Math.cos(a) * 2
|
||||||
|
const y = R - R * Math.sin(a) * 2
|
||||||
|
const center = alpha > 180 ? 1 : 0
|
||||||
|
const path = `M${R},${-50} A${R * 2},${
|
||||||
|
R * 2
|
||||||
|
},0,${center},1,${x},${y} L${R},${R} L${R},${-R}`
|
||||||
|
if (el) el.setAttribute('d', path)
|
||||||
|
}
|
||||||
|
|
||||||
|
$: springed.set({ scroll: $scroll })
|
||||||
|
|
||||||
|
$: updateState($springed.scroll)
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<svg viewBox="0 0 100 100" xmlns="http://www.w3.org/2000/svg" version="1.1">
|
||||||
|
<path bind:this={el} fill="var(--clr-secondary)" d="" />
|
||||||
|
</svg>
|
||||||
|
|
||||||
|
<style>
|
||||||
|
svg {
|
||||||
|
position: fixed;
|
||||||
|
bottom: 1em;
|
||||||
|
right: 1em;
|
||||||
|
border: 0.125em solid var(--clr-primary);
|
||||||
|
width: 2em;
|
||||||
|
height: 2em;
|
||||||
|
pointer-events: none;
|
||||||
|
}
|
||||||
|
</style>
|
3
src/lib/scroll.js
Normal file
3
src/lib/scroll.js
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
import { writable } from 'svelte/store'
|
||||||
|
|
||||||
|
export const scroll = writable(0)
|
@ -2,7 +2,9 @@
|
|||||||
import { onMount } from 'svelte'
|
import { onMount } from 'svelte'
|
||||||
import { stores } from '@sapper/app'
|
import { stores } from '@sapper/app'
|
||||||
|
|
||||||
|
import { scroll } from '../lib/scroll'
|
||||||
import Nav from '../components/Nav.svelte'
|
import Nav from '../components/Nav.svelte'
|
||||||
|
import Loading from '../components/Loading.svelte'
|
||||||
|
|
||||||
export let segment
|
export let segment
|
||||||
let wrapper
|
let wrapper
|
||||||
@ -24,13 +26,31 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function updateScroll(e) {
|
||||||
|
const el = e.target
|
||||||
|
const percentage = el.scrollTop / (el.scrollHeight - el.offsetHeight)
|
||||||
|
scroll.set(isNaN(percentage) ? 0 : percentage)
|
||||||
|
}
|
||||||
|
|
||||||
onMount(() => {
|
onMount(() => {
|
||||||
const listener = window.addEventListener('resize', resize)
|
const resizeFN = window.addEventListener('resize', resize, false)
|
||||||
|
const scrollFN = main.addEventListener('scroll', updateScroll, false)
|
||||||
resize()
|
resize()
|
||||||
return () => window.removeEventListener(listener)
|
return () => {
|
||||||
|
window.removeEventListener(resizeFN)
|
||||||
|
main.removeEventListener(scrollFN)
|
||||||
|
}
|
||||||
})
|
})
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
<div bind:this={wrapper}>
|
||||||
|
<Nav {segment} />
|
||||||
|
<main bind:this={main}>
|
||||||
|
<slot />
|
||||||
|
</main>
|
||||||
|
<Loading />
|
||||||
|
</div>
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
div {
|
div {
|
||||||
display: flex;
|
display: flex;
|
||||||
@ -56,10 +76,3 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<div bind:this={wrapper}>
|
|
||||||
<Nav {segment} />
|
|
||||||
<main bind:this={main}>
|
|
||||||
<slot />
|
|
||||||
</main>
|
|
||||||
</div>
|
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
<script context="module">
|
<script context="module">
|
||||||
export async function preload({ params }) {
|
export async function preload({ params }) {
|
||||||
return this.fetch(`/api/posts/${params.slug}.json`).then((res) => res.json())
|
return this.fetch(`/api/posts/${params.slug}.json`).then((res) =>
|
||||||
|
res.json()
|
||||||
|
)
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user