Skip to content

Customizing Component

How to change loader progress

Method 1: Override the loader image and/or the progress percentage

vue
<template>
    <VPdfViewer src="https://raw.githubusercontent.com/mozilla/pdf.js/ba2edeae/web/compressed.tracemonkey-pldi-09.pdf">
    <template #loaderImage>
        <!-- you can use image or svg tag -->
        <svg width="40px" height="40px" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 200 200">
            <path
            fill="white"
            stroke="white"
            stroke-width="15"
            transform-origin="center"
            d="m148 84.7 13.8-8-10-17.3-13.8 8a50 50 0 0 0-27.4-15.9v-16h-20v16A50 50 0 0 0 63 67.4l-13.8-8-10 17.3 13.8 8a50 50 0 0 0 0 31.7l-13.8 8 10 17.3 13.8-8a50 50 0 0 0 27.5 15.9v16h20v-16a50 50 0 0 0 27.4-15.9l13.8 8 10-17.3-13.8-8a50 50 0 0 0 0-31.7Zm-47.5 50.8a35 35 0 1 1 0-70 35 35 0 0 1 0 70Z"
            ></path>
        </svg>
    </template>
    <template #loaderProgress="{ progress }">
        <div style="color: white">
        {{ progress }} % loading
        </div>
    </template>
    </VPdfViewer>
</template>

<style scoped>
/* to replace the default mask color */
:deep(.vpv-variables) {
    --vpv-loader-backdrop-color: #7862ff;
    /* if you want to change the animation, you may set the name of "--vpv-loader-animation-name" css variable */
}
:deep(.vpv-variables.vpv-variables__dark) {
    --vpv-loader-backdrop-color: white;
}
</style>

An image of a customized loader progress with a different icon and progress percentage

Method 2: Customize all elements of the progress loader

vue
<template>
    <VPdfViewer src="https://raw.githubusercontent.com/mozilla/pdf.js/ba2edeae/web/compressed.tracemonkey-pldi-09.pdf">
    <template #loader="{ loaded, progress }">
        <div v-if="!loaded" class="wrapper">
        {{ progress }}%
        </div>
    </template>
</VPdfViewer>
</template>
<style scoped>
    .wrapper {
    inset: 0;
    position: absolute;
    background: white;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    }
</style>

An image of a complete customization of the loader element with a simple text and percentage

How to add a custom language

If you wish to add a custom language, please do so by using the locale and localization props in the component:

vue
<VPdfViewer locale="customLang" :localization="{ customLang: { .... } }" />

It's important to note that the locale string must match the key in the localization object. Otherwise, it will fall back to en_US.