Files
Innei fcdaf9d814 🔧 chore: update eslint v2 configuration and suppressions (#12133)
* v2 init

* chore: update eslint suppressions and package dependencies

- Removed several eslint suppressions related to array sorting and reversing from eslint-suppressions.json to clean up the configuration.
- Updated @lobehub/lint package version from 2.0.0-beta.6 to 2.0.0-beta.7 in package.json for improvements and bug fixes.
- Made minor formatting adjustments in vitest.config.mts and various SKILL.md files for better readability and consistency.

Signed-off-by: Innei <tukon479@gmail.com>

* fix: clean up import statements and formatting

- Removed unnecessary whitespace in replaceComponentImports.ts for improved readability.
- Standardized import statements in contextEngineering.ts and createAgentExecutors.ts by adding missing spaces for consistency.

Signed-off-by: Innei <tukon479@gmail.com>

* chore: update eslint suppressions and clean up code formatting

* 🐛 fix: use vi.hoisted for mock variable initialization

Fix TDZ error in persona service test by using vi.hoisted() to ensure
mock variables are available when vi.mock factory runs.

---------

Signed-off-by: Innei <tukon479@gmail.com>
2026-02-11 13:04:48 +08:00

65 lines
1.7 KiB
TypeScript

import { readFileSync, writeFileSync } from 'node:fs';
import { resolve } from 'node:path';
import { kebabCase } from 'es-toolkit/compat';
import { AGENT_I18N_URL, AGENT_URL, PLUGIN_I18N_URL, PLUGIN_URL, root } from './const';
const fetchIndex = async (url: string) => {
const res = await fetch(url);
return await res.json();
};
export const fetchAgentIndex = async (lang?: string) => {
const url = lang ? AGENT_I18N_URL(lang) : AGENT_URL;
const data = await fetchIndex(url);
return data.agents;
};
export const fetchPluginIndex = async (lang?: string) => {
const url = lang ? PLUGIN_I18N_URL(lang) : PLUGIN_URL;
const data = await fetchIndex(url);
return data.plugins;
};
export const genLink = (title: string, url: string) => `[${title}](${url})`;
export const genTags = (tags: string[]) =>
tags
.filter(Boolean)
.map((tag) => `\`${kebabCase(tag)}\``)
.join(' ');
const getReadmePath = (lang?: string) => {
return resolve(root, lang ? `./README.${lang}.md` : `./README.md`);
};
export const readReadme = (lang?: string): string => {
return readFileSync(getReadmePath(lang), 'utf8');
};
export const writeReadme = (content: string, lang?: string) => {
writeFileSync(getReadmePath(lang), content, 'utf8');
};
export const updateReadme = (split: string, md: string, content: string): string => {
const mds = md.split(split);
mds[1] = [' ', content, ' '].join('\n\n');
return mds.join(split);
};
export const getTitle = (lang?: string) => {
switch (lang) {
case 'zh-CN': {
return ['最近新增', '描述'];
}
case 'ja-JP': {
return ['最近追加', '説明'];
}
default: {
return ['Recent Submits', 'Description'];
}
}
};