mirror of
https://github.com/NapNeko/NapCatQQ.git
synced 2025-07-19 12:03:37 +00:00
refactor: framework的操作性
This commit is contained in:
@@ -1,6 +1,10 @@
|
|||||||
//LiteLoader需要提供部分IPC接口,以便于其他插件调用
|
//LiteLoader需要提供部分IPC接口,以便于其他插件调用
|
||||||
const { ipcMain } = require('electron');
|
const { ipcMain } = require('electron');
|
||||||
const napcat = require('./napcat.cjs');
|
const napcat = require('./napcat.cjs');
|
||||||
|
const { shell } = require('electron');
|
||||||
ipcMain.handle('napcat_get_webtoken', async (event, arg) => {
|
ipcMain.handle('napcat_get_webtoken', async (event, arg) => {
|
||||||
return napcat.NCgetWebUiUrl();
|
return napcat.NCgetWebUiUrl();
|
||||||
});
|
});
|
||||||
|
ipcMain.on('open_external_url', (event, url) => {
|
||||||
|
shell.openExternal(url);
|
||||||
|
});
|
@@ -1,10 +1,11 @@
|
|||||||
const { contextBridge } = require('electron');
|
const { contextBridge, ipcRenderer } = require('electron');
|
||||||
const { ipcRenderer } = require('electron');
|
|
||||||
|
|
||||||
const napcat = {
|
const napcat = {
|
||||||
getWebUiUrl: async () => {
|
getWebUiUrl: async () => {
|
||||||
return ipcRenderer.invoke('napcat_get_webtoken');
|
return ipcRenderer.invoke('napcat_get_webtoken');
|
||||||
},
|
},
|
||||||
|
openExternalUrl: async (url) => {
|
||||||
|
ipcRenderer.send('open_external_url', url);
|
||||||
|
}
|
||||||
};
|
};
|
||||||
// 在window对象下导出只读对象
|
// 在window对象下导出只读对象
|
||||||
contextBridge.exposeInMainWorld('napcat', napcat);
|
contextBridge.exposeInMainWorld('napcat', napcat);
|
@@ -1,27 +1,16 @@
|
|||||||
export const onSettingWindowCreated = async (view) => {
|
export const onSettingWindowCreated = async (view) => {
|
||||||
|
|
||||||
// view.style.width = "100%";
|
|
||||||
// view.style.height = "100%";
|
|
||||||
// //添加iframe
|
|
||||||
// const iframe = document.createElement("iframe");
|
|
||||||
// iframe.src = await window.napcat.getWebUiUrl();
|
|
||||||
// iframe.width = "100%";
|
|
||||||
// iframe.height = "100%";
|
|
||||||
// iframe.style.border = "none";
|
|
||||||
// //去掉iframe滚动条
|
|
||||||
// //iframe.scrolling = "no";
|
|
||||||
// //有滚动条何尝不是一种美
|
|
||||||
// view.appendChild(iframe);
|
|
||||||
let webui = await window.napcat.getWebUiUrl();
|
let webui = await window.napcat.getWebUiUrl();
|
||||||
view.innerHTML = `
|
view.innerHTML = `
|
||||||
<setting-section data-title="">
|
<setting-section data-title="">
|
||||||
<setting-panel>
|
<setting-panel>
|
||||||
<setting-list data-direction="column">
|
<setting-list data-direction="column">
|
||||||
<setting-item>
|
<setting-item>
|
||||||
<setting-button data-type="primary" class="nc_openwebui">打开配置页面</setting-button>
|
<setting-button data-type="primary" class="nc_openwebui">在QQ内打开配置页面</setting-button>
|
||||||
|
<setting-button data-type="primary" class="nc_openwebui_ex">在默认浏览器打开配置页面</setting-button>
|
||||||
</setting-item>
|
</setting-item>
|
||||||
<setting-item>
|
<setting-item>
|
||||||
<div>
|
<div>
|
||||||
|
<setting-text>WebUi远程地址可以点击下方复制哦~</setting-text>
|
||||||
<setting-text class="nc_webui">WebUi</setting-text>
|
<setting-text class="nc_webui">WebUi</setting-text>
|
||||||
</div>
|
</div>
|
||||||
</setting-item>
|
</setting-item>
|
||||||
@@ -32,5 +21,18 @@ export const onSettingWindowCreated = async (view) => {
|
|||||||
view.querySelector('.nc_openwebui').addEventListener('click', () => {
|
view.querySelector('.nc_openwebui').addEventListener('click', () => {
|
||||||
window.open(webui, '_blank');
|
window.open(webui, '_blank');
|
||||||
});
|
});
|
||||||
|
view.querySelector('.nc_openwebui_ex').addEventListener('click', () => {
|
||||||
|
window.napcat.openExternalUrl(webui);
|
||||||
|
});
|
||||||
view.querySelector('.nc_webui').innerText = webui;
|
view.querySelector('.nc_webui').innerText = webui;
|
||||||
};
|
|
||||||
|
// 添加点击复制功能
|
||||||
|
view.querySelector('.nc_webui').addEventListener('click', async () => {
|
||||||
|
try {
|
||||||
|
await navigator.clipboard.writeText(webui);
|
||||||
|
alert('WebUi URL 已复制到剪贴板');
|
||||||
|
} catch (err) {
|
||||||
|
console.error('复制到剪贴板失败: ', err);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
Reference in New Issue
Block a user