2017-04-15 14:16:14 +00:00
|
|
|
//noinspection NpmUsedModulesInstalled
|
|
|
|
import Vue from 'vue'
|
|
|
|
//noinspection NpmUsedModulesInstalled
|
|
|
|
import Vuex from 'vuex'
|
|
|
|
import axios from 'axios'
|
|
|
|
|
2017-04-28 10:08:01 +00:00
|
|
|
import {join} from 'path'
|
|
|
|
import {userInfo} from 'os'
|
|
|
|
import {readFileSync} from 'fs'
|
|
|
|
|
|
|
|
const configPath = join(userInfo().homedir, '.KawAnime', 'config.json')
|
|
|
|
const configFile = readFileSync(configPath)
|
|
|
|
|
|
|
|
const config = JSON.parse(configFile).config
|
|
|
|
|
|
|
|
// config file looks like this
|
|
|
|
// const config = {
|
|
|
|
// fansub: 'HorribleSubs',
|
|
|
|
// quality: '720p',
|
|
|
|
// sound: 'Nyanpasu',
|
|
|
|
// localPath: join(userInfo().homedir, 'Downloads'),
|
|
|
|
// inside: true,
|
|
|
|
// magnets: false
|
|
|
|
// }
|
|
|
|
|
2017-04-15 14:16:14 +00:00
|
|
|
Vue.use(Vuex)
|
|
|
|
|
|
|
|
const store = new Vuex.Store({
|
|
|
|
state: {
|
2017-04-27 20:48:03 +00:00
|
|
|
releaseFansub: '',
|
|
|
|
releaseQuality: '',
|
2017-04-15 14:16:14 +00:00
|
|
|
releases: [],
|
2017-04-29 10:53:01 +00:00
|
|
|
errorSnackbar: {
|
|
|
|
show: false,
|
|
|
|
text: ''
|
|
|
|
},
|
2017-04-15 14:16:14 +00:00
|
|
|
downloaderForm: {
|
|
|
|
name: '',
|
|
|
|
fromEp: '',
|
|
|
|
untilEp: '',
|
2017-04-27 20:48:03 +00:00
|
|
|
quality: '',
|
2017-04-15 14:16:14 +00:00
|
|
|
loading: false
|
|
|
|
},
|
|
|
|
downloaderModal: {
|
|
|
|
show: false,
|
|
|
|
title: '',
|
|
|
|
text: ''
|
|
|
|
},
|
|
|
|
seasons: [],
|
|
|
|
seasonsStats: {},
|
|
|
|
year: 2017,
|
|
|
|
season: 'spring',
|
|
|
|
news: [],
|
|
|
|
inside: true,
|
|
|
|
localFiles: [],
|
2017-04-20 06:23:25 +00:00
|
|
|
watchList: [],
|
|
|
|
seen: [],
|
|
|
|
watching: [],
|
2017-04-27 20:48:03 +00:00
|
|
|
config: {},
|
|
|
|
configDir: '',
|
|
|
|
currentDir: '',
|
2017-04-16 13:18:34 +00:00
|
|
|
searchInputModal: false,
|
|
|
|
searchInput: '',
|
2017-04-24 21:49:56 +00:00
|
|
|
searchInfo: {},
|
2017-04-30 16:13:42 +00:00
|
|
|
history: {},
|
|
|
|
historyModal: false
|
2017-04-15 14:16:14 +00:00
|
|
|
},
|
|
|
|
mutations: {
|
2017-04-28 10:08:01 +00:00
|
|
|
init(state) {
|
2017-04-27 20:48:03 +00:00
|
|
|
config.inside = config.inside.toString()
|
|
|
|
|
|
|
|
state.releaseFansub = config.fansub
|
|
|
|
state.releaseQuality = config.quality
|
|
|
|
state.downloaderForm.quality = config.quality
|
|
|
|
state.configDir = config.localPath
|
|
|
|
state.currentDir = config.localPath
|
|
|
|
|
|
|
|
state.config = config
|
|
|
|
},
|
2017-04-29 19:07:04 +00:00
|
|
|
setErrorSnackbar(state, data) {
|
|
|
|
state.errorSnackbar.text = data
|
|
|
|
state.errorSnackbar.show = true
|
|
|
|
},
|
2017-04-15 14:16:14 +00:00
|
|
|
setCurrentSeason(state, data) {
|
|
|
|
state.year = data.year
|
|
|
|
state.season = data.season
|
|
|
|
},
|
|
|
|
setSeasons: function (state, data) {
|
|
|
|
state.seasons = data.info
|
|
|
|
state.seasonsStats = data.stats
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Seasons set.`)
|
|
|
|
},
|
|
|
|
emptySeasons: function (state) {
|
|
|
|
state.seasons = []
|
|
|
|
},
|
|
|
|
emptyReleases: function (state) {
|
|
|
|
state.releases = []
|
|
|
|
},
|
|
|
|
setReleases: function (state, data) {
|
|
|
|
state.releases = data
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Releases updated.`)
|
|
|
|
},
|
|
|
|
emptyNews: function (state) {
|
|
|
|
state.news = []
|
|
|
|
},
|
|
|
|
setNews: function (state, data) {
|
|
|
|
state.news = data
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: News updated.`)
|
|
|
|
},
|
|
|
|
emptyLocals: function (state) {
|
|
|
|
state.localFiles = []
|
|
|
|
},
|
|
|
|
setLocalFiles: function (state, data) {
|
|
|
|
state.localFiles = data
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Local files updated.`)
|
|
|
|
},
|
|
|
|
setCurrentDir: function (state, data) {
|
|
|
|
state.currentDir = data
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Current directory now is ${state.currentDir}`)
|
|
|
|
},
|
2017-04-20 06:23:25 +00:00
|
|
|
setWatchList: function (state, data) {
|
|
|
|
state.watchList = data
|
|
|
|
},
|
|
|
|
setSeen: function (state, data) {
|
|
|
|
state.seen = data
|
|
|
|
},
|
|
|
|
setWatching: function (state, data) {
|
|
|
|
state.watching = data
|
|
|
|
},
|
2017-04-16 10:57:28 +00:00
|
|
|
setConfigDir: function (state, data) {
|
|
|
|
state.configDir = data
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Config directory now is ${state.currentDir}`)
|
|
|
|
},
|
2017-04-15 14:16:14 +00:00
|
|
|
setDownloaderValues: function (state, data) {
|
|
|
|
state.downloaderForm = data
|
|
|
|
},
|
|
|
|
setQuality: function (state, quality) {
|
|
|
|
state.downloaderForm.quality = quality
|
|
|
|
},
|
|
|
|
setDownloaderModal: function (state, data) {
|
|
|
|
state.downloaderModal = data
|
|
|
|
},
|
|
|
|
showDownloaderModal: function (state, value) {
|
|
|
|
state.downloaderModal.show = value
|
2017-04-16 10:57:28 +00:00
|
|
|
},
|
|
|
|
setConfig: function (state, data) {
|
|
|
|
state.config = data
|
2017-04-24 21:49:56 +00:00
|
|
|
},
|
|
|
|
setHistory: function (state, data) {
|
|
|
|
state.history = data
|
2017-04-30 16:13:42 +00:00
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: History updated.`)
|
|
|
|
},
|
|
|
|
setHistoryModal: function (state, data) {
|
|
|
|
state.historyModal = data
|
2017-04-15 14:16:14 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
actions: {
|
2017-04-29 21:39:29 +00:00
|
|
|
async releasesInit({state, commit, dispatch}) {
|
2017-04-15 14:16:14 +00:00
|
|
|
console.log('[INIT] Releases')
|
2017-04-29 10:53:01 +00:00
|
|
|
const {data, status} = await axios.get(`releases.json?fansub=${state.releaseFansub}&quality=${state.releaseQuality}`)
|
|
|
|
|
|
|
|
if (status === 200) commit('setReleases', data)
|
|
|
|
else
|
|
|
|
{
|
2017-04-29 19:07:04 +00:00
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: An error occurred while getting the latest releases. Retrying in 30 seconds.`)
|
|
|
|
commit('setErrorSnackbar', 'Could not get the latest releases. Retrying in 30 seconds.')
|
|
|
|
setTimeout(function () {
|
2017-04-29 10:53:01 +00:00
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Retrying to get latest releases.`)
|
2017-04-29 21:39:29 +00:00
|
|
|
dispatch('releasesInit')
|
2017-04-29 10:53:01 +00:00
|
|
|
}, 30 * 1000)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
,
|
2017-04-15 14:16:14 +00:00
|
|
|
async seasonsInit({state, commit}) {
|
|
|
|
console.log('[INIT] Seasons')
|
|
|
|
const {data} = await axios.get(`seasons.json?year=${state.year}&season=${state.season}`)
|
|
|
|
|
|
|
|
commit('setSeasons', data)
|
|
|
|
},
|
|
|
|
async newsInit({commit}) {
|
|
|
|
console.log('[INIT] News')
|
|
|
|
const {data} = await axios.get('news.json')
|
|
|
|
|
|
|
|
commit('setNews', data)
|
|
|
|
},
|
|
|
|
async localInit({state, commit}) {
|
|
|
|
console.log('[INIT] Local Files')
|
|
|
|
|
|
|
|
const {data} = await axios.get(`local.json?dir=${state.currentDir}`)
|
|
|
|
|
|
|
|
commit('setLocalFiles', data)
|
|
|
|
},
|
2017-04-20 06:23:25 +00:00
|
|
|
async listInit({commit}) {
|
|
|
|
console.log('[INIT] Watch List')
|
|
|
|
|
|
|
|
const {data} = await axios.get(`watchList.json?`)
|
|
|
|
|
2017-04-20 22:18:50 +00:00
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Received watch lists.`)
|
2017-04-20 06:23:25 +00:00
|
|
|
|
|
|
|
commit('setWatchList', data.watchList)
|
|
|
|
commit('setSeen', data.seen)
|
|
|
|
commit('setWatching', data.watching)
|
|
|
|
},
|
2017-04-22 10:34:50 +00:00
|
|
|
async refreshReleases({state, commit}) {
|
2017-04-15 14:16:14 +00:00
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Refreshing Releases...`)
|
|
|
|
|
|
|
|
commit('emptyReleases')
|
|
|
|
|
2017-04-22 10:34:50 +00:00
|
|
|
const {data} = await axios.get(`releases.json?fansub=${state.releaseFansub}&quality=${state.releaseQuality}`)
|
2017-04-15 14:16:14 +00:00
|
|
|
|
|
|
|
commit('setReleases', data)
|
|
|
|
},
|
|
|
|
async refreshSeasons({state, commit}) {
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Refreshing Seasons...`)
|
|
|
|
|
|
|
|
commit('emptySeasons')
|
|
|
|
|
|
|
|
const year = state.year
|
|
|
|
const season = state.season
|
|
|
|
const {data} = await axios.get(`seasons.json?year=${year}&season=${season}`)
|
|
|
|
commit('setSeasons', data)
|
|
|
|
|
|
|
|
console.log('Seasons refreshed.')
|
|
|
|
},
|
|
|
|
async refreshNews({commit}) {
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Refreshing News...`)
|
|
|
|
|
|
|
|
commit('emptyNews')
|
|
|
|
|
|
|
|
const {data} = await axios.get('news.json')
|
|
|
|
|
|
|
|
commit('setNews', data)
|
|
|
|
},
|
|
|
|
async refreshLocal({commit, state}) {
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Refreshing Local files...`)
|
|
|
|
|
|
|
|
const {data} = await axios.get(`local.json?dir=${state.currentDir}`)
|
|
|
|
|
|
|
|
commit('setLocalFiles', data)
|
|
|
|
},
|
2017-04-23 00:11:51 +00:00
|
|
|
async resetLocal({dispatch}) {
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Resetting local information...`)
|
|
|
|
|
|
|
|
axios.get('resetLocal').then(({status}) => {
|
|
|
|
if (status !== 200)
|
|
|
|
{
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Server failed to suppress old data with code ${status}...`)
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Retrying in 5 seconds...`)
|
|
|
|
|
|
|
|
setTimeout(dispatch('resetLocal'), 5 * 1000)
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
dispatch('refreshLocal').then(
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Reset completed.`)
|
|
|
|
)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
},
|
2017-04-15 14:16:14 +00:00
|
|
|
async changePath({commit, dispatch}) {
|
2017-04-27 19:05:55 +00:00
|
|
|
const {data} = await axios.get('openThis?type=dialog')
|
|
|
|
|
|
|
|
commit('emptyLocals')
|
|
|
|
commit('setCurrentDir', data.path)
|
|
|
|
dispatch('refreshLocal')
|
2017-04-16 10:57:28 +00:00
|
|
|
},
|
|
|
|
async changePathWithConfig({commit, dispatch}) {
|
2017-04-27 19:05:55 +00:00
|
|
|
const {data} = await axios.get('openThis?type=dialog')
|
|
|
|
|
|
|
|
commit('emptyLocals')
|
|
|
|
commit('setCurrentDir', data.path)
|
|
|
|
commit('setConfigDir', data.path)
|
|
|
|
dispatch('refreshLocal')
|
2017-04-15 14:16:14 +00:00
|
|
|
},
|
|
|
|
async openNewsLink({state}, link) {
|
2017-04-27 19:05:55 +00:00
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Opening a link`)
|
2017-04-15 14:16:14 +00:00
|
|
|
|
2017-04-22 10:34:50 +00:00
|
|
|
if ((state.config.inside === 'true' ) === false)
|
2017-04-15 14:16:14 +00:00
|
|
|
await axios.get(`openThis?type=link&link=${link}`)
|
|
|
|
else
|
2017-04-27 19:05:55 +00:00
|
|
|
await axios.get(`openThis?type=insideLink&link=${link}`)
|
2017-04-15 14:16:14 +00:00
|
|
|
},
|
|
|
|
async download({state, commit}) {
|
|
|
|
const name = state.downloaderForm.name.replace(' ', '_')
|
|
|
|
const fromEp = state.downloaderForm.fromEp !== ''
|
|
|
|
? state.downloaderForm.fromEp
|
|
|
|
: 0
|
|
|
|
const untilEp = state.downloaderForm.untilEp !== ''
|
|
|
|
? state.downloaderForm.untilEp
|
|
|
|
: 20000
|
|
|
|
const quality = state.downloaderForm.quality
|
|
|
|
|
2017-04-16 13:18:34 +00:00
|
|
|
const magnets = state.config.magnets
|
2017-04-16 13:22:31 +00:00
|
|
|
const fansub = state.config.fansub
|
2017-04-15 14:16:14 +00:00
|
|
|
|
2017-04-25 19:55:30 +00:00
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Received a request to download ${name} from ep ${fromEp} to ep ${untilEp}. Transmitting...`)
|
2017-04-15 14:16:14 +00:00
|
|
|
|
2017-04-16 13:22:31 +00:00
|
|
|
const {data, status} = await axios.get(
|
|
|
|
`download?name=${name}&fromEp=${fromEp}&untilEp=${untilEp}&quality=${quality}&magnets=${magnets}&fansub=${fansub}`)
|
2017-04-15 14:16:14 +00:00
|
|
|
|
|
|
|
status === 404
|
2017-04-25 19:55:30 +00:00
|
|
|
? console.log(`[${(new Date()).toLocaleTimeString()}]: Oops. It looks like something went wrong. Please check your internet connection and retry.`)
|
|
|
|
: console.log(`[${(new Date()).toLocaleTimeString()}]: Request fulfilled!`)
|
2017-04-15 14:16:14 +00:00
|
|
|
|
|
|
|
state.downloaderForm.loading = false
|
|
|
|
|
|
|
|
let magnetLinks = []
|
|
|
|
|
|
|
|
data.links.forEach((link) => {
|
|
|
|
magnets === true
|
|
|
|
? magnetLinks.push(link)
|
|
|
|
: window.open(link)
|
|
|
|
})
|
|
|
|
|
|
|
|
if (magnets === true)
|
|
|
|
{
|
2017-04-25 19:55:30 +00:00
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: User says he prefers having magnets hashes.`)
|
2017-04-15 14:16:14 +00:00
|
|
|
commit('setDownloaderModal', {
|
|
|
|
show: true,
|
|
|
|
title: `${name.replace('_', ' ')}\t ${fromEp} - ${untilEp}`,
|
|
|
|
text: magnetLinks
|
|
|
|
})
|
|
|
|
}
|
|
|
|
else
|
2017-04-25 19:55:30 +00:00
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Opening torrents directly on preferred torrent client.`)
|
2017-04-16 10:57:28 +00:00
|
|
|
},
|
2017-04-27 21:38:07 +00:00
|
|
|
saveConfig({}, data) {
|
|
|
|
axios.post('saveConfig', JSON.stringify(data)).then((res) => {
|
|
|
|
if (res.status === 200)
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Successfully updated config!`)
|
|
|
|
}).catch((err) => {
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: An error occurred while saving config: ${err}`)
|
2017-04-16 10:57:28 +00:00
|
|
|
})
|
2017-04-24 21:49:56 +00:00
|
|
|
},
|
2017-04-29 10:53:01 +00:00
|
|
|
appendHistory({}, data) {
|
|
|
|
axios.post('appendHistory', JSON.stringify(data)).then(() => {
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: Successfully appended to history.`)
|
|
|
|
}).catch((err) => {
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: An error occurred while appending to history... ${err}`)
|
|
|
|
})
|
2017-04-24 21:49:56 +00:00
|
|
|
},
|
|
|
|
async getHistory({commit}) {
|
|
|
|
const {data, status} = await axios.get('getHistory?')
|
|
|
|
|
|
|
|
if (status !== 200)
|
|
|
|
console.log(`[${(new Date()).toLocaleTimeString()}]: An error occurred while gathering the history.`)
|
|
|
|
|
|
|
|
commit('setHistory', data)
|
2017-04-15 14:16:14 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
2017-04-28 10:08:01 +00:00
|
|
|
store.commit('init')
|
|
|
|
|
2017-04-29 10:53:01 +00:00
|
|
|
store.dispatch('releasesInit').catch(err => {})
|
|
|
|
store.dispatch('seasonsInit').catch(err => {})
|
|
|
|
store.dispatch('newsInit').catch(err => {})
|
|
|
|
store.dispatch('localInit').catch(err => {})
|
|
|
|
store.dispatch('listInit').catch(err => {})
|
2017-04-30 16:13:42 +00:00
|
|
|
store.dispatch('getHistory').catch(err => {})
|
2017-04-27 20:48:03 +00:00
|
|
|
|
2017-04-15 14:16:14 +00:00
|
|
|
|
|
|
|
export default store
|