123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184 |
- import { defineConfig } from 'vite';
- import vue from '@vitejs/plugin-vue';
- import vueJsx from '@vitejs/plugin-vue-jsx';
- import Components from 'unplugin-vue-components/vite';
- import { NaiveUiResolver } from 'unplugin-vue-components/resolvers';
- import legacyPlugin from '@vitejs/plugin-legacy';
- import { VitePWA } from 'vite-plugin-pwa';
- import px2rem from 'postcss-px2rem';
- import versionUpdatePlugin from './src/plugins/version';
- const postcss = px2rem({
-
- remUnit: 16
- });
- const path = require('path');
- function resolve(dir: string) {
- return path.join(__dirname, dir);
- }
- const proxyUrl = 'https://dev.kt.colexiu.com/';
- const now = new Date().getTime();
- export default defineConfig(() => {
- return {
- base: './',
- plugins: [
- vue(),
- vueJsx(),
-
- Components({
- dts: true,
- resolvers: [NaiveUiResolver()]
- }),
- legacyPlugin({
- targets: ['defaults', 'not IE 11'],
- additionalLegacyPolyfills: ['regenerator-runtime/runtime'],
- renderLegacyChunks: true,
- polyfills: [
- 'es.symbol',
- 'es.promise',
- 'es.promise.finally',
- 'es/map',
- 'es/set',
- 'es.array.filter',
- 'es.array.for-each',
- 'es.array.flat-map',
- 'es.object.define-properties',
- 'es.object.define-property',
- 'es.object.get-own-property-descriptor',
- 'es.object.get-own-property-descriptors',
- 'es.object.keys',
- 'es.object.to-string',
- 'web.dom-collections.for-each',
- 'esnext.global-this',
- 'esnext.string.match-all'
- ]
- }),
- VitePWA({
- injectRegister: 'auto',
- registerType: 'autoUpdate',
- includeAssets: ['./logo.png'],
- workbox: {
- skipWaiting: true,
- clientsClaim: true,
- runtimeCaching: [
- {
- urlPattern: ({ url }) =>
- url.origin === 'https://dev.kt.colexiu.com',
- handler: 'NetworkFirst',
- options: {
- cacheName: 'api-cache'
- }
- }
- ]
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- },
- manifest: {
- name: '酷乐秀-音乐数字课堂',
- short_name: '音乐数字课堂',
- theme_color: '#E8EAED',
- display: 'fullscreen',
- icons: [
- {
- src: './logo.png',
- sizes: '192x192',
- type: 'image/png'
- },
- {
- src: './logo.png',
- sizes: '512x512',
- type: 'image/png'
- },
- {
- src: './logo.png',
- sizes: '512x512',
- type: 'image/png',
- purpose: 'any maskable'
- }
- ],
- prefer_related_applications: false,
- related_applications: [
- {
- platform: 'webapp',
- id: '1.0.0',
- url: './manifest.webmanifest'
- }
- ]
- },
- devOptions: {
- enabled: true
- }
- }),
- versionUpdatePlugin({
- version: now
- })
- ],
- define: {
-
- __APP_VERSION__: now
- },
- build: {
- target: 'es2015',
- rollupOptions: {
- output: {
- entryFileNames: `[name]-[hash]-${now}.js`,
- chunkFileNames: `[name]-[hash]-${now}.js`,
- assetFileNames: `[name]-[hash].[ext]`
- }
- }
- },
- resolve: {
- alias: {
- '@': resolve('./src'),
- '@common': resolve('./src/common'),
- '@components': resolve('./src/components'),
- '@store': resolve('./src/store'),
- '@views': resolve('./src/views')
- }
- },
- server: {
- host: '0.0.0.0',
- port: 5005,
- strictPort: true,
- cors: true,
- https: false,
- proxy: {
- '/edu-app': {
- target: proxyUrl,
- changeOrigin: true
- }
- }
- }
- };
- });
|