Files
inkclip/webapp/vite.config.ts
T
2026-01-15 21:24:16 -04:00

60 lines
1.3 KiB
TypeScript

/// <reference types="node" />
import { resolve } from 'path'
import { svelte } from '@sveltejs/vite-plugin-svelte'
import tailwindcss from '@tailwindcss/vite'
import icons from 'unplugin-icons/vite'
import { defineConfig } from 'vite'
import { ManifestOptions, VitePWA as pwa } from 'vite-plugin-pwa'
const manifest: Partial<ManifestOptions> = {
name: 'Write to Inkclip',
short_name: 'Inkclip',
description: 'Utility for writing patterns to the “Inkclip” e-paper accessory.',
categories: ['utilities'],
display: 'standalone',
background_color: '#0c0a09',
icons: [
{
src: 'icon-64.png',
sizes: '64x64',
type: 'image/png',
},
{
src: 'icon-192.png',
sizes: '192x192',
type: 'image/png',
},
{
src: 'icon-512.png',
sizes: '512x512',
type: 'image/png',
},
{
src: 'icon-512.png',
sizes: '512x512',
type: 'image/png',
purpose: 'maskable',
},
],
}
// https://vite.dev/config/
export default defineConfig({
plugins: [
icons({ compiler: 'svelte' }),
tailwindcss(),
pwa({
registerType: 'autoUpdate',
workbox: { globPatterns: ['**/*.{js,css,html,svg,png,ico,woff2}'] },
manifest,
devOptions: { enabled: true },
}),
svelte(),
],
resolve: {
alias: {
$lib: resolve('./src/lib'),
},
},
})