* Add vue-rx, rxjs and lodash as dependencies * Added vue-rx plugin integration to nuxt config * Initial settings store implementation * Add babel plugin for private class properties to for Jest * Add DispatchingStore test spec * Initial settings code * Reactive Streams for fb current user and id token * Fix typo * Migrate index and graphql pages to the new store * Migrate network strategy to the new store * Fixed Section.vue errors * Fix getSettingSubject issue * Migrate fb settings reference in components to the new state system * Add typings for lodash as dev dependency * Load setting * Load initial sync setting values * Update proxy url * Add typescript support * Rewrite Settings store to TypeScript * Port Settings page to TypeScript as reference * Move all store migrations to a separate file * Delete test file for fb.js * Add ts-jest as dev dependency * Remove firebase-mock as dependency * Remove FRAME_COLORS_ENABLED settings value
28 lines
816 B
JavaScript
28 lines
816 B
JavaScript
import AxiosStrategy, { cancelRunningAxiosRequest } from "./strategies/AxiosStrategy"
|
|
import ExtensionStrategy, {
|
|
cancelRunningExtensionRequest,
|
|
hasExtensionInstalled,
|
|
} from "./strategies/ExtensionStrategy"
|
|
import { settingsStore } from "~/newstore/settings"
|
|
|
|
export const cancelRunningRequest = () => {
|
|
if (isExtensionsAllowed() && hasExtensionInstalled()) {
|
|
cancelRunningExtensionRequest()
|
|
} else {
|
|
cancelRunningAxiosRequest()
|
|
}
|
|
}
|
|
|
|
const isExtensionsAllowed = () => settingsStore.value.EXTENSIONS_ENABLED
|
|
|
|
const runAppropriateStrategy = (req) => {
|
|
if (isExtensionsAllowed() && hasExtensionInstalled()) {
|
|
return ExtensionStrategy(req)
|
|
}
|
|
|
|
return AxiosStrategy(req)
|
|
}
|
|
|
|
export const sendNetworkRequest = (req) =>
|
|
runAppropriateStrategy(req).finally(() => window.$nuxt.$loading.finish())
|