[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": { "http": {
"request": true, "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": { "shell": {
"all": false, "all": false,

View File

@@ -81,7 +81,7 @@ const DownloadedPluginControl = ({
const NotDownloadedPluginControl = ({ option, plugin_status, downloadStartFunction }) => { 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) { if (plugin_status.is_latest_version_available) {
return ( return (

View File

@@ -1,4 +1,5 @@
import { invoke } from "@tauri-apps/api/tauri"; import { invoke } from "@tauri-apps/api/tauri";
import { IS_PLUGIN_DEV_MODE, getPluginsList } from "@ui_configs";
import { import {
createAtomWithHook, createAtomWithHook,
useStore_SavedPluginsStatus, useStore_SavedPluginsStatus,
@@ -14,7 +15,7 @@ const imported_dev_plugins = [];
dev_plugins.forEach(async ({entry_path}) => { dev_plugins.forEach(async ({entry_path}) => {
imported_dev_plugins.push({ imported_dev_plugins.push({
index: await import(`@plugins_path/${entry_path}/index.jsx`), 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 // 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 = () => { export const usePlugins = () => {
const { asyncStdoutToPython } = useStdoutToPython(); const { asyncStdoutToPython } = useStdoutToPython();
@@ -135,7 +136,7 @@ export const usePlugins = () => {
}; };
const asyncLoadAllPlugins = async () => { const asyncLoadAllPlugins = async () => {
if (!import.meta.env.DEV) { if (IS_PLUGIN_DEV_MODE) {
imported_dev_plugins.forEach(({ index, downloaded_plugin_info }) => { imported_dev_plugins.forEach(({ index, downloaded_plugin_info }) => {
if (!index || !downloaded_plugin_info) { if (!index || !downloaded_plugin_info) {
console.error("Invalid development plugin detected", index, downloaded_plugin_info); console.error("Invalid development plugin detected", index, downloaded_plugin_info);
@@ -150,7 +151,9 @@ export const usePlugins = () => {
}); });
} else { } else {
try { 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) { for (const target_dir of plugin_files) {
const target_path = target_dir.name; const target_path = target_dir.name;
await asyncLoadPlugin(target_path); await asyncLoadPlugin(target_path);
@@ -368,9 +371,11 @@ const removeImportStatements = (code) => {
// import { readTextFile, BaseDirectory } from "@tauri-apps/api/fs"; // import { readTextFile, BaseDirectory } from "@tauri-apps/api/fs";
const loadPluginCSS = async (plugin_css_path) => { const loadPluginCSS = async (plugin_css_path) => {
if (!await exists(plugin_css_path, { dir: BaseDirectory.Resource, recursive: true })) return;
try { try {
// プラグインフォルダのルートにある main.css を読み込む // プラグインフォルダのルートにある main.css を読み込む
const css_content = await readTextFile(plugin_css_path, { dir: BaseDirectory.Resource }); const css_content = await readTextFile(plugin_css_path, { dir: BaseDirectory.Resource });
// style タグを作成して head に挿入する // style タグを作成して head に挿入する
const style_tag = document.createElement("style"); const style_tag = document.createElement("style");
style_tag.id = `plugin-css-${plugin_css_path.replace(/[^a-zA-Z0-9_-]/g, "")}`; 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 = [ export const translator_status = [
{ id: "DeepL", label: "DeepL", is_available: false }, { id: "DeepL", label: "DeepL", is_available: false },
{ id: "DeepL_API", label: `DeepL API`, is_available: false }, { id: "DeepL_API", label: `DeepL API`, is_available: false },