From 7d45f0d951873a82531608d2668bc596a35e8a5d Mon Sep 17 00:00:00 2001 From: luke358 Date: Thu, 18 Jan 2024 11:36:36 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E8=84=9A=E6=9C=AC=E6=B3=A8=E5=85=A5web?= =?UTF-8?q?view=20&=20=E7=99=BD=E5=B1=8F=E8=B7=AF=E7=94=B1=E5=88=87?= =?UTF-8?q?=E6=8D=A2?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .eslintrc | 3 --- auto-imports.d.ts | 1 + components.d.ts | 5 +---- electron-builder.json5 | 2 +- electron/main/index.ts | 7 +++++- electron/preload/index.ts | 6 ++++++ eslint.config.js | 3 +++ package.json | 2 +- preload/preload.js | 44 ++++++++++++++++++++++++++++++++++++++ src/App.vue | 2 +- src/components/WebView.vue | 37 ++++++++++++++++++++------------ src/main.ts | 2 +- src/router/index.ts | 5 ++--- tsconfig.node.json | 2 +- 14 files changed, 91 insertions(+), 30 deletions(-) delete mode 100644 .eslintrc create mode 100644 eslint.config.js create mode 100644 preload/preload.js diff --git a/.eslintrc b/.eslintrc deleted file mode 100644 index 146f0c9..0000000 --- a/.eslintrc +++ /dev/null @@ -1,3 +0,0 @@ -{ - "extends": "@antfu" -} \ No newline at end of file diff --git a/auto-imports.d.ts b/auto-imports.d.ts index 918aad8..1d89ee8 100644 --- a/auto-imports.d.ts +++ b/auto-imports.d.ts @@ -1,6 +1,7 @@ /* eslint-disable */ /* prettier-ignore */ // @ts-nocheck +// noinspection JSUnusedGlobalSymbols // Generated by unplugin-auto-import export {} declare global { diff --git a/components.d.ts b/components.d.ts index 41e9f33..4627702 100644 --- a/components.d.ts +++ b/components.d.ts @@ -3,11 +3,9 @@ // @ts-nocheck // Generated by unplugin-vue-components // Read more: https://github.com/vuejs/core/pull/3399 -import '@vue/runtime-core' - export {} -declare module '@vue/runtime-core' { +declare module 'vue' { export interface GlobalComponents { AddServiceDrawer: typeof import('./src/components/AddServiceDrawer.vue')['default'] ContextMenuPopover: typeof import('./src/components/ContextMenuPopover.vue')['default'] @@ -30,7 +28,6 @@ declare module '@vue/runtime-core' { Setting: typeof import('./src/components/Setting.vue')['default'] Sidebar: typeof import('./src/components/Sidebar.vue')['default'] WebView: typeof import('./src/components/WebView.vue')['default'] - WebviewEnable: typeof import('./src/components/WebviewEnable.vue')['default'] WebViewEnable: typeof import('./src/components/WebViewEnable.vue')['default'] WebViewError: typeof import('./src/components/WebViewError.vue')['default'] WebViewHibernate: typeof import('./src/components/WebViewHibernate.vue')['default'] diff --git a/electron-builder.json5 b/electron-builder.json5 index cc2fca2..18098f5 100644 --- a/electron-builder.json5 +++ b/electron-builder.json5 @@ -3,7 +3,7 @@ */ { "$schema": "https://raw.githubusercontent.com/electron-userland/electron-builder/master/packages/app-builder-lib/scheme.json", - "appId": "YourAppID", + "appId": "com.allInBox.com", "asar": true, "directories": { "output": "release/${version}" diff --git a/electron/main/index.ts b/electron/main/index.ts index 01c6f84..95c63b7 100644 --- a/electron/main/index.ts +++ b/electron/main/index.ts @@ -61,7 +61,7 @@ async function createWindow() { // Consider using contextBridge.exposeInMainWorld // Read more on https://www.electronjs.org/docs/latest/tutorial/context-isolation nodeIntegration: true, - contextIsolation: false, + contextIsolation: true, webviewTag: true, plugins: true, }, @@ -99,6 +99,11 @@ async function createWindow() { }) // win.webContents.on('will-navigate', (event, url) => { }) #344 attachTitlebarToWindow(win) + + win.webContents.on('will-attach-webview', (e, webPreferences) => { + console.log(webPreferences, e, 'qd'); + webPreferences.preload = join(__dirname, '../../preload/preload.js') + }) } app.whenReady().then(createWindow) diff --git a/electron/preload/index.ts b/electron/preload/index.ts index 4dbab09..fde8ee3 100644 --- a/electron/preload/index.ts +++ b/electron/preload/index.ts @@ -1,4 +1,5 @@ import { Titlebar, TitlebarColor } from 'custom-electron-titlebar' +import { contextBridge } from 'electron' window.addEventListener('DOMContentLoaded', () => { // Title bar implementation @@ -18,6 +19,11 @@ function domReady(condition: DocumentReadyState[] = ['complete', 'interactive']) }) } +contextBridge.exposeInMainWorld('API', { + // eslint-disable-next-line no-console + log: console.log, +}) + const safeDOM = { append(parent: HTMLElement, child: HTMLElement) { if (!Array.from(parent.children).find(e => e === child)) diff --git a/eslint.config.js b/eslint.config.js new file mode 100644 index 0000000..3b614a0 --- /dev/null +++ b/eslint.config.js @@ -0,0 +1,3 @@ +import antfu from '@antfu/eslint-config' + +export default antfu() diff --git a/package.json b/package.json index f755c30..7fbea81 100644 --- a/package.json +++ b/package.json @@ -42,7 +42,7 @@ "vue-router": "^4.2.0" }, "devDependencies": { - "@antfu/eslint-config": "^0.43.1", + "@antfu/eslint-config": "^2.6.2", "@types/lodash-es": "^4.17.7", "@types/ms": "^0.7.31", "@vitejs/plugin-vue": "^4.2.3", diff --git a/preload/preload.js b/preload/preload.js new file mode 100644 index 0000000..3b63382 --- /dev/null +++ b/preload/preload.js @@ -0,0 +1,44 @@ +// // window.addEventListener('DOMContentLoaded', () => { +// // console.log('domloaded') + +// // }) + +// ferdium.log('testing') +// function getMessages() { +// let directCount = 0 +// const directCountPerServer = document.querySelectorAll( +// '[class*="lowerBadge_"] [class*="numberBadge_"]', +// ) + +// for (const directCountBadge of directCountPerServer) +// directCount += Number.parseInt(directCountBadge.textContent) + +// const indirectCountPerServer +// = document.title.search('• Discord') === -1 ? 0 : 1 + +// // console.log(directCount); +// // window.api.log(directCount, 'directCount') +// // window.api.log(document.querySelectorAll( +// // '[class*="lowerBadge_"] [class*="numberBadge_"]', +// // )) +// // window.api.log(document.title) +// // console.log(Ferdium) +// } +// // setInterval(getMessages, 1000) +// console.log(document.querySelectorAll('input')) +// console.log('ccc') +// getMessages() +// console.log(document) +const { ipcRenderer } = require('electron') +console.log('tttt') +document.addEventListener('DOMContentLoaded', function () { + var data = { + 'title': document.title, + 'url': window.location.href, + 'array': { + 'array': ['1','2','3'] + } + }; + console.log(data, 'dddd') + ipcRenderer.sendToHost('data', data); +}); diff --git a/src/App.vue b/src/App.vue index 9f85742..be598fe 100644 --- a/src/App.vue +++ b/src/App.vue @@ -6,7 +6,7 @@ const services = useServiceStore() services.serviceMaintenanceTick() services.$subscribe((mutation, state) => { - if ((mutation.events as any).key !== 'teardown') + if ((mutation.events as any)?.key !== 'teardown') localStorage.setItem('services', JSON.stringify({ allServices: state.allServices.map(s => omit(s, '_webview')) })) }) diff --git a/src/components/WebView.vue b/src/components/WebView.vue index 9671917..268c74e 100644 --- a/src/components/WebView.vue +++ b/src/components/WebView.vue @@ -1,5 +1,5 @@ - - + + diff --git a/src/main.ts b/src/main.ts index 7f03e8f..566c3f0 100644 --- a/src/main.ts +++ b/src/main.ts @@ -5,7 +5,7 @@ import piniaPluginPersistedstate from 'pinia-plugin-persistedstate' import router from './router' import './style.scss' import App from './App.vue' -import './samples/node-api' +// import './samples/node-api' import 'normalize.css' const pinia = createPinia() diff --git a/src/router/index.ts b/src/router/index.ts index 7dfc4b9..f1ba772 100644 --- a/src/router/index.ts +++ b/src/router/index.ts @@ -1,8 +1,7 @@ -import { createRouter, createWebHistory } from 'vue-router' +import { createRouter, createWebHashHistory } from 'vue-router' import { defineAsyncComponent } from 'vue' - const router = createRouter({ - history: createWebHistory(), + history: createWebHashHistory(), routes: [ { path: '/', diff --git a/tsconfig.node.json b/tsconfig.node.json index ed1b586..d17485e 100644 --- a/tsconfig.node.json +++ b/tsconfig.node.json @@ -6,5 +6,5 @@ "resolveJsonModule": true, "allowSyntheticDefaultImports": true }, - "include": ["vite.config.ts", "package.json", "electron"] + "include": ["vite.config.ts", "package.json", "electron", "preload"] }