[Update] Add dev plugin mode and dev plugin list.

This commit is contained in:
Sakamoto Shiina
2025-04-12 14:28:01 +09:00
parent d4219b5ce0
commit 1bea61c45a
4 changed files with 25 additions and 6 deletions

View File

@@ -41,7 +41,12 @@
},
"http": {
"request": true,
"scope": ["https://api.github.com/repos/**", "https://github.com/**", "https://raw.githubusercontent.com/ShiinaSakamoto/vrct_plugins_list/main/vrct_plugins_list.json"]
"scope": [
"https://api.github.com/repos/**",
"https://github.com/**",
"https://raw.githubusercontent.com/ShiinaSakamoto/vrct_plugins_list/main/vrct_plugins_list.json",
"https://raw.githubusercontent.com/ShiinaSakamoto/vrct_plugins_list/main/dev_vrct_plugins_list.json"
]
},
"shell": {
"all": false,

View File

@@ -81,7 +81,7 @@ const DownloadedPluginControl = ({
const NotDownloadedPluginControl = ({ option, plugin_status, downloadStartFunction }) => {
const latest_version = plugin_status.latest_plugin_info.plugin_version;
const latest_version = plugin_status.latest_plugin_info?.plugin_version;
if (plugin_status.is_latest_version_available) {
return (

View File

@@ -1,4 +1,5 @@
import { invoke } from "@tauri-apps/api/tauri";
import { IS_PLUGIN_DEV_MODE, getPluginsList } from "@ui_configs";
import {
createAtomWithHook,
useStore_SavedPluginsStatus,
@@ -14,7 +15,7 @@ const imported_dev_plugins = [];
dev_plugins.forEach(async ({entry_path}) => {
imported_dev_plugins.push({
index: await import(`@plugins_path/${entry_path}/index.jsx`),
plugin_info: await import(`@plugins_path/${entry_path}/plugin_info.json`),
downloaded_plugin_info: await import(`@plugins_path/${entry_path}/plugin_info.json`),
});
})
@@ -28,7 +29,7 @@ import * as logics_common from "@logics_common";
// PLUGIN_LIST_URL は中央リポジトリにある、各プラグインの plugin_info.json への URL の配列を保持する JSON の URL
const PLUGIN_LIST_URL = "https://raw.githubusercontent.com/ShiinaSakamoto/vrct_plugins_list/main/vrct_plugins_list.json";
const PLUGIN_LIST_URL = getPluginsList();
export const usePlugins = () => {
const { asyncStdoutToPython } = useStdoutToPython();
@@ -135,7 +136,7 @@ export const usePlugins = () => {
};
const asyncLoadAllPlugins = async () => {
if (!import.meta.env.DEV) {
if (IS_PLUGIN_DEV_MODE) {
imported_dev_plugins.forEach(({ index, downloaded_plugin_info }) => {
if (!index || !downloaded_plugin_info) {
console.error("Invalid development plugin detected", index, downloaded_plugin_info);
@@ -150,7 +151,9 @@ export const usePlugins = () => {
});
} else {
try {
const plugin_files = await readDir("plugins", { dir: BaseDirectory.Resource, recursive: true });
const plugin_entries = await readDir("plugins", { dir: BaseDirectory.Resource, recursive: true });
const plugin_files = plugin_entries.filter(entry => entry.children && Array.isArray(entry.children));
for (const target_dir of plugin_files) {
const target_path = target_dir.name;
await asyncLoadPlugin(target_path);
@@ -368,9 +371,11 @@ const removeImportStatements = (code) => {
// import { readTextFile, BaseDirectory } from "@tauri-apps/api/fs";
const loadPluginCSS = async (plugin_css_path) => {
if (!await exists(plugin_css_path, { dir: BaseDirectory.Resource, recursive: true })) return;
try {
// プラグインフォルダのルートにある main.css を読み込む
const css_content = await readTextFile(plugin_css_path, { dir: BaseDirectory.Resource });
// style タグを作成して head に挿入する
const style_tag = document.createElement("style");
style_tag.id = `plugin-css-${plugin_css_path.replace(/[^a-zA-Z0-9_-]/g, "")}`;

View File

@@ -52,6 +52,15 @@ export const ui_configs = {
]
};
export const IS_PLUGIN_DEV_MODE = false;
export const getPluginsList = () => {
const base_url = "https://raw.githubusercontent.com/ShiinaSakamoto/vrct_plugins_list/main/";
const plugins_list_url = (IS_PLUGIN_DEV_MODE)
? base_url + "dev_vrct_plugins_list.json"
: base_url + "vrct_plugins_list.json";
return plugins_list_url;
};
export const translator_status = [
{ id: "DeepL", label: "DeepL", is_available: false },
{ id: "DeepL_API", label: `DeepL API`, is_available: false },