added start / stop events; starting / stopping folder watcher.
This commit is contained in:
@@ -6,9 +6,19 @@ class FolderWatcher {
|
|||||||
this.window = window
|
this.window = window
|
||||||
this.state = state
|
this.state = state
|
||||||
this.torrentsFolderPath
|
this.torrentsFolderPath
|
||||||
|
this.watching = false
|
||||||
}
|
}
|
||||||
|
|
||||||
init () {
|
isEnabled () {
|
||||||
|
return this.state.saved.prefs.autoAddTorrents
|
||||||
|
}
|
||||||
|
|
||||||
|
start () {
|
||||||
|
log('--- FOLDER WATCHER --> START')
|
||||||
|
// Stop watching previous folder before
|
||||||
|
// start watching a new one.
|
||||||
|
if (this.watching) this.stop()
|
||||||
|
|
||||||
const torrentsFolderPath = this.state.saved.prefs.torrentsFolderPath
|
const torrentsFolderPath = this.state.saved.prefs.torrentsFolderPath
|
||||||
this.torrentsFolderPath = torrentsFolderPath
|
this.torrentsFolderPath = torrentsFolderPath
|
||||||
if (!torrentsFolderPath) return
|
if (!torrentsFolderPath) return
|
||||||
@@ -23,30 +33,15 @@ class FolderWatcher {
|
|||||||
log('-- torrent added: ', path)
|
log('-- torrent added: ', path)
|
||||||
this.window.dispatch('addTorrent', path)
|
this.window.dispatch('addTorrent', path)
|
||||||
})
|
})
|
||||||
}
|
|
||||||
|
|
||||||
start (torrentsFolderPath) {
|
this.watching = true
|
||||||
// Stop watching previous folder before
|
|
||||||
// start watching a new one.
|
|
||||||
if (this.torrentsFolderPath) {
|
|
||||||
this.stop()
|
|
||||||
}
|
|
||||||
|
|
||||||
const glob = `${torrentsFolderPath}/**/*.torrent`
|
|
||||||
log('Folder Watcher: watching: ', glob)
|
|
||||||
|
|
||||||
const options = {ignoreInitial: true}
|
|
||||||
this.watcher = chokidar.watch(glob, options)
|
|
||||||
this.watcher
|
|
||||||
.on('add', (path) => {
|
|
||||||
log('-- torrent added: ', path)
|
|
||||||
this.window.dispatch('addTorrent', path)
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
stop () {
|
stop () {
|
||||||
if (!this.watcher) return
|
log('--- FOLDER WATCHER --> STOP')
|
||||||
|
if (!this.watching) return
|
||||||
this.watcher.close()
|
this.watcher.close()
|
||||||
|
this.watching = false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -136,7 +136,11 @@ function delayedInit (state) {
|
|||||||
announcement.init()
|
announcement.init()
|
||||||
dock.init()
|
dock.init()
|
||||||
updater.init()
|
updater.init()
|
||||||
folderWatcher.init()
|
|
||||||
|
ipc.setModule('folderWatcher', folderWatcher)
|
||||||
|
if (folderWatcher.isEnabled()) {
|
||||||
|
folderWatcher.start()
|
||||||
|
}
|
||||||
|
|
||||||
if (process.platform === 'win32') {
|
if (process.platform === 'win32') {
|
||||||
const userTasks = require('./user-tasks')
|
const userTasks = require('./user-tasks')
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
module.exports = {
|
module.exports = {
|
||||||
init
|
init,
|
||||||
|
setModule
|
||||||
}
|
}
|
||||||
|
|
||||||
const electron = require('electron')
|
const electron = require('electron')
|
||||||
@@ -13,6 +14,14 @@ const windows = require('./windows')
|
|||||||
// Messages from the main process, to be sent once the WebTorrent process starts
|
// Messages from the main process, to be sent once the WebTorrent process starts
|
||||||
const messageQueueMainToWebTorrent = []
|
const messageQueueMainToWebTorrent = []
|
||||||
|
|
||||||
|
// Will hold modules injected from the app that will be used on fired
|
||||||
|
// IPC events.
|
||||||
|
const modules = {}
|
||||||
|
|
||||||
|
function setModule (name, module) {
|
||||||
|
modules[name] = module
|
||||||
|
}
|
||||||
|
|
||||||
function init () {
|
function init () {
|
||||||
const ipc = electron.ipcMain
|
const ipc = electron.ipcMain
|
||||||
|
|
||||||
@@ -106,6 +115,16 @@ function init () {
|
|||||||
thumbar.onPlayerPause()
|
thumbar.onPlayerPause()
|
||||||
})
|
})
|
||||||
|
|
||||||
|
ipc.on('startFolderWatcher', function () {
|
||||||
|
log('--- Torrent Watcher started')
|
||||||
|
modules['folderWatcher'].start()
|
||||||
|
})
|
||||||
|
|
||||||
|
ipc.on('stopFolderWatcher', function () {
|
||||||
|
log('--- Torrent Watcher stop')
|
||||||
|
modules['folderWatcher'].stop()
|
||||||
|
})
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Shell
|
* Shell
|
||||||
*/
|
*/
|
||||||
|
|||||||
@@ -111,6 +111,10 @@ function onState (err, _state) {
|
|||||||
update: createGetter(() => {
|
update: createGetter(() => {
|
||||||
const UpdateController = require('./controllers/update-controller')
|
const UpdateController = require('./controllers/update-controller')
|
||||||
return new UpdateController(state)
|
return new UpdateController(state)
|
||||||
|
}),
|
||||||
|
folderWatcher: createGetter(() => {
|
||||||
|
const FolderWatcherController = require('./controllers/folder-watcher-controller')
|
||||||
|
return new FolderWatcherController()
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -296,6 +300,8 @@ const dispatchHandlers = {
|
|||||||
'preferences': () => controllers.prefs().show(),
|
'preferences': () => controllers.prefs().show(),
|
||||||
'updatePreferences': (key, value) => controllers.prefs().update(key, value),
|
'updatePreferences': (key, value) => controllers.prefs().update(key, value),
|
||||||
'checkDownloadPath': checkDownloadPath,
|
'checkDownloadPath': checkDownloadPath,
|
||||||
|
'startFolderWatcher': () => controllers.folderWatcher().start(),
|
||||||
|
'stopFolderWatcher': () => controllers.folderWatcher().stop(),
|
||||||
|
|
||||||
// Update (check for new versions on Linux, where there's no auto updater)
|
// Update (check for new versions on Linux, where there's no auto updater)
|
||||||
'updateAvailable': (version) => controllers.update().updateAvailable(version),
|
'updateAvailable': (version) => controllers.update().updateAvailable(version),
|
||||||
|
|||||||
@@ -130,6 +130,13 @@ class PreferencesPage extends React.Component {
|
|||||||
}
|
}
|
||||||
|
|
||||||
dispatch('updatePreferences', 'autoAddTorrents', isChecked)
|
dispatch('updatePreferences', 'autoAddTorrents', isChecked)
|
||||||
|
|
||||||
|
if (isChecked) {
|
||||||
|
dispatch('startFolderWatcher', null)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
dispatch('stopFolderWatcher', null)
|
||||||
}
|
}
|
||||||
|
|
||||||
torrentsFolderPathSelector () {
|
torrentsFolderPathSelector () {
|
||||||
|
|||||||
Reference in New Issue
Block a user