feat:打开目录,读取文件及文件夹内容

This commit is contained in:
shixiaohua 2024-01-05 18:01:13 +08:00
parent 8bcc7ccb1f
commit 1b66d3aa6d
2 changed files with 137 additions and 132 deletions

17
main.js
View File

@ -3,7 +3,7 @@ const { app,Menu, BrowserWindow , ipcMain } = require('electron')
const path = require('path') const path = require('path')
const fs = require('fs') const fs = require('fs')
const https = require('https') const https = require('https')
const template = require('./src/comment/TopMenu.js') const {menuRebuild} = require('./src/comment/TopMenu.js')
// electorn // electorn
const createWindow = () => { const createWindow = () => {
// Create the browser window. // Create the browser window.
@ -17,24 +17,13 @@ const createWindow = () => {
// 加载 index.html // 加载 index.html
win.loadFile('index.html') win.loadFile('index.html')
// win.loadURL('http://localhost/show/sync?current=1&pageSize=5') // win.loadURL('http://localhost/show/sync?current=1&pageSize=5')
// 打开开发工具 // 打开开发工具
win.webContents.openDevTools() win.webContents.openDevTools()
Menu.setApplicationMenu(Menu.buildFromTemplate(template.template)) Menu.setApplicationMenu(Menu.buildFromTemplate(menuRebuild(win)))
} }
const iconName = path.join(__dirname, 'iconForDragAndDrop.png') const iconName = path.join(__dirname, 'iconForDragAndDrop.png')
// const icon = fs.createWriteStream(iconName)
// Create a new file to copy - you can also copy existing files. // 这段程序将会在 Electron 结束初始化和创建浏览器窗口的时候调用
// fs.writeFileSync(path.join(__dirname, 'drag-and-drop-1.md'), '# First file to test drag and drop')
// fs.writeFileSync(path.join(__dirname, 'drag-and-drop-2.md'), '# Second file to test drag and drop')
// https.get('https://img.icons8.com/ios/452/drag-and-drop.png', (response) => {
// response.pipe(icon)
// })
// 这段程序将会在 Electron 结束初始化
// 和创建浏览器窗口的时候调用
// 部分 API 在 ready 事件触发后才能使用。 // 部分 API 在 ready 事件触发后才能使用。
app.whenReady().then(() => { app.whenReady().then(() => {
// ipcMain.handle('ping', () => 'pong') // ipcMain.handle('ping', () => 'pong')

View File

@ -1,122 +1,138 @@
const { app, Menu, shell} = require('electron') const { app, Menu, shell, dialog} = require('electron')
const {readdir} = require("node:fs/promises");
const {stat} = require("fs/promises");
const isMac = process.platform === 'darwin' const isMac = process.platform === 'darwin'
exports.menuRebuild=(mainWindow)=> {
exports.template = [ return template = [
// { role: 'appMenu' } // { role: 'appMenu' }
...(isMac ...(isMac
? [{ ? [{
label: app.name, label: app.name,
submenu: [
{ role: 'about' },
{ type: 'separator' },
{ role: 'services' },
{ type: 'separator' },
{ role: 'hide' },
{ role: 'hideOthers' },
{ role: 'unhide' },
{ type: 'separator' },
{ role: 'quit' }
]
}]
: []),
// { role: 'fileMenu' }
{
label: 'File',
submenu: [ submenu: [
{ role: 'about' }, {label:'打开目录',
{ type: 'separator' }, click: async () => {
{ role: 'services' }, const { dialog } = require('electron')
{ type: 'separator' }, dialog.showOpenDialog({
{ role: 'hide' }, properties: ['openDirectory']
{ role: 'hideOthers' }, }).then(async result => {
{ role: 'unhide' }, console.log(result.canceled)
{ type: 'separator' }, // 不取消就发送目录
{ role: 'quit' } if (!result.canceled) {
] console.log(result.filePaths)
}] const {readdir,stat} = require('fs/promises')
: []), try {
// { role: 'fileMenu' } const files = await readdir(result.filePaths[0]);
{ const fileStats = []
label: 'File', for (let i = 0; i < files.length; i++) {
submenu: [ const state = await stat(result.filePaths+'/'+files[i]);
{label:'打开目录', fileStats.push({'fileName': files[i], 'dir':state.isDirectory()})
click: async () => { }
const { dialog } = require('electron') mainWindow.webContents.send('openDirectory',
dialog.showOpenDialog({ {'fileDir':result.filePaths,'fileList':fileStats}
properties: ['openDirectory'] )
}).then(result => { } catch (err) {
console.log(result.canceled) console.error(err);
// 不取消就发送目录 }
if (!result.canceled) }
console.log(result.filePaths) }).catch(err => {
}).catch(err => { console.log(err)
console.log(err) })
}) }
} },
}, isMac ? { role: 'close' } : { role: 'quit' },
isMac ? { role: 'close' } : { role: 'quit' }, ]
isMac ? { role: 'open' } : { role: 'open' } },
] // { role: 'editMenu' }
}, {
// { role: 'editMenu' } label: 'Edit',
{ submenu: [
label: 'Edit', { role: 'undo' },
submenu: [ { role: 'redo' },
{ role: 'undo' }, { type: 'separator' },// 分割线
{ role: 'redo' }, { role: 'cut' },
{ type: 'separator' },// 分割线 { role: 'copy' },
{ role: 'cut' }, { role: 'paste' },
{ role: 'copy' }, ...(isMac
{ role: 'paste' }, ? [
...(isMac { role: 'pasteAndMatchStyle' },
? [ { role: 'delete' },
{ role: 'pasteAndMatchStyle' }, { role: 'selectAll' },
{ role: 'delete' }, { type: 'separator' },
{ role: 'selectAll' }, {
{ type: 'separator' }, label: 'Speech',
{ submenu: [
label: 'Speech', { role: 'startSpeaking' },
submenu: [ { role: 'stopSpeaking' }
{ role: 'startSpeaking' }, ]
{ role: 'stopSpeaking' } }
] ]
: [
{ role: 'delete' },
{ type: 'separator' },
{ role: 'selectAll' }
])
]
},
// { role: 'viewMenu' }
{
label: 'View',
submenu: [
{ role: 'reload' },
{ role: 'forceReload' },
{ role: 'toggleDevTools' },
{ type: 'separator' },
{ role: 'resetZoom' },
{ role: 'zoomIn' },
{ role: 'zoomOut' },
{ type: 'separator' },
{ role: 'togglefullscreen' }
]
},
// { role: 'windowMenu' }
{
label: 'Window',
submenu: [
{ role: 'minimize' },
{ role: 'zoom' },
...(isMac
? [
{ type: 'separator' },
{ role: 'front' },
{ type: 'separator' },
{ role: 'window' }
]
: [
{ role: 'close' }
])
]
},
{
role: 'help',
submenu: [
{
label: 'Learn More',
click: async () => {
const { shell } = require('electron')
await shell.openExternal('http://www.huaruyu.com')
} }
]
: [
{ role: 'delete' },
{ type: 'separator' },
{ role: 'selectAll' }
])
]
},
// { role: 'viewMenu' }
{
label: 'View',
submenu: [
{ role: 'reload' },
{ role: 'forceReload' },
{ role: 'toggleDevTools' },
{ type: 'separator' },
{ role: 'resetZoom' },
{ role: 'zoomIn' },
{ role: 'zoomOut' },
{ type: 'separator' },
{ role: 'togglefullscreen' }
]
},
// { role: 'windowMenu' }
{
label: 'Window',
submenu: [
{ role: 'minimize' },
{ role: 'zoom' },
...(isMac
? [
{ type: 'separator' },
{ role: 'front' },
{ type: 'separator' },
{ role: 'window' }
]
: [
{ role: 'close' }
])
]
},
{
role: 'help',
submenu: [
{
label: 'Learn More',
click: async () => {
const { shell } = require('electron')
await shell.openExternal('http://www.huaruyu.com')
} }
} ]
] }
} ];
] }