2017-11-27 19:21:12 -05:00
|
|
|
'use strict'
|
|
|
|
|
2017-11-29 10:13:35 -05:00
|
|
|
import uploader from './utils/uploader.js'
|
2017-11-27 19:21:12 -05:00
|
|
|
import { app, BrowserWindow, Tray, Menu, Notification, clipboard, ipcMain } from 'electron'
|
2017-11-28 10:56:15 -05:00
|
|
|
import db from '../datastore'
|
|
|
|
import pasteTemplate from './utils/pasteTemplate'
|
2017-11-27 19:21:12 -05:00
|
|
|
/**
|
|
|
|
* Set `__static` path to static files in production
|
|
|
|
* https://simulatedgreg.gitbooks.io/electron-vue/content/en/using-static-assets.html
|
|
|
|
*/
|
|
|
|
if (process.env.NODE_ENV !== 'development') {
|
|
|
|
global.__static = require('path').join(__dirname, '/static').replace(/\\/g, '\\\\')
|
|
|
|
}
|
|
|
|
|
|
|
|
let window
|
|
|
|
let settingWindow
|
|
|
|
let tray
|
2017-12-15 04:37:38 -05:00
|
|
|
let menu
|
2017-11-27 19:21:12 -05:00
|
|
|
const winURL = process.env.NODE_ENV === 'development'
|
|
|
|
? `http://localhost:9080`
|
|
|
|
: `file://${__dirname}/index.html`
|
|
|
|
const settingWinURL = process.env.NODE_ENV === 'development'
|
|
|
|
? `http://localhost:9080/#setting/upload`
|
|
|
|
: `file://${__dirname}/index.html#setting/upload`
|
|
|
|
|
2017-12-22 09:30:16 -05:00
|
|
|
const uploadFailed = () => {
|
|
|
|
const notification = new Notification({
|
|
|
|
title: '上传失败',
|
|
|
|
body: '请检查你的图床配置!'
|
|
|
|
})
|
|
|
|
notification.show()
|
|
|
|
}
|
|
|
|
|
2017-11-27 19:21:12 -05:00
|
|
|
function createTray () {
|
2017-12-08 02:52:41 -05:00
|
|
|
tray = new Tray(`${__static}/menubar.png`)
|
2017-11-27 19:21:12 -05:00
|
|
|
const contextMenu = Menu.buildFromTemplate([
|
|
|
|
{
|
2017-11-28 10:56:15 -05:00
|
|
|
label: '打开详细窗口',
|
2017-11-27 19:21:12 -05:00
|
|
|
click () {
|
|
|
|
if (settingWindow === null) {
|
|
|
|
createSettingWindow()
|
2017-12-11 08:52:14 -05:00
|
|
|
settingWindow.show()
|
2017-11-27 19:21:12 -05:00
|
|
|
} else {
|
|
|
|
settingWindow.show()
|
|
|
|
settingWindow.focus()
|
|
|
|
}
|
|
|
|
}
|
2017-11-28 10:56:15 -05:00
|
|
|
},
|
|
|
|
{
|
|
|
|
label: '选择默认图床',
|
|
|
|
type: 'submenu',
|
|
|
|
submenu: [
|
|
|
|
{
|
|
|
|
label: '微博图床',
|
|
|
|
type: 'radio',
|
2017-11-29 03:23:05 -05:00
|
|
|
checked: db.read().get('picBed.current').value() === 'weibo',
|
|
|
|
click () {
|
|
|
|
db.read().set('picBed.current', 'weibo')
|
|
|
|
.write()
|
|
|
|
}
|
2017-11-28 10:56:15 -05:00
|
|
|
},
|
|
|
|
{
|
|
|
|
label: '七牛图床',
|
|
|
|
type: 'radio',
|
|
|
|
checked: db.read().get('picBed.current').value() === 'qiniu',
|
|
|
|
click () {
|
|
|
|
db.read().set('picBed.current', 'qiniu')
|
|
|
|
.write()
|
|
|
|
}
|
2017-12-20 22:18:54 -05:00
|
|
|
},
|
|
|
|
{
|
|
|
|
label: '腾讯云COS',
|
|
|
|
type: 'radio',
|
|
|
|
checked: db.read().get('picBed.current').value() === 'tcyun',
|
|
|
|
click () {
|
|
|
|
db.read().set('picBed.current', 'tcyun')
|
|
|
|
.write()
|
|
|
|
}
|
2017-12-22 09:30:16 -05:00
|
|
|
},
|
|
|
|
{
|
|
|
|
label: '又拍云图床',
|
|
|
|
type: 'radio',
|
|
|
|
checked: db.read().get('picBed.current').value() === 'upyun',
|
|
|
|
click () {
|
|
|
|
db.read().set('picBed.current', 'upyun')
|
|
|
|
.write()
|
|
|
|
}
|
2017-11-28 10:56:15 -05:00
|
|
|
}
|
|
|
|
]
|
2017-12-11 08:52:14 -05:00
|
|
|
},
|
|
|
|
{
|
|
|
|
role: 'quit',
|
|
|
|
label: '退出'
|
2017-11-27 19:21:12 -05:00
|
|
|
}
|
|
|
|
])
|
|
|
|
tray.on('right-click', () => {
|
|
|
|
window.hide()
|
|
|
|
tray.popUpContextMenu(contextMenu)
|
|
|
|
})
|
|
|
|
tray.on('click', () => {
|
|
|
|
let img = clipboard.readImage()
|
|
|
|
let obj = []
|
|
|
|
if (!img.isEmpty()) {
|
2017-11-29 10:13:35 -05:00
|
|
|
// 从剪贴板来的图片默认转为png
|
|
|
|
const imgUrl = 'data:image/png;base64,' + Buffer.from(img.toPNG(), 'binary').toString('base64')
|
2017-11-27 19:21:12 -05:00
|
|
|
obj.push({
|
|
|
|
width: img.getSize().width,
|
|
|
|
height: img.getSize().height,
|
2017-11-29 10:13:35 -05:00
|
|
|
imgUrl
|
2017-11-27 19:21:12 -05:00
|
|
|
})
|
|
|
|
}
|
|
|
|
toggleWindow()
|
|
|
|
setTimeout(() => {
|
|
|
|
window.webContents.send('clipboardFiles', obj)
|
|
|
|
}, 0)
|
|
|
|
})
|
|
|
|
|
|
|
|
tray.on('drag-enter', () => {
|
|
|
|
tray.setImage(`${__static}/upload.png`)
|
|
|
|
})
|
|
|
|
|
|
|
|
tray.on('drag-end', () => {
|
2017-12-11 08:52:14 -05:00
|
|
|
tray.setImage(`${__static}/menubar.png`)
|
2017-11-27 19:21:12 -05:00
|
|
|
})
|
|
|
|
|
|
|
|
tray.on('drop-files', async (event, files) => {
|
2017-11-29 10:13:35 -05:00
|
|
|
const pasteStyle = db.read().get('picBed.pasteStyle').value() || 'markdown'
|
|
|
|
const imgs = await uploader(files, 'imgFromPath', window.webContents)
|
2017-12-22 09:30:16 -05:00
|
|
|
if (imgs !== false) {
|
|
|
|
for (let i in imgs) {
|
|
|
|
clipboard.writeText(pasteTemplate(pasteStyle, imgs[i].imgUrl))
|
|
|
|
const notification = new Notification({
|
|
|
|
title: '上传成功',
|
|
|
|
body: imgs[i].imgUrl,
|
|
|
|
icon: files[i]
|
|
|
|
})
|
|
|
|
setTimeout(() => {
|
|
|
|
notification.show()
|
|
|
|
}, i * 100)
|
|
|
|
}
|
|
|
|
window.webContents.send('dragFiles', imgs)
|
|
|
|
} else {
|
|
|
|
uploadFailed()
|
2017-11-27 19:21:12 -05:00
|
|
|
}
|
|
|
|
})
|
2017-12-08 02:52:41 -05:00
|
|
|
// toggleWindow()
|
2017-11-27 19:21:12 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
const createWindow = () => {
|
|
|
|
window = new BrowserWindow({
|
|
|
|
height: 350,
|
|
|
|
width: 196, // 196
|
|
|
|
show: false,
|
|
|
|
frame: false,
|
|
|
|
fullscreenable: false,
|
|
|
|
resizable: false,
|
|
|
|
transparent: true,
|
|
|
|
vibrancy: 'ultra-dark',
|
|
|
|
webPreferences: {
|
|
|
|
backgroundThrottling: false
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
window.loadURL(winURL)
|
|
|
|
|
|
|
|
window.on('closed', () => {
|
|
|
|
window = null
|
|
|
|
})
|
|
|
|
|
|
|
|
window.on('blur', () => {
|
|
|
|
window.hide()
|
|
|
|
})
|
|
|
|
|
|
|
|
createSettingWindow()
|
|
|
|
}
|
|
|
|
|
|
|
|
const createSettingWindow = () => {
|
|
|
|
settingWindow = new BrowserWindow({
|
|
|
|
height: 450,
|
|
|
|
width: 800,
|
2017-12-08 02:52:41 -05:00
|
|
|
show: false,
|
2017-11-27 19:21:12 -05:00
|
|
|
frame: true,
|
|
|
|
center: true,
|
|
|
|
fullscreenable: false,
|
|
|
|
resizable: false,
|
|
|
|
title: 'Pic',
|
|
|
|
vibrancy: 'ultra-dark',
|
|
|
|
transparent: true,
|
|
|
|
titleBarStyle: 'hidden',
|
|
|
|
webPreferences: {
|
|
|
|
backgroundThrottling: false
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
settingWindow.loadURL(settingWinURL)
|
|
|
|
|
|
|
|
settingWindow.on('closed', () => {
|
|
|
|
settingWindow = null
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2017-12-15 04:37:38 -05:00
|
|
|
const createMenu = () => {
|
|
|
|
const template = [{
|
|
|
|
label: 'Edit',
|
|
|
|
submenu: [
|
|
|
|
{ label: 'Undo', accelerator: 'CmdOrCtrl+Z', selector: 'undo:' },
|
|
|
|
{ label: 'Redo', accelerator: 'Shift+CmdOrCtrl+Z', selector: 'redo:' },
|
|
|
|
{ type: 'separator' },
|
|
|
|
{ label: 'Cut', accelerator: 'CmdOrCtrl+X', selector: 'cut:' },
|
|
|
|
{ label: 'Copy', accelerator: 'CmdOrCtrl+C', selector: 'copy:' },
|
|
|
|
{ label: 'Paste', accelerator: 'CmdOrCtrl+V', selector: 'paste:' },
|
|
|
|
{ label: 'Select All', accelerator: 'CmdOrCtrl+A', selector: 'selectAll:' },
|
|
|
|
{
|
|
|
|
label: 'Quit',
|
|
|
|
accelerator: 'CmdOrCtrl+Q',
|
|
|
|
click () {
|
|
|
|
app.quit()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
]
|
|
|
|
}]
|
|
|
|
menu = Menu.buildFromTemplate(template)
|
|
|
|
Menu.setApplicationMenu(menu)
|
|
|
|
}
|
|
|
|
|
2017-11-27 19:21:12 -05:00
|
|
|
const getWindowPosition = () => {
|
|
|
|
const windowBounds = window.getBounds()
|
|
|
|
const trayBounds = tray.getBounds()
|
|
|
|
const x = Math.round(trayBounds.x + (trayBounds.width / 2) - (windowBounds.width / 2))
|
|
|
|
const y = Math.round(trayBounds.y + trayBounds.height - 10)
|
|
|
|
|
|
|
|
return {
|
|
|
|
x,
|
|
|
|
y
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const toggleWindow = () => {
|
|
|
|
if (window.isVisible()) {
|
|
|
|
window.hide()
|
|
|
|
} else {
|
|
|
|
showWindow()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const showWindow = () => {
|
|
|
|
const position = getWindowPosition()
|
|
|
|
window.setPosition(position.x, position.y, false)
|
2017-12-07 01:33:14 -05:00
|
|
|
window.webContents.send('updateFiles')
|
2017-11-27 19:21:12 -05:00
|
|
|
window.show()
|
|
|
|
window.focus()
|
|
|
|
}
|
|
|
|
|
|
|
|
ipcMain.on('uploadClipboardFiles', async (evt, file) => {
|
2017-11-29 10:13:35 -05:00
|
|
|
const img = await uploader(file, 'imgFromClipboard', window.webContents)
|
2017-12-22 09:30:16 -05:00
|
|
|
if (img !== false) {
|
|
|
|
const pasteStyle = db.read().get('picBed.pasteStyle').value() || 'markdown'
|
|
|
|
clipboard.writeText(pasteTemplate(pasteStyle, img[0].imgUrl))
|
|
|
|
const notification = new Notification({
|
|
|
|
title: '上传成功',
|
|
|
|
body: img[0].imgUrl,
|
|
|
|
icon: file[0]
|
|
|
|
})
|
|
|
|
notification.show()
|
|
|
|
window.webContents.send('clipboardFiles', [])
|
|
|
|
window.webContents.send('uploadFiles', img)
|
|
|
|
} else {
|
|
|
|
uploadFailed()
|
|
|
|
}
|
2017-11-28 10:56:15 -05:00
|
|
|
})
|
|
|
|
|
|
|
|
ipcMain.on('uploadChoosedFiles', async (evt, files) => {
|
2017-11-29 10:13:35 -05:00
|
|
|
const imgs = await uploader(files, 'imgFromUploader', settingWindow.webContents)
|
2017-12-22 09:30:16 -05:00
|
|
|
if (imgs !== false) {
|
|
|
|
const pasteStyle = db.read().get('picBed.pasteStyle').value() || 'markdown'
|
|
|
|
let pasteText = ''
|
|
|
|
for (let i in imgs) {
|
|
|
|
pasteText += pasteTemplate(pasteStyle, imgs[i].imgUrl) + '\r\n'
|
|
|
|
const notification = new Notification({
|
|
|
|
title: '上传成功',
|
|
|
|
body: imgs[i].imgUrl,
|
|
|
|
icon: files[i].path
|
|
|
|
})
|
|
|
|
setTimeout(() => {
|
|
|
|
notification.show()
|
|
|
|
}, i * 100)
|
|
|
|
}
|
|
|
|
clipboard.writeText(pasteText)
|
|
|
|
window.webContents.send('uploadFiles', imgs)
|
|
|
|
} else {
|
|
|
|
uploadFailed()
|
2017-11-28 10:56:15 -05:00
|
|
|
}
|
2017-11-27 19:21:12 -05:00
|
|
|
})
|
|
|
|
|
|
|
|
app.on('ready', () => {
|
|
|
|
createWindow()
|
|
|
|
createTray()
|
2017-12-15 04:37:38 -05:00
|
|
|
createMenu()
|
2017-11-27 19:21:12 -05:00
|
|
|
})
|
|
|
|
|
|
|
|
app.on('window-all-closed', () => {
|
|
|
|
if (process.platform !== 'darwin') {
|
|
|
|
app.quit()
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
app.on('activate', () => {
|
|
|
|
if (window === null || settingWindow === null) {
|
|
|
|
createWindow()
|
|
|
|
createTray()
|
2017-12-15 04:37:38 -05:00
|
|
|
createMenu()
|
2017-11-27 19:21:12 -05:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Auto Updater
|
|
|
|
*
|
|
|
|
* Uncomment the following code below and install `electron-updater` to
|
|
|
|
* support auto updating. Code Signing with a valid certificate is required.
|
|
|
|
* https://simulatedgreg.gitbooks.io/electron-vue/content/en/using-electron-builder.html#auto-updating
|
|
|
|
*/
|
|
|
|
|
|
|
|
// import { autoUpdater } from 'electron-updater'
|
|
|
|
|
|
|
|
// autoUpdater.on('update-downloaded', () => {
|
|
|
|
// autoUpdater.quitAndInstall()
|
|
|
|
// })
|
|
|
|
|
|
|
|
// app.on('ready', () => {
|
|
|
|
// if (process.env.NODE_ENV === 'production') {
|
|
|
|
// autoUpdater.checkForUpdates()
|
|
|
|
// }
|
|
|
|
// })
|