 2cbe1d1210
			
		
	
	2cbe1d1210
	
	
	
		
			
			* fix * navhookをbootに移動 * サーバーサイドのbootも分けるように * 埋め込みページかどうかの判定は最初の一回だけに * tooltipは出せるように * fix design * 埋め込み独自のtooltipを削除 * ロジックの分岐が多かったMkNoteDetailedを分離 * fix indent * プレビュー用iframeにフォーカスが当たるのを修正 * popupの制御を出す側で行うように * パラメータが逆になっていたのを修正 * Update MkEmbedCodeGenDialog.vue * fix * eliminate misskey-js lint warns * fix * add appropriate attributes to embed html * enhance: サーバーサイドのembed系をさらに分離 * enhance: embed routerを分離(route定義をboot時に変更できるようにする改修を含む) * type * lint * fix indent * server-side styleを完全に分離 * Revert "refactor: 画面サイズのしきい値をconstにまとめる" This reverts commit05ca36f400. * fix * revert all changes in base.pug * embedドメインをまとめた * embedドメインをまとめた * prevent calling contextmenu in embed page by stopping at the caller * fix import * fix import * improve directory structure * fix import * register timeline ui as a container * wa- * rename * wa- * Update EmMediaList.vue * Update EmMediaList.vue * Update EmMediaList.vue * Update EmMediaImage.vue * Update EmNote.vue * revert mkmedialist changes * 戻し漏れ * wip * tweak embed media ui * revert original media components * Update boot.embed.js * rename * wip * Update MkNote.vue * wip * Update MkSubNoteContent.vue * Update EmNote.vue * Update packages/frontend/src/router/definition.ts * Revert "Update packages/frontend/src/router/definition.ts" This reverts commit937ae44521. * refactor EmMediaImage * fix import * remove unused imports * Update router.ts * wip * Update boot.ts * wip * wip * wip * wip * Update EmNote.vue * Update EmNote.vue * Create EmA.vue * Create EmAvatar.vue * Update EmAvatar.vue * wip * wip * wip * Create EmImgWithBlurhash.vue * Update EmImgWithBlurhash.vue * Create EmPagination.vue * wip * Update boot.ts * wip * wip * wi@p * wip * wip * wiop * wip * wip * wip * wip * wip * wip * wip * wip * wip * wip * Update boot.ts * wip * Update MkMisskeyFlavoredMarkdown.ts * wip * wip * wip * wip * wip * Update post-message.ts * wip * Update EmNoteDetailed.vue * Update EmNoteDetailed.vue * Create instance.ts * Update EmNoteDetailed.vue * wip * Update EmNoteDetailed.vue * wip * wip * wip * Update pnpm-lock.yaml * wip * wip * wp * wip * Update ClientServerService.ts * wip * Update boot.ts * Update vite.config.local-dev.ts * Update vite.config.ts * Create index.html * wa- * wip * Update boot.ts * wip * wip * wip * wip * wip * wip * wip * wip * wip * Create EmLink.vue * Create EmMention.vue * Update EmMfm.ts * wip * wip * wip * wip * Update vite.config.ts * Update boot.ts * Update EmA.vue * うぃp * wip * wip * Create EmError.vue * wip * Update MkEmbedCodeGenDialog.vue * Update EmNote.vue * wip * wip * Update user-timeline.vue * Update check-spdx-license-id.yml * wip * wip * style(frontend-shared): lint fixes on build.js * fix(frontend-shared): include `*.{js,json}` files in js-built * wip * use alias * refactor * refactor * Update scroll.ts * refactor * refactor * refactor * wip * wip * wip * wip * Update roles.vue * Update branding.vue * wip * wip * wip * Update page.vue * wip * fix import * add missing css variables * 絵文字をtwemojiに変更 クライアントデフォルトにあわせるため * force empoll readonly * fix compiler error * fix broken imports * tweak button style * run api extractor * fix storybook theme preloads * fix storybook instance imports * Update preview.ts * Update preview.ts * Update preview.ts * Revert "Update preview.ts" This reverts commit12bab1c6fb. * Revert "Update preview.ts" This reverts commit5c0ce01dbd. * Revert "Update preview.ts" This reverts commitf4863524d7. * Revert "fix storybook instance imports" This reverts commited8eabb246. * Revert "wip" This reverts commitd3c1926519. * Revert "Update page.vue" This reverts commit27c7900b0c. * Revert "Update branding.vue" This reverts commitc08ccb65ba. * Revert "Update roles.vue" This reverts commit1488b67066. * Revert "wip" This reverts commitaab1c76981. * refactor: use common media proxy * fix imports * fix * fix: MediaProxyの初期化を保証する(storybook対策?) * enhance(frontend-embed): improve embedParams provide * fix(backend): MK_DEV_PREFER=backendのときにembed viteが読み込めないのを修正 * fix * embed-pageを共通化 * fix import * fix import * fix import * const.jsを共通化 (たぶんrevertしすぎた) * fix type error * fix duplicated import * fix lint * fix * コメントとして残す * sharedとembedをlint対象にする * lint * attempt to fix eslint (frontend-shared) * lint fixes --------- Co-authored-by: syuilo <4439005+syuilo@users.noreply.github.com> Co-authored-by: zyoshoka <107108195+zyoshoka@users.noreply.github.com>
		
			
				
	
	
		
			157 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			157 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import path from 'path';
 | ||
| import pluginVue from '@vitejs/plugin-vue';
 | ||
| import { type UserConfig, defineConfig } from 'vite';
 | ||
| 
 | ||
| import locales from '../../locales/index.js';
 | ||
| import meta from '../../package.json';
 | ||
| import packageInfo from './package.json' with { type: 'json' };
 | ||
| import pluginJson5 from './vite.json5.js';
 | ||
| 
 | ||
| const extensions = ['.ts', '.tsx', '.js', '.jsx', '.mjs', '.json', '.json5', '.svg', '.sass', '.scss', '.css', '.vue'];
 | ||
| 
 | ||
| /**
 | ||
|  * Misskeyのフロントエンドにバンドルせず、CDNなどから別途読み込むリソースを記述する。
 | ||
|  * CDNを使わずにバンドルしたい場合、以下の配列から該当要素を削除orコメントアウトすればOK
 | ||
|  */
 | ||
| const externalPackages = [
 | ||
| 	// shiki(コードブロックのシンタックスハイライトで使用中)はテーマ・言語の定義の容量が大きいため、それらはCDNから読み込む
 | ||
| 	{
 | ||
| 		name: 'shiki',
 | ||
| 		match: /^shiki\/(?<subPkg>(langs|themes))$/,
 | ||
| 		path(id: string, pattern: RegExp): string {
 | ||
| 			const match = pattern.exec(id)?.groups;
 | ||
| 			return match
 | ||
| 				? `https://esm.sh/shiki@${packageInfo.dependencies.shiki}/${match['subPkg']}`
 | ||
| 				: id;
 | ||
| 		},
 | ||
| 	},
 | ||
| ];
 | ||
| 
 | ||
| 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: '/embed_vite/',
 | ||
| 
 | ||
| 		server: {
 | ||
| 			port: 5174,
 | ||
| 		},
 | ||
| 
 | ||
| 		plugins: [
 | ||
| 			pluginVue(),
 | ||
| 			pluginJson5(),
 | ||
| 		],
 | ||
| 
 | ||
| 		resolve: {
 | ||
| 			extensions,
 | ||
| 			alias: {
 | ||
| 				'@/': __dirname + '/src/',
 | ||
| 				'@@/': __dirname + '/../frontend-shared/',
 | ||
| 				'/client-assets/': __dirname + '/assets/',
 | ||
| 				'/static-assets/': __dirname + '/../backend/assets/'
 | ||
| 			},
 | ||
| 		},
 | ||
| 
 | ||
| 		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:'),
 | ||
| 			__VUE_OPTIONS_API__: false,
 | ||
| 			__VUE_PROD_DEVTOOLS__: false,
 | ||
| 		},
 | ||
| 
 | ||
| 		build: {
 | ||
| 			target: [
 | ||
| 				'chrome116',
 | ||
| 				'firefox116',
 | ||
| 				'safari16',
 | ||
| 			],
 | ||
| 			manifest: 'manifest.json',
 | ||
| 			rollupOptions: {
 | ||
| 				input: {
 | ||
| 					app: './src/boot.ts',
 | ||
| 				},
 | ||
| 				external: externalPackages.map(p => p.match),
 | ||
| 				output: {
 | ||
| 					manualChunks: {
 | ||
| 						vue: ['vue'],
 | ||
| 					},
 | ||
| 					chunkFileNames: process.env.NODE_ENV === 'production' ? '[hash:8].js' : '[name]-[hash:8].js',
 | ||
| 					assetFileNames: process.env.NODE_ENV === 'production' ? '[hash:8][extname]' : '[name]-[hash:8][extname]',
 | ||
| 					paths(id) {
 | ||
| 						for (const p of externalPackages) {
 | ||
| 							if (p.match.test(id)) {
 | ||
| 								return p.path(id, p.match);
 | ||
| 							}
 | ||
| 						}
 | ||
| 
 | ||
| 						return id;
 | ||
| 					},
 | ||
| 				},
 | ||
| 			},
 | ||
| 			cssCodeSplit: true,
 | ||
| 			outDir: __dirname + '/../../built/_frontend_embed_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/],
 | ||
| 			},
 | ||
| 		},
 | ||
| 
 | ||
| 		worker: {
 | ||
| 			format: 'es',
 | ||
| 		},
 | ||
| 	};
 | ||
| }
 | ||
| 
 | ||
| const config = defineConfig(({ command, mode }) => getConfig());
 | ||
| 
 | ||
| export default config;
 |