mirror of
https://codeberg.org/yeentown/barkey.git
synced 2025-10-24 10:14:51 +00:00
* wip * wip * wip * test * wip rollup pluginでsearchIndexの情報生成 * wip * SPDX * wip: markerIdを自動付与 * rollupでビルド時・devモード時に毎回uuidを生成するように * 開発サーバーでだけ必要な挙動は開発サーバーのみで * 条件が逆 * wip: childrenの生成 * update comment * update comment * rename auto generated file * hashをパスと行数から決定 * Update privacy.vue * Update privacy.vue * wip * Update general.vue * Update general.vue * wip * wip * Update SearchMarker.vue * wip * Update profile.vue * Update mute-block.vue * Update mute-block.vue * Update general.vue * Update general.vue * childrenがduplicate key errorを吐く問題をいったん解決 * マーカーの形を成形 * loggerを置きかえ * とりあえず省略記法に対応 * Refactor and Format codes * wip * Update settings-search-index.ts * wip * wip * とりあえず不確定要因の仮置きidを削除 * hashの生成を正規化(絶対パスになっていたのを緩和) * pathの入力を省略可能に * adminでもパス生成できるように * Update settings-search-index.ts * Update privacy.vue * wip * build searchIndex * wip * build * Update general.vue * build * Update sounds.vue * build * build * Update sounds.vue * 🎨 * 🎨 * Update privacy.vue * Update privacy.vue * Update security.vue * create-search-indexを多少改善 * build * Update 2fa.vue * wip * 必ずtransformCodeCacheを利用するように, キャッシュの明確な受け渡しを定義 * キャッシュはdevServerでなくても更新 * Revert "wip" This reverts commit 41bffd3a13f55618bf939dc1c9acb2a77ead4054. * inlining * wip * Update theme.vue * 🎨 * wip normalize * Update theme.vue * キャッシュのパス変換 * build * wip * wip * Update SearchMarker.vue * i18n.ts['key'] の形式が取り出せない問題のFix * build * 仮でpath入れ * 必ず絶対パスが使われるように * wip * 🎨 * storybookビルド時はcreateSearchIndexをしない * inliningの構造化 * format code * Update index.vue * wip * wip * 🎨 * wip * wip * wip * wip * wip * wip * wip * wip * clean up * Update navbar.vue * enhance: 検索で上下矢印を使用することで検索結果を移動できるように * refactor * fix(frontend): PageWindowでSearchMarkerが動作するように * enhance(frontend): SearchMarkerの点滅を一定時間で止める * lint fix * fix: 子要素監視が抜けていたのを修正 * アニメーションの回数はCSSで制御するように * refactor * enhance(frontend): 検索インデックス作成時のログを削減 * revert * fix * fix --------- Co-authored-by: tai-cha <dev@taichan.site> Co-authored-by: taichan <40626578+tai-cha@users.noreply.github.com> Co-authored-by: kakkokari-gtyih <67428053+kakkokari-gtyih@users.noreply.github.com>
216 lines
6.5 KiB
TypeScript
216 lines
6.5 KiB
TypeScript
import path from 'path';
|
||
import pluginReplace from '@rollup/plugin-replace';
|
||
import pluginVue from '@vitejs/plugin-vue';
|
||
import { type UserConfig, defineConfig } from 'vite';
|
||
import * as yaml from 'js-yaml';
|
||
import { promises as fsp } from 'fs';
|
||
|
||
import locales from '../../locales/index.js';
|
||
import meta from '../../package.json';
|
||
import packageInfo from './package.json' with { type: 'json' };
|
||
import pluginUnwindCssModuleClassName from './lib/rollup-plugin-unwind-css-module-class-name.js';
|
||
import pluginJson5 from './vite.json5.js';
|
||
import pluginCreateSearchIndex from './lib/vite-plugin-create-search-index.js';
|
||
|
||
const url = process.env.NODE_ENV === 'development' ? yaml.load(await fsp.readFile('../../.config/default.yml', 'utf-8')).url : null;
|
||
const host = url ? (new URL(url)).hostname : undefined;
|
||
|
||
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;
|
||
},
|
||
},
|
||
];
|
||
|
||
export 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);
|
||
};
|
||
|
||
export const BASE62_DIGITS = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
|
||
|
||
export 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/',
|
||
|
||
server: {
|
||
host,
|
||
port: 5173,
|
||
hmr: {
|
||
// バックエンド経由での起動時、Viteは5173経由でアセットを参照していると思い込んでいるが実際は3000から配信される
|
||
// そのため、バックエンドのWSサーバーにHMRのWSリクエストが吸収されてしまい、正しくHMRが機能しない
|
||
// クライアント側のWSポートをViteサーバーのポートに強制させることで、正しくHMRが機能するようになる
|
||
clientPort: 5173,
|
||
},
|
||
headers: { // なんか効かない
|
||
'X-Frame-Options': 'DENY',
|
||
},
|
||
},
|
||
|
||
plugins: [
|
||
pluginCreateSearchIndex({
|
||
targetFilePaths: ['src/pages/settings/*.vue'],
|
||
exportFilePath: './src/scripts/autogen/settings-search-index.ts',
|
||
verbose: process.env.FRONTEND_SEARCH_INDEX_VERBOSE === 'true',
|
||
}),
|
||
pluginVue(),
|
||
pluginUnwindCssModuleClassName(),
|
||
pluginJson5(),
|
||
...process.env.NODE_ENV === 'production'
|
||
? [
|
||
pluginReplace({
|
||
preventAssignment: true,
|
||
values: {
|
||
'isChromatic()': JSON.stringify(false),
|
||
},
|
||
}),
|
||
]
|
||
: [],
|
||
],
|
||
|
||
resolve: {
|
||
extensions,
|
||
alias: {
|
||
'@/': __dirname + '/src/',
|
||
'@@/': __dirname + '/../frontend-shared/',
|
||
'/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;
|
||
}
|
||
},
|
||
},
|
||
preprocessorOptions: {
|
||
scss: {
|
||
api: 'modern-compiler',
|
||
},
|
||
},
|
||
},
|
||
|
||
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,
|
||
},
|
||
|
||
build: {
|
||
target: [
|
||
'chrome116',
|
||
'firefox116',
|
||
'safari16',
|
||
],
|
||
manifest: 'manifest.json',
|
||
rollupOptions: {
|
||
input: {
|
||
app: './src/_boot_.ts',
|
||
},
|
||
external: externalPackages.map(p => p.match),
|
||
output: {
|
||
manualChunks: {
|
||
vue: ['vue'],
|
||
photoswipe: ['photoswipe', 'photoswipe/lightbox', 'photoswipe/style.css'],
|
||
},
|
||
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_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/, /misskey-reversi/, /misskey-bubble-game/, /node_modules/],
|
||
},
|
||
},
|
||
|
||
worker: {
|
||
format: 'es',
|
||
},
|
||
|
||
test: {
|
||
environment: 'happy-dom',
|
||
deps: {
|
||
optimizer: {
|
||
web: {
|
||
include: [
|
||
// XXX: misskey-dev/browser-image-resizer has no "type": "module"
|
||
'browser-image-resizer',
|
||
],
|
||
},
|
||
},
|
||
},
|
||
includeSource: ['src/**/*.ts'],
|
||
},
|
||
};
|
||
}
|
||
|
||
const config = defineConfig(({ command, mode }) => getConfig());
|
||
|
||
export default config;
|