feat:打开目录,读取文件及文件夹内容
This commit is contained in:
parent
8bcc7ccb1f
commit
1b66d3aa6d
17
main.js
17
main.js
|
@ -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')
|
||||||
|
|
|
@ -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')
|
|
||||||
}
|
}
|
||||||
}
|
]
|
||||||
]
|
}
|
||||||
}
|
];
|
||||||
]
|
}
|
||||||
|
|
Loading…
Reference in New Issue