2023-01-14 02:10:41 +00:00
|
|
|
|
import path from 'path';
|
2023-04-13 14:23:11 +00:00
|
|
|
|
import pluginReplace from '@rollup/plugin-replace';
|
2024-06-21 14:51:57 +00:00
|
|
|
|
import type { RollupReplaceOptions } from '@rollup/plugin-replace';
|
2022-05-01 13:51:07 +00:00
|
|
|
|
import pluginVue from '@vitejs/plugin-vue';
|
2023-04-04 00:38:34 +00:00
|
|
|
|
import { type UserConfig, defineConfig } from 'vite';
|
2022-05-01 13:51:07 +00:00
|
|
|
|
|
2023-12-24 07:16:58 +00:00
|
|
|
|
import locales from '../../locales/index.js';
|
2022-05-01 13:51:07 +00:00
|
|
|
|
import meta from '../../package.json';
|
2024-03-20 01:30:45 +00:00
|
|
|
|
import packageInfo from './package.json' assert { type: 'json' };
|
2023-12-24 07:16:58 +00:00
|
|
|
|
import pluginUnwindCssModuleClassName from './lib/rollup-plugin-unwind-css-module-class-name.js';
|
|
|
|
|
import pluginJson5 from './vite.json5.js';
|
2022-05-01 13:51:07 +00:00
|
|
|
|
|
2024-03-14 11:41:24 +00:00
|
|
|
|
const extensions = ['.ts', '.tsx', '.js', '.jsx', '.mjs', '.json', '.json5', '.svg', '.sass', '.scss', '.css', '.vue', '.wasm'];
|
2022-05-01 13:51:07 +00:00
|
|
|
|
|
2024-03-20 01:30:45 +00:00
|
|
|
|
/**
|
|
|
|
|
* 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;
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
];
|
|
|
|
|
|
2023-01-09 23:39:19 +00:00
|
|
|
|
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);
|
|
|
|
|
}
|
2023-03-09 03:48:39 +00:00
|
|
|
|
|
2023-01-09 23:39:19 +00:00
|
|
|
|
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);
|
2023-03-09 03:48:39 +00:00
|
|
|
|
|
2023-01-09 23:39:19 +00:00
|
|
|
|
return 4294967296 * (2097151 & h2) + (h1 >>> 0);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const BASE62_DIGITS = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
|
2023-12-24 07:16:58 +00:00
|
|
|
|
|
2023-01-09 23:39:19 +00:00
|
|
|
|
function toBase62(n: number): string {
|
|
|
|
|
if (n === 0) {
|
|
|
|
|
return '0';
|
|
|
|
|
}
|
2023-03-09 03:48:39 +00:00
|
|
|
|
let result = '';
|
2023-01-09 23:39:19 +00:00
|
|
|
|
while (n > 0) {
|
|
|
|
|
result = BASE62_DIGITS[n % BASE62_DIGITS.length] + result;
|
|
|
|
|
n = Math.floor(n / BASE62_DIGITS.length);
|
|
|
|
|
}
|
2023-03-09 03:48:39 +00:00
|
|
|
|
|
2023-01-09 23:39:19 +00:00
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
2024-06-21 14:51:57 +00:00
|
|
|
|
function iconsReplace(opts: RollupReplaceOptions) {
|
|
|
|
|
return pluginReplace({
|
|
|
|
|
...opts,
|
|
|
|
|
preventAssignment: false,
|
2024-06-21 15:53:54 +00:00
|
|
|
|
// only replace these strings at the start of strings, remove a
|
|
|
|
|
// `ti-fw` it if happens to be just after, and make sure they're
|
2024-06-21 14:51:57 +00:00
|
|
|
|
// followed by a word-boundary that's not a dash
|
2024-06-21 15:53:54 +00:00
|
|
|
|
delimiters: ['(?<=["\'`])', '(?: ti-fw)?\\b(?!-)'],
|
2024-06-21 14:51:57 +00:00
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2023-04-04 00:38:34 +00:00
|
|
|
|
export function getConfig(): UserConfig {
|
2022-05-01 13:51:07 +00:00
|
|
|
|
return {
|
2022-12-20 04:05:36 +00:00
|
|
|
|
base: '/vite/',
|
2022-05-01 13:51:07 +00:00
|
|
|
|
|
2023-05-06 01:25:15 +00:00
|
|
|
|
server: {
|
|
|
|
|
port: 5173,
|
|
|
|
|
},
|
|
|
|
|
|
2022-05-01 13:51:07 +00:00
|
|
|
|
plugins: [
|
2023-12-07 05:42:09 +00:00
|
|
|
|
pluginVue(),
|
2023-06-01 08:19:46 +00:00
|
|
|
|
pluginUnwindCssModuleClassName(),
|
2022-05-01 13:51:07 +00:00
|
|
|
|
pluginJson5(),
|
2024-06-21 14:52:22 +00:00
|
|
|
|
iconsReplace({
|
|
|
|
|
values: {
|
|
|
|
|
'ti ti-alert-triangle': 'ph-warning ph-bold ph-lg',
|
|
|
|
|
},
|
|
|
|
|
exclude: [
|
|
|
|
|
'**/components/MkAnnouncementDialog.*',
|
|
|
|
|
'**/pages/announcement.*',
|
|
|
|
|
],
|
|
|
|
|
}),
|
|
|
|
|
iconsReplace({
|
|
|
|
|
values: {
|
|
|
|
|
'ti ti-alert-triangle': 'ph-warning-circle ph-bold ph-lg',
|
|
|
|
|
},
|
|
|
|
|
include: [
|
|
|
|
|
'**/components/MkAnnouncementDialog.*',
|
|
|
|
|
'**/pages/announcement.*',
|
|
|
|
|
],
|
|
|
|
|
}),
|
2024-06-21 15:00:35 +00:00
|
|
|
|
iconsReplace({
|
|
|
|
|
values: {
|
|
|
|
|
'ti ti-reload': 'ph-arrow-clockwise ph-bold ph-lg',
|
|
|
|
|
},
|
|
|
|
|
exclude: [
|
|
|
|
|
'**/pages/settings/emoji-picker.*',
|
|
|
|
|
'**/pages/flash/flash.*',
|
|
|
|
|
],
|
|
|
|
|
}),
|
|
|
|
|
iconsReplace({
|
|
|
|
|
values: {
|
|
|
|
|
'ti ti-reload': 'ph-arrow-counter-clockwise ph-bold ph-lg',
|
|
|
|
|
},
|
|
|
|
|
include: [
|
|
|
|
|
'**/pages/settings/emoji-picker.*',
|
|
|
|
|
],
|
|
|
|
|
}),
|
|
|
|
|
iconsReplace({
|
|
|
|
|
values: {
|
|
|
|
|
'ti ti-reload': 'ph-arrows-clockwise ph-bold ph-lg',
|
|
|
|
|
},
|
|
|
|
|
include: [
|
|
|
|
|
'**/pages/flash/flash.*',
|
|
|
|
|
],
|
|
|
|
|
}),
|
2024-06-21 15:19:13 +00:00
|
|
|
|
iconsReplace({
|
2024-06-21 11:24:04 +00:00
|
|
|
|
values: {
|
|
|
|
|
'ti ti-terminal-2': 'ph-terminal-window ph-bold ph-lg',
|
2024-06-21 11:32:48 +00:00
|
|
|
|
'ti ti-download': 'ph-download ph-bold ph-lg',
|
2024-06-21 11:38:50 +00:00
|
|
|
|
'ti ti-circle-x': 'ph-x-circle ph-bold ph-lg',
|
2024-06-21 11:42:33 +00:00
|
|
|
|
'ti ti-plus': 'ph-plus ph-bold ph-lg',
|
2024-06-21 11:49:30 +00:00
|
|
|
|
'ti ti-planet': 'ph-planet ph-bold ph-lg',
|
|
|
|
|
'ti ti-world-x': 'ph-planet ph-bold ph-lg',
|
|
|
|
|
'ti ti-world-search': 'ph-planet ph-bold ph-lg',
|
2024-06-21 11:57:35 +00:00
|
|
|
|
'ti ti-chevron-right': 'ph-caret-right ph-bold ph-lg',
|
|
|
|
|
'ti ti-chevrons-right': 'ph-caret-right ph-bold ph-lg',
|
2024-06-21 12:04:54 +00:00
|
|
|
|
'ti ti-dots': 'ph-dots-three ph-bold ph-lg',
|
2024-06-21 12:09:24 +00:00
|
|
|
|
'ti ti-check': 'ph-check ph-bold ph-lg',
|
2024-06-21 12:13:02 +00:00
|
|
|
|
'ti ti-device-floppy': 'ph-floppy-disk ph-bold ph-lg',
|
2024-06-21 12:20:42 +00:00
|
|
|
|
'ti ti-shield': 'ph-shield ph-bold ph-lg',
|
|
|
|
|
'ti ti-shield-lock': 'ph-shield ph-bold ph-lg',
|
2024-06-21 12:23:23 +00:00
|
|
|
|
'ti ti-confetti': 'ph-confetti ph-bold ph-lg',
|
2024-06-21 12:28:16 +00:00
|
|
|
|
'ti ti-home': 'ph-house ph-bold ph-lg',
|
2024-06-21 12:30:42 +00:00
|
|
|
|
'ti ti-clock': 'ph-clock ph-bold ph-lg',
|
2024-06-21 12:44:45 +00:00
|
|
|
|
'ti ti-pencil': 'ph-pencil-simple ph-bold ph-lg',
|
2024-06-21 13:27:32 +00:00
|
|
|
|
'ti ti-arrow-right': 'ph-arrow-right ph-bold ph-lg',
|
2024-06-21 13:30:40 +00:00
|
|
|
|
'ti ti-pin': 'ph-push-pin ph-bold ph-lg',
|
2024-06-21 13:38:16 +00:00
|
|
|
|
'ti ti-heart': 'ph-heart ph-bold ph-lg',
|
|
|
|
|
'ti ti-heart-filled': 'ph-heart ph-bold ph-lg',
|
|
|
|
|
'ti ti-heart-plus': 'ph-heart ph-bold ph-lg',
|
2024-06-21 13:40:19 +00:00
|
|
|
|
'ti ti-arrow-left': 'ph-arrow-left ph-bold ph-lg',
|
2024-06-21 13:42:59 +00:00
|
|
|
|
'ti ti-settings': 'ph-gear ph-bold ph-lg',
|
2024-06-21 13:48:54 +00:00
|
|
|
|
'ti ti-link': 'ph-link ph-bold ph-lg',
|
2024-06-21 13:54:06 +00:00
|
|
|
|
'ti ti-key': 'ph-key ph-bold ph-lg',
|
2024-06-21 13:59:21 +00:00
|
|
|
|
'ti ti-code': 'ph-code ph-bold ph-lg',
|
2024-06-21 14:02:54 +00:00
|
|
|
|
'ti ti-star': 'ph-star ph-bold ph-lg',
|
2024-06-21 14:08:38 +00:00
|
|
|
|
'ti ti-eye': 'ph-eye ph-bold ph-lg',
|
2024-06-21 14:21:11 +00:00
|
|
|
|
'ti ti-eye-off': 'ti ti-eye-exclamation',
|
|
|
|
|
'ti ti-eye-exclamation': 'ph-eye-slash ph-bold ph-lg',
|
2024-06-21 14:25:18 +00:00
|
|
|
|
'ti ti-lock': 'ph-lock ph-bold ph-lg',
|
2024-06-21 15:19:13 +00:00
|
|
|
|
'ti ti-users': 'ph-users ph-bold ph-lg',
|
2024-06-21 15:24:29 +00:00
|
|
|
|
'ti ti-exclamation-circle': 'ph-warning-circle ph-bold ph-lg',
|
|
|
|
|
'ti ti-user-exclamation': 'ph-warning-circle ph-bold ph-lg',
|
2024-06-21 15:27:36 +00:00
|
|
|
|
'ti ti-info-circle': 'ph-info ph-bold ph-lg',
|
2024-06-21 15:33:05 +00:00
|
|
|
|
'ti ti-checklist': 'ph-list-checks ph-bold ph-lg',
|
2024-06-21 15:36:34 +00:00
|
|
|
|
'ti ti-plane-departure': 'ph-airplane-takeoff ph-bold ph-lg',
|
2024-06-21 15:39:29 +00:00
|
|
|
|
'ti ti-minus': 'ph-minus ph-bold ph-lg',
|
2024-06-21 15:41:02 +00:00
|
|
|
|
'ti ti-device-tv': 'ph-television ph-bold ph-lg',
|
2024-06-21 15:42:45 +00:00
|
|
|
|
'ti ti-cookie': 'ph-cookie ph-bold ph-lg',
|
2024-06-21 15:44:52 +00:00
|
|
|
|
'ti ti-copy': 'ph-copy ph-bold ph-lg',
|
2024-06-21 15:53:54 +00:00
|
|
|
|
'ti ti-chevron-up': 'ph-caret-up ph-bold ph-lg',
|
2024-06-21 15:58:33 +00:00
|
|
|
|
'ti ti-chevron-down': 'ph-caret-down ph-bold ph-lg',
|
|
|
|
|
'ti ti-caret-down': 'ph-caret-down ph-bold ph-lg',
|
2024-06-21 16:00:46 +00:00
|
|
|
|
'ti ti-help-circle': 'ph-question ph-bold ph-lg',
|
2024-06-21 16:02:50 +00:00
|
|
|
|
'ti ti-x': 'ph-x ph-bold ph-lg',
|
2024-06-21 16:05:25 +00:00
|
|
|
|
'ti ti-folder': 'ph-folder ph-bold ph-lg',
|
2024-06-21 16:07:52 +00:00
|
|
|
|
'ti ti-folder-plus': 'ph-folder-plus ph-bold ph-lg',
|
2024-06-21 16:08:40 +00:00
|
|
|
|
'ti ti-app-window': 'ph-app-window ph-bold ph-lg',
|
2024-06-21 16:12:57 +00:00
|
|
|
|
'ti ti-forms': 'ph-textbox ph-bold ph-lg',
|
2024-06-21 11:24:04 +00:00
|
|
|
|
},
|
|
|
|
|
}),
|
2023-04-13 14:23:11 +00:00
|
|
|
|
...process.env.NODE_ENV === 'production'
|
|
|
|
|
? [
|
|
|
|
|
pluginReplace({
|
|
|
|
|
preventAssignment: true,
|
|
|
|
|
values: {
|
|
|
|
|
'isChromatic()': JSON.stringify(false),
|
|
|
|
|
},
|
|
|
|
|
}),
|
|
|
|
|
]
|
|
|
|
|
: [],
|
2022-05-01 13:51:07 +00:00
|
|
|
|
],
|
|
|
|
|
|
|
|
|
|
resolve: {
|
|
|
|
|
extensions,
|
|
|
|
|
alias: {
|
|
|
|
|
'@/': __dirname + '/src/',
|
|
|
|
|
'/client-assets/': __dirname + '/assets/',
|
|
|
|
|
'/static-assets/': __dirname + '/../backend/assets/',
|
2023-01-22 12:25:55 +00:00
|
|
|
|
'/fluent-emojis/': __dirname + '/../../fluent-emojis/dist/',
|
2024-01-04 19:42:25 +00:00
|
|
|
|
'/tossface/': __dirname + '/../../tossface-emojis/dist/',
|
2023-01-22 12:25:55 +00:00
|
|
|
|
'/fluent-emoji/': __dirname + '/../../fluent-emojis/dist/',
|
2022-05-01 13:51:07 +00:00
|
|
|
|
},
|
2023-01-09 23:39:19 +00:00
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
css: {
|
|
|
|
|
modules: {
|
2023-04-04 00:38:34 +00:00
|
|
|
|
generateScopedName(name, filename, _css): string {
|
2023-01-16 04:59:14 +00:00
|
|
|
|
const id = (path.relative(__dirname, filename.split('?')[0]) + '-' + name).replace(/[\\\/\.\?&=]/g, '-').replace(/(src-|vue-)/g, '');
|
2023-10-17 22:41:41 +00:00
|
|
|
|
const shortId = id.replace(/^(components(-global)?|widgets|ui(-_common_)?)-/, '');
|
|
|
|
|
return shortId + '-' + toBase62(hash(id)).substring(0, 4);
|
2023-01-09 23:39:19 +00:00
|
|
|
|
},
|
|
|
|
|
},
|
2022-05-01 13:51:07 +00:00
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
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'),
|
2023-05-14 04:23:25 +00:00
|
|
|
|
__VUE_OPTIONS_API__: true,
|
2022-05-01 13:51:07 +00:00
|
|
|
|
__VUE_PROD_DEVTOOLS__: false,
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
build: {
|
2023-01-09 07:16:00 +00:00
|
|
|
|
target: [
|
2023-09-15 10:49:52 +00:00
|
|
|
|
'chrome116',
|
|
|
|
|
'firefox116',
|
2023-01-09 07:45:18 +00:00
|
|
|
|
'safari16',
|
2023-01-09 07:16:00 +00:00
|
|
|
|
],
|
2022-05-01 13:51:07 +00:00
|
|
|
|
manifest: 'manifest.json',
|
|
|
|
|
rollupOptions: {
|
|
|
|
|
input: {
|
2023-05-15 10:08:46 +00:00
|
|
|
|
app: './src/_boot_.ts',
|
2022-05-01 13:51:07 +00:00
|
|
|
|
},
|
2024-03-20 01:30:45 +00:00
|
|
|
|
external: externalPackages.map(p => p.match),
|
2022-05-01 13:51:07 +00:00
|
|
|
|
output: {
|
|
|
|
|
manualChunks: {
|
2022-06-20 08:38:49 +00:00
|
|
|
|
vue: ['vue'],
|
2023-01-17 08:36:18 +00:00
|
|
|
|
photoswipe: ['photoswipe', 'photoswipe/lightbox', 'photoswipe/style.css'],
|
2022-05-01 13:51:07 +00:00
|
|
|
|
},
|
2023-05-30 09:55:22 +00:00
|
|
|
|
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]',
|
2024-03-20 01:30:45 +00:00
|
|
|
|
paths(id) {
|
|
|
|
|
for (const p of externalPackages) {
|
|
|
|
|
if (p.match.test(id)) {
|
|
|
|
|
return p.path(id, p.match);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return id;
|
|
|
|
|
},
|
2022-05-01 13:51:07 +00:00
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
cssCodeSplit: true,
|
2022-12-20 04:05:36 +00:00
|
|
|
|
outDir: __dirname + '/../../built/_vite_',
|
2022-05-01 13:51:07 +00:00
|
|
|
|
assetsDir: '.',
|
|
|
|
|
emptyOutDir: false,
|
2022-12-20 04:05:36 +00:00
|
|
|
|
sourcemap: process.env.NODE_ENV === 'development',
|
2022-05-01 13:51:07 +00:00
|
|
|
|
reportCompressedSize: false,
|
2023-03-30 00:33:19 +00:00
|
|
|
|
|
|
|
|
|
// https://vitejs.dev/guide/dep-pre-bundling.html#monorepos-and-linked-dependencies
|
|
|
|
|
commonjsOptions: {
|
2024-01-20 00:53:26 +00:00
|
|
|
|
include: [/misskey-js/, /misskey-reversi/, /misskey-bubble-game/, /node_modules/],
|
2023-03-30 00:33:19 +00:00
|
|
|
|
},
|
2022-05-01 13:51:07 +00:00
|
|
|
|
},
|
2023-03-09 03:48:39 +00:00
|
|
|
|
|
2023-05-19 00:44:06 +00:00
|
|
|
|
worker: {
|
|
|
|
|
format: 'es',
|
|
|
|
|
},
|
|
|
|
|
|
2023-03-09 03:48:39 +00:00
|
|
|
|
test: {
|
|
|
|
|
environment: 'happy-dom',
|
|
|
|
|
deps: {
|
2023-11-29 01:41:11 +00:00
|
|
|
|
optimizer: {
|
|
|
|
|
web: {
|
|
|
|
|
include: [
|
|
|
|
|
// XXX: misskey-dev/browser-image-resizer has no "type": "module"
|
|
|
|
|
'browser-image-resizer',
|
|
|
|
|
],
|
|
|
|
|
},
|
|
|
|
|
},
|
2023-03-09 03:48:39 +00:00
|
|
|
|
},
|
2024-01-19 23:11:59 +00:00
|
|
|
|
includeSource: ['src/**/*.ts'],
|
2023-03-09 03:48:39 +00:00
|
|
|
|
},
|
2022-06-20 08:38:49 +00:00
|
|
|
|
};
|
2023-04-04 00:38:34 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const config = defineConfig(({ command, mode }) => getConfig());
|
|
|
|
|
|
|
|
|
|
export default config;
|