KawAnime/store/index.js

391 lines
12 KiB
JavaScript
Raw Normal View History

2017-04-15 14:16:14 +00:00
//noinspection NpmUsedModulesInstalled
import Vue from 'vue'
//noinspection NpmUsedModulesInstalled
import Vuex from 'vuex'
import axios from 'axios'
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-05-03 18:22:07 +00:00
releasesUpdateTime: (new Date()).toLocaleTimeString(),
errorSnackbar: {
show: false,
text: ''
},
2017-05-03 18:22:07 +00:00
downloaderList: [],
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: [],
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: '',
searchInfo: {},
2017-04-30 16:13:42 +00:00
history: {},
historyModal: false
2017-04-15 14:16:14 +00:00
},
mutations: {
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-05-03 18:22:07 +00:00
setDownloaderList(state, data) {
state.downloaderList = data
console.log(`[${(new Date()).toLocaleTimeString()}]: ${data.length} anime name loaded.`)
},
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
2017-05-03 18:22:07 +00:00
console.log(`[${(new Date()).toLocaleTimeString()}]: Current directory now is ${state.currentDir}.`)
2017-04-15 14:16:14 +00:00
},
setWatchList: function (state, data) {
state.watchList = data
},
setSeen: function (state, data) {
state.seen = data
},
setWatching: function (state, data) {
state.watching = data
},
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
},
setConfig: function (state, data) {
state.config = data
},
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-05-03 18:22:07 +00:00
},
setReleasesUpdateTime(state, data) {
state.releasesUpdateTime = data
2017-04-15 14:16:14 +00:00
}
},
actions: {
2017-05-03 18:22:07 +00:00
async downloaderInit({commit}) {
const {data} = await axios.get('getAllShows.json')
commit('setDownloaderList', data)
},
async releasesInit({state, commit, dispatch}) {
2017-04-15 14:16:14 +00:00
console.log('[INIT] Releases')
2017-05-03 18:22:07 +00:00
const {data, status} = await axios.get(`getLatest.json?quality=${state.releaseQuality}`)
if (status === 200) commit('setReleases', data)
2017-05-01 21:41:35 +00:00
else if (status === 204)
{
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 () {
console.log(`[${(new Date()).toLocaleTimeString()}]: Retrying to get latest releases.`)
2017-05-03 18:22:07 +00:00
dispatch('refreshReleases').catch(err => {})
}, 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)
},
async listInit({commit}) {
console.log('[INIT] Watch List')
const {data} = await axios.get(`watchList.json?`)
console.log(`[${(new Date()).toLocaleTimeString()}]: Received watch lists.`)
commit('setWatchList', data.watchList)
commit('setSeen', data.seen)
commit('setWatching', data.watching)
},
2017-05-03 18:22:07 +00:00
async refreshReleases({state, commit, dispatch}) {
2017-04-15 14:16:14 +00:00
console.log(`[${(new Date()).toLocaleTimeString()}]: Refreshing Releases...`)
commit('emptyReleases')
2017-05-03 18:22:07 +00:00
const {data, status} = await axios.get(`getLatest.json?quality=${state.releaseQuality}`)
2017-04-15 14:16:14 +00:00
2017-05-03 18:22:07 +00:00
if (status === 200) commit('setReleases', data)
else if (status === 204)
{
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 () {
console.log(`[${(new Date()).toLocaleTimeString()}]: Retrying to get latest releases.`)
dispatch('refreshReleases').catch(err => {})
}, 30 * 1000)
}
2017-04-15 14:16:14 +00:00
},
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)
},
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')
},
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
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-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-05-03 18:22:07 +00:00
const {data, status} = await axios.post('download', {
name: name.replace('_', ' '),
quality: quality,
fromEp: fromEp,
untilEp: untilEp
})
2017-04-15 14:16:14 +00:00
state.downloaderForm.loading = false
2017-05-03 18:22:07 +00:00
if (status === 200)
{
console.log(`[${(new Date()).toLocaleTimeString()}]: Request fulfilled!`)
2017-04-15 14:16:14 +00:00
2017-05-03 18:22:07 +00:00
if (magnets === true)
{
const lastEp = fromEp !== '1' ? +fromEp + +data.length : data.length
2017-05-03 18:22:07 +00:00
console.log(`[${(new Date()).toLocaleTimeString()}]: User says he prefers having magnets hashes.`)
commit('setDownloaderModal', {
show: true,
title: `${name.replace('_', ' ')}\t ${fromEp} - ${lastEp}`,
2017-05-03 18:22:07 +00:00
text: data
})
}
else
{
console.log(`[${(new Date()).toLocaleTimeString()}]: Opening torrents directly on preferred torrent client.`)
2017-04-15 14:16:14 +00:00
2017-05-03 18:22:07 +00:00
data.forEach((link) => {
window.open(link)
})
}
2017-04-15 14:16:14 +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}`)
})
},
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}`)
})
},
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
}
}
})
store.commit('init')
2017-05-03 18:22:07 +00:00
store.dispatch('downloaderInit').catch(err => {})
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