* build(#10336): init
* fix(#10336): invalid name conversion
* build(#10336): load locales and vite config
* refactor(#10336): remove unused imports
* build(#10336): separate definitions and generated codes
* refactor(#10336): remove hatches
* refactor(#10336): module semantics
* refactor(#10336): remove unused common preferences
* fix: typo
* build(#10336): mock assets
* build(#10336): impl `SatisfiesExpression`
* build(#10336): control themes
* refactor(#10336): semantics
* build(#10336): make .storybook as an individual TypeScript project
* style(#10336): use single quote
* build(#10336): avoid intrinsic component names
* chore: suppress linter
* style: typing
* build(#10336): update dependencies
* docs: note about Storybook
* build(#10336): sync
* build(#10336): full reload server on change
* chore: use defaultStore instead
* build(#10336): show popups on Story
* refactor(#10336): remove redundant div
* docs: fix
* build(#10336): interactions
* build(#10336): add an interaction test for `<MkA/>`
* build(#10336): bump storybook
* docs(#10336): mention to pre-build misskey-js
* build(#10336): write stories for `MkAcct`
* build(#10336): write stories for `MkAd`
* build(#10336): fix missing type definition
* build(#10336): use `toHaveTextContent`
* build(#10336): write some stories
* build(#10336): hide internal args
* build(#10336): generate `components/global` stories only
* build(#10336): write stories for `MkMisskeyFlavoredMarkdown`
* fix: conflict errors
* build(#10336): subcomponents on sidebar
* refactor: restore `SatisfiesExpression`
* docs(#10336): note development status
* build(#10336): use chokidar-cli
* docs(#10336): note chokidar-cli mode
* chore(#10336): untrack generated stories files
* fix: pointer handling
* build(#10336): finalize
* chore: add static option to `MkLoading`
* refactor(#10336): bind to local args
* fix: missing case
* revert: restore `SatisfiesExpression`
This reverts commit f246699f38.
* build(#10336): make storybook buildable
* build(#10336): staticify assets
* build(#10336): staticified directory structure
* build(#10336): normalize path for Windows
* ci(#10336): create actions
* build(#10336): ignore tsc errors
* build(#10336): ignore tsc errors
* build(#10336): missing dependencies
* build(#10336): missing dependencies
* build(#10336): use fast-glob
* fix: invalid lockfile
* ci(#10336): increase heap size
* build(#10336): use unpkg for storybook tabler icons
* build(#10336): use unpkg for storybook twemojis
* build(#10336): disable `ProfilePageCat`
* build(#10336): blur `MkA` before interaction ends
* ci(#10336): stabilize
* ci(#10336): fetch-depth
* build(#10336): isChromatic
* ci(#10336): notify on changes
* ci(#10336): fix typo
* ci(#10336): missing working directory
* ci(#10336): skip build
* ci(#10336): fix path
* build(#10336): fails on Windows
* build(#10336): available on Windows
* ci(#10336): disable animation on chromatic
* ci(#10336): add static option to `PageHeader.tabs`
* chore: void
* ci(#10336): change parameters
* docs(#10336): update CONTRIBUTING
* docs(#10336): note about meta overriding and etc.
* ci(#10336): use Chromatic for checks
* ci(#10336): use `pull_request` instead of `pull_request_target` for now
* ci(#10336): use `exitOnceUploaded`
* ci(#10336): reuse built storybook
* ci(#10336): back to `pull_request_target`
* chore: unused dependencies
* style(#10336): reduce prettier indents
* style: note about `TSSatisfiesExpression`
		
	
		
			
				
	
	
		
			139 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			139 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import path from 'path';
 | 
						|
import pluginVue from '@vitejs/plugin-vue';
 | 
						|
import { type UserConfig, defineConfig } from 'vite';
 | 
						|
 | 
						|
import locales from '../../locales';
 | 
						|
import meta from '../../package.json';
 | 
						|
import pluginJson5 from './vite.json5';
 | 
						|
 | 
						|
const extensions = ['.ts', '.tsx', '.js', '.jsx', '.mjs', '.json', '.json5', '.svg', '.sass', '.scss', '.css', '.vue'];
 | 
						|
 | 
						|
const hash = (str: string, seed = 0): number => {
 | 
						|
	let h1 = 0xdeadbeef ^ seed,
 | 
						|
		h2 = 0x41c6ce57 ^ seed;
 | 
						|
	for (let i = 0, ch; i < str.length; i++) {
 | 
						|
		ch = str.charCodeAt(i);
 | 
						|
		h1 = Math.imul(h1 ^ ch, 2654435761);
 | 
						|
		h2 = Math.imul(h2 ^ ch, 1597334677);
 | 
						|
	}
 | 
						|
 | 
						|
	h1 = Math.imul(h1 ^ (h1 >>> 16), 2246822507) ^ Math.imul(h2 ^ (h2 >>> 13), 3266489909);
 | 
						|
	h2 = Math.imul(h2 ^ (h2 >>> 16), 2246822507) ^ Math.imul(h1 ^ (h1 >>> 13), 3266489909);
 | 
						|
 | 
						|
	return 4294967296 * (2097151 & h2) + (h1 >>> 0);
 | 
						|
};
 | 
						|
 | 
						|
const BASE62_DIGITS = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
 | 
						|
function toBase62(n: number): string {
 | 
						|
	if (n === 0) {
 | 
						|
		return '0';
 | 
						|
	}
 | 
						|
	let result = '';
 | 
						|
	while (n > 0) {
 | 
						|
		result = BASE62_DIGITS[n % BASE62_DIGITS.length] + result;
 | 
						|
		n = Math.floor(n / BASE62_DIGITS.length);
 | 
						|
	}
 | 
						|
 | 
						|
	return result;
 | 
						|
}
 | 
						|
 | 
						|
export function getConfig(): UserConfig {
 | 
						|
	return {
 | 
						|
		base: '/vite/',
 | 
						|
 | 
						|
		plugins: [
 | 
						|
			pluginVue({
 | 
						|
				reactivityTransform: true,
 | 
						|
			}),
 | 
						|
			pluginJson5(),
 | 
						|
		],
 | 
						|
 | 
						|
		resolve: {
 | 
						|
			extensions,
 | 
						|
			alias: {
 | 
						|
				'@/': __dirname + '/src/',
 | 
						|
				'/client-assets/': __dirname + '/assets/',
 | 
						|
				'/static-assets/': __dirname + '/../backend/assets/',
 | 
						|
				'/fluent-emojis/': __dirname + '/../../fluent-emojis/dist/',
 | 
						|
				'/fluent-emoji/': __dirname + '/../../fluent-emojis/dist/',
 | 
						|
			},
 | 
						|
		},
 | 
						|
 | 
						|
		css: {
 | 
						|
			modules: {
 | 
						|
				generateScopedName(name, filename, _css): string {
 | 
						|
					const id = (path.relative(__dirname, filename.split('?')[0]) + '-' + name).replace(/[\\\/\.\?&=]/g, '-').replace(/(src-|vue-)/g, '');
 | 
						|
					if (process.env.NODE_ENV === 'production') {
 | 
						|
						return 'x' + toBase62(hash(id)).substring(0, 4);
 | 
						|
					} else {
 | 
						|
						return id;
 | 
						|
					}
 | 
						|
				},
 | 
						|
			},
 | 
						|
		},
 | 
						|
 | 
						|
		define: {
 | 
						|
			_VERSION_: JSON.stringify(meta.version),
 | 
						|
			_LANGS_: JSON.stringify(Object.entries(locales).map(([k, v]) => [k, v._lang_])),
 | 
						|
			_ENV_: JSON.stringify(process.env.NODE_ENV),
 | 
						|
			_DEV_: process.env.NODE_ENV !== 'production',
 | 
						|
			_PERF_PREFIX_: JSON.stringify('Misskey:'),
 | 
						|
			_DATA_TRANSFER_DRIVE_FILE_: JSON.stringify('mk_drive_file'),
 | 
						|
			_DATA_TRANSFER_DRIVE_FOLDER_: JSON.stringify('mk_drive_folder'),
 | 
						|
			_DATA_TRANSFER_DECK_COLUMN_: JSON.stringify('mk_deck_column'),
 | 
						|
			__VUE_OPTIONS_API__: true,
 | 
						|
			__VUE_PROD_DEVTOOLS__: false,
 | 
						|
		},
 | 
						|
 | 
						|
		// https://vitejs.dev/guide/dep-pre-bundling.html#monorepos-and-linked-dependencies
 | 
						|
		optimizeDeps: {
 | 
						|
			include: ['misskey-js'],
 | 
						|
		},
 | 
						|
 | 
						|
		build: {
 | 
						|
			target: [
 | 
						|
				'chrome108',
 | 
						|
				'firefox109',
 | 
						|
				'safari16',
 | 
						|
			],
 | 
						|
			manifest: 'manifest.json',
 | 
						|
			rollupOptions: {
 | 
						|
				input: {
 | 
						|
					app: './src/init.ts',
 | 
						|
				},
 | 
						|
				output: {
 | 
						|
					manualChunks: {
 | 
						|
						vue: ['vue'],
 | 
						|
						photoswipe: ['photoswipe', 'photoswipe/lightbox', 'photoswipe/style.css'],
 | 
						|
					},
 | 
						|
				},
 | 
						|
			},
 | 
						|
			cssCodeSplit: true,
 | 
						|
			outDir: __dirname + '/../../built/_vite_',
 | 
						|
			assetsDir: '.',
 | 
						|
			emptyOutDir: false,
 | 
						|
			sourcemap: process.env.NODE_ENV === 'development',
 | 
						|
			reportCompressedSize: false,
 | 
						|
 | 
						|
			// https://vitejs.dev/guide/dep-pre-bundling.html#monorepos-and-linked-dependencies
 | 
						|
			commonjsOptions: {
 | 
						|
				include: [/misskey-js/, /node_modules/],
 | 
						|
			},
 | 
						|
		},
 | 
						|
 | 
						|
		test: {
 | 
						|
			environment: 'happy-dom',
 | 
						|
			deps: {
 | 
						|
				inline: [
 | 
						|
					// XXX: misskey-dev/browser-image-resizer has no "type": "module"
 | 
						|
					'browser-image-resizer',
 | 
						|
				],
 | 
						|
			},
 | 
						|
		},
 | 
						|
	};
 | 
						|
}
 | 
						|
 | 
						|
const config = defineConfig(({ command, mode }) => getConfig());
 | 
						|
 | 
						|
export default config;
 |