Package Exports
- @prgm/sveltekit-progress-bar
- @prgm/sveltekit-progress-bar/ProgressBar.svelte
- @prgm/sveltekit-progress-bar/package.json
Readme
sveltekit-progress-bar
A SvelteKit component that displays a progress bar when the page is loading.
This component is based on the svelte-progress-bar component for Svelte. It has been adapted to integrate with SvelteKit.
If you are looking for a standalone component, check out the original component.
Demo
Please refer to the svelte-progress-bar package for a demo.
Installation
In a SvelteKit project:
npm install --save-dev @prgm/sveltekit-progress-barUsing pnpm:
pnpm add --save-dev @prgm/sveltekit-progress-barUsage
In a SvelteKit page or layout where you would like to use the component,
for instance in the src/routes/+layout.svelte file:
<!-- +layout.svelte -->
<script lang="ts">
import { ProgressBar } from '@prgm/sveltekit-progress-bar'
</script>
<ProgressBar color="#7F57F1" />
<slot />On SvelteKit versions prior to 1.0.0-next.572
This package uses $app/navigation from SvelteKit. If you are using a version
of SvelteKit prior to 1.0.0-next.572, you will need to exclude it in your Vite
configuration, like so:
// vite.config.js
import { sveltekit } from '@sveltejs/kit/vite';
/** @type {import('vite').UserConfig} */
const config = {
plugins: [sveltekit()],
+ optimizeDeps: { exclude: ['$app'] },
}}(see https://github.com/sveltejs/kit/pull/7933)
Bar Color
The progress bar does not have a default color, so you will need to set one. You can either set the color as a data property, as a text- class if you're using Tailwind/WindiCSS, or override the CSS.
Svelte component:
<!-- Set the CSS color through an attribute: -->
<ProgressBar color="#0366d6" />
<!-- Or, if you're using Tailwind/Windi: -->
<ProgressBar class="text-green-500" />Other Styles
If you are using some type of navbar at the top of the page, like Bootstrap's, it is likely that you will need to change the z-index to get the progress bar to appear over the navbar:
.svelte-progress-bar {
z-index: 100;
}
.svelte-progress-bar-leader {
z-index: 101;
}Options
You shouldn't need to play with these, they've been selected based on UX design expertise, but they're available if you need them:
minimum(number, range: 0-1, default: 0.08): The starting percent width use when the bar starts. Starting at0doesn't usually look very good.maximum(number, range: 0-1, default: 0.994): The maximum percent width value to use when the bar is at the end but not marked as complete. Letting the bar stay at 100% width for a while doesn't usually look very good either.intervalTime(number, default: 800): Milliseconds to wait between incrementing bar width when using thestart(auto-increment) method.settleTime(number, default: 700): Milliseconds to wait after thecompletemethod is called to hide the progress bar. Letting it sit at 100% width for a very short time makes it feel more fluid.
Methods
These additional methods are available on an instantiated progress bar:
start(): Set the width to the minimum and increment until maximum width.complete(): Set the width to100%and then hide aftersettleTime.reset(): Set the width to minimum but do not start incrementing.animate(): Start incrementing from whatever the current width is.stop(): Stop incrementing and take no further action.setWidthRatio(ratio: number): Stop auto-incrementing and manually specify the width.