mirror of
https://activitypub.software/TransFem-org/Sharkey.git
synced 2024-12-12 20:40:46 +01:00
8a34d8e9d2
# Conflicts: # locales/en-US.yml # locales/ja-JP.yml # packages/backend/src/core/NoteCreateService.ts # packages/backend/src/core/NoteDeleteService.ts # packages/backend/src/core/NoteEditService.ts # packages/frontend-shared/js/config.ts # packages/frontend/src/boot/common.ts # packages/frontend/src/pages/following-feed.vue # packages/misskey-js/src/autogen/endpoint.ts
128 lines
4.6 KiB
JavaScript
128 lines
4.6 KiB
JavaScript
/*
|
|
* SPDX-FileCopyrightText: syuilo and misskey-project
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
*/
|
|
|
|
import * as fs from 'node:fs/promises';
|
|
import * as path from 'node:path';
|
|
import { fileURLToPath } from 'node:url';
|
|
import cssnano from 'cssnano';
|
|
import * as yaml from 'js-yaml';
|
|
import postcss from 'postcss';
|
|
import * as terser from 'terser';
|
|
|
|
import { build as buildLocales } from '../locales/index.js';
|
|
import generateDTS from '../locales/generateDTS.js';
|
|
import meta from '../package.json' with { type: "json" };
|
|
import buildTarball from './tarball.mjs';
|
|
import { localesVersion } from '../locales/version.js';
|
|
|
|
const configDir = fileURLToPath(new URL('../.config', import.meta.url));
|
|
const configPath = process.env.MISSKEY_CONFIG_YML
|
|
? path.resolve(configDir, process.env.MISSKEY_CONFIG_YML)
|
|
: process.env.NODE_ENV === 'test'
|
|
? path.resolve(configDir, 'test.yml')
|
|
: path.resolve(configDir, 'default.yml');
|
|
|
|
let locales = buildLocales();
|
|
|
|
async function loadConfig() {
|
|
return fs.readFile(configPath, 'utf-8').then(data => yaml.load(data)).catch(() => null);
|
|
}
|
|
|
|
async function copyFrontendFonts() {
|
|
await fs.cp('./packages/frontend/node_modules/three/examples/fonts', './built/_frontend_dist_/fonts', { dereference: true, recursive: true });
|
|
}
|
|
|
|
async function copyFrontendTablerIcons() {
|
|
await fs.cp('./packages/frontend/node_modules/@phosphor-icons/web/src', './built/_frontend_dist_/phosphor-icons', { dereference: true, recursive: true });
|
|
|
|
for (const file of [
|
|
'./built/_frontend_dist_/phosphor-icons/bold/style.css',
|
|
'./built/_frontend_dist_/phosphor-icons/duotone/style.css',
|
|
'./built/_frontend_dist_/phosphor-icons/fill/style.css',
|
|
'./built/_frontend_dist_/phosphor-icons/light/style.css',
|
|
'./built/_frontend_dist_/phosphor-icons/regular/style.css',
|
|
'./built/_frontend_dist_/phosphor-icons/thin/style.css',
|
|
]) {
|
|
let source = await fs.readFile(file, { encoding: 'utf-8' });
|
|
source = source.replaceAll(/(url\(.+?Phosphor.+?\.(?:[a-zA-Z0-9]+))/g, `$1?version=${meta.version}`);
|
|
await fs.writeFile(file, source);
|
|
}
|
|
|
|
}
|
|
|
|
async function copyFrontendLocales() {
|
|
generateDTS();
|
|
|
|
await fs.mkdir('./built/_frontend_dist_/locales', { recursive: true });
|
|
|
|
const v = { '_version_': localesVersion };
|
|
|
|
for (const [lang, locale] of Object.entries(locales)) {
|
|
await fs.writeFile(`./built/_frontend_dist_/locales/${lang}.${localesVersion}.json`, JSON.stringify({ ...locale, ...v }), 'utf-8');
|
|
}
|
|
}
|
|
|
|
async function copyBackendViews() {
|
|
await fs.cp('./packages/backend/src/server/web/views', './packages/backend/built/server/web/views', { recursive: true });
|
|
}
|
|
|
|
async function buildBackendScript() {
|
|
await fs.mkdir('./packages/backend/built/server/web', { recursive: true });
|
|
|
|
for (const file of [
|
|
'./packages/backend/src/server/web/boot.js',
|
|
'./packages/backend/src/server/web/boot.embed.js',
|
|
'./packages/backend/src/server/web/bios.js',
|
|
'./packages/backend/src/server/web/cli.js'
|
|
]) {
|
|
let source = await fs.readFile(file, { encoding: 'utf-8' });
|
|
source = source.replaceAll(/\bLANGS\b/g, JSON.stringify(Object.keys(locales)));
|
|
source = source.replaceAll(/\bLANGS_VERSION\b/g, JSON.stringify(localesVersion));
|
|
const { code } = await terser.minify(source, { toplevel: true });
|
|
await fs.writeFile(`./packages/backend/built/server/web/${path.basename(file)}`, code);
|
|
}
|
|
}
|
|
|
|
async function buildBackendStyle() {
|
|
await fs.mkdir('./packages/backend/built/server/web', { recursive: true });
|
|
|
|
for (const file of [
|
|
'./packages/backend/src/server/web/style.css',
|
|
'./packages/backend/src/server/web/style.embed.css',
|
|
'./packages/backend/src/server/web/bios.css',
|
|
'./packages/backend/src/server/web/cli.css',
|
|
'./packages/backend/src/server/web/error.css'
|
|
]) {
|
|
const source = await fs.readFile(file, { encoding: 'utf-8' });
|
|
const { css } = await postcss([cssnano({ zindex: false })]).process(source, { from: undefined });
|
|
await fs.writeFile(`./packages/backend/built/server/web/${path.basename(file)}`, css);
|
|
}
|
|
}
|
|
|
|
async function build() {
|
|
await Promise.all([
|
|
copyFrontendFonts(),
|
|
copyFrontendTablerIcons(),
|
|
copyFrontendLocales(),
|
|
copyBackendViews(),
|
|
buildBackendScript(),
|
|
buildBackendStyle(),
|
|
loadConfig().then(config => config?.publishTarballInsteadOfProvideRepositoryUrl && buildTarball()),
|
|
]);
|
|
}
|
|
|
|
await build();
|
|
|
|
if (process.argv.includes('--watch')) {
|
|
const watcher = fs.watch('./locales');
|
|
for await (const event of watcher) {
|
|
const filename = event.filename?.replaceAll('\\', '/');
|
|
if (/^[a-z]+-[A-Z]+\.yml/.test(filename)) {
|
|
console.log(`update ${filename} ...`)
|
|
locales = buildLocales();
|
|
await copyFrontendLocales()
|
|
}
|
|
}
|
|
}
|