diff options
| author | Craig Jennings <craigmartinjennings@gmail.com> | 2024-03-24 14:41:32 -0500 | 
|---|---|---|
| committer | Craig Jennings <craigmartinjennings@gmail.com> | 2024-03-24 14:41:32 -0500 | 
| commit | 4aed6ea63ae93704b5d4cc07b528a0dd70a5d752 (patch) | |
| tree | d7610e41ff54da3f340cec1c86134c189a44db8a /layouts/partials/typeActivity.html | |
initial commit; forked from https://github.com/Yukuro/hugo-theme-shell
Diffstat (limited to 'layouts/partials/typeActivity.html')
| -rw-r--r-- | layouts/partials/typeActivity.html | 57 | 
1 files changed, 57 insertions, 0 deletions
| diff --git a/layouts/partials/typeActivity.html b/layouts/partials/typeActivity.html new file mode 100644 index 0000000..911754f --- /dev/null +++ b/layouts/partials/typeActivity.html @@ -0,0 +1,57 @@ +<span id="activity-title"></span> <br> + <span id="activity-content"></span> <br> + +<script type="text/javascript"> +    async function typewriter(text, elementId, waitAfter) { +        var n = 0, +            isTag = false +        addText = ""; +        const el = document.getElementById(elementId); + +        const wait = () => new Promise(r => setTimeout(r, waitAfter)); +        const nowait = () => new Promise(r => r()); + +        const render = () => el.innerHTML = (text.slice(0, n + 1) + addText); + +        const cursor = document.createElement('span'); +        cursor.id = "blink"; + +        el.style.setProperty("--cursor-visibility", "visible"); +        while (n < text.length) { +            if (text.charAt(n + 1) === "<") isTag = true; +            if (text.charAt(n + 1) === ">") isTag = false; + +            if (isTag) { +                n++; +                continue; +            } + +            requestAnimationFrame(render); + +            if (waitAfter === 0) { +                await nowait(); +            } else { +                await wait(); +            } + +            n++; +        } +        el.style.setProperty("--cursor-visibility", "collapse"); +    } + +    function parseDelay(d) { +        const parsed = parseInt(d, 10); +        if (isNaN(parsed)) return 0; +        return parsed; +    } + +    const titleDelay = parseDelay("{{ .titledelay }}"), +        contentDelay = parseDelay("{{ .contentdelay }}"); +    const typeeffetct = async () => { +        await typewriter("{{ .title }}", "activity-title", titleDelay); +        await typewriter("{{ .content }}", "activity-content", contentDelay); +        return; +    } + +    typeeffetct() +</script>
\ No newline at end of file | 
