aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAndrey Borysenko <andrey18106x@gmail.com>2024-10-29 14:02:40 +0200
committerAndrey Borysenko <andrey18106x@gmail.com>2024-10-30 20:36:58 +0200
commit41c61c31e269ed200d3f9f9b852ae614d2cc6456 (patch)
tree1101fa4417252b675613b5253489e8c5bbf1febb
parent6be8cbd16d49f584b6632eb6697cb3472958456a (diff)
downloadnextcloud-server-41c61c31e269ed200d3f9f9b852ae614d2cc6456.tar.gz
nextcloud-server-41c61c31e269ed200d3f9f9b852ae614d2cc6456.zip
fix: loading state reactivity
Signed-off-by: Andrey Borysenko <andrey18106x@gmail.com>
-rw-r--r--apps/settings/src/store/app-api-store.ts52
1 files changed, 28 insertions, 24 deletions
diff --git a/apps/settings/src/store/app-api-store.ts b/apps/settings/src/store/app-api-store.ts
index 3a7bd676a91..ff7a56c6d03 100644
--- a/apps/settings/src/store/app-api-store.ts
+++ b/apps/settings/src/store/app-api-store.ts
@@ -15,7 +15,7 @@ import api from './api'
import logger from '../logger'
import type { IAppstoreExApp, IDeployDaemon, IExAppStatus } from '../app-types'
-import { reactive } from 'vue'
+import Vue from 'vue'
interface AppApiState {
apps: IAppstoreExApp[]
@@ -31,7 +31,7 @@ export const useAppApiStore = defineStore('app-api-apps', {
state: (): AppApiState => ({
apps: [],
updateCount: loadState('settings', 'appstoreExAppUpdateCount', 0),
- loading: reactive({}),
+ loading: {},
loadingList: false,
statusUpdater: null,
daemonAccessible: loadState('settings', 'defaultDaemonConfigAccessible', false),
@@ -62,6 +62,10 @@ export const useAppApiStore = defineStore('app-api-apps', {
logger.error(error)
},
+ setLoading(id: string, value: boolean) {
+ Vue.set(this.loading, id, value)
+ },
+
setError(appId: string | string[], error: string) {
const appIds = Array.isArray(appId) ? appId : [appId]
appIds.forEach((_id) => {
@@ -73,14 +77,14 @@ export const useAppApiStore = defineStore('app-api-apps', {
},
enableApp(appId: string) {
- this.loading[appId] = true
- this.loading.install = true
+ this.setLoading(appId, true)
+ this.setLoading('install', true)
return confirmPassword().then(() => {
return axios.post(generateUrl(`/apps/app_api/apps/enable/${appId}`))
.then((response) => {
- this.loading[appId] = false
- this.loading.install = false
+ this.setLoading(appId, false)
+ this.setLoading('install', false)
const app = this.apps.find((app) => app.id === appId)
if (app) {
@@ -123,8 +127,8 @@ export const useAppApiStore = defineStore('app-api-apps', {
})
})
.catch((error) => {
- this.loading[appId] = false
- this.loading.install = false
+ this.setLoading(appId, false)
+ this.setLoading('install', false)
this.setError(appId, error.response.data.data.message)
this.appsApiFailure({ appId, error })
})
@@ -132,8 +136,8 @@ export const useAppApiStore = defineStore('app-api-apps', {
},
forceEnableApp(appId: string) {
- this.loading[appId] = true
- this.loading.install = true
+ this.setLoading(appId, true)
+ this.setLoading('install', true)
return confirmPassword().then(() => {
return api.post(generateUrl('/apps/app_api/apps/force'), { appId })
@@ -141,8 +145,8 @@ export const useAppApiStore = defineStore('app-api-apps', {
location.reload()
})
.catch((error) => {
- this.loading[appId] = false
- this.loading.install = false
+ this.setLoading(appId, false)
+ this.setLoading('install', false)
this.setError(appId, error.response.data.data.message)
this.appsApiFailure({ appId, error })
})
@@ -150,12 +154,12 @@ export const useAppApiStore = defineStore('app-api-apps', {
},
disableApp(appId: string) {
- this.loading[appId] = true
+ this.setLoading(appId, true)
return confirmPassword().then(() => {
return api.get(generateUrl(`apps/app_api/apps/disable/${appId}`))
.then(() => {
- this.loading[appId] = false
+ this.setLoading(appId, false)
const app = this.apps.find((app) => app.id === appId)
if (app) {
app.active = false
@@ -166,19 +170,19 @@ export const useAppApiStore = defineStore('app-api-apps', {
return true
})
.catch((error) => {
- this.loading[appId] = false
+ this.setLoading(appId, false)
this.appsApiFailure({ appId, error })
})
})
},
uninstallApp(appId: string, removeData: boolean) {
- this.loading[appId] = true
+ this.setLoading(appId, true)
return confirmPassword().then(() => {
return api.get(generateUrl(`/apps/app_api/apps/uninstall/${appId}?removeData=${removeData}`))
.then(() => {
- this.loading[appId] = false
+ this.setLoading(appId, false)
const app = this.apps.find((app) => app.id === appId)
if (app) {
app.active = false
@@ -196,21 +200,21 @@ export const useAppApiStore = defineStore('app-api-apps', {
return true
})
.catch((error) => {
- this.loading[appId] = false
+ this.setLoading(appId, false)
this.appsApiFailure({ appId, error })
})
})
},
updateApp(appId: string) {
- this.loading[appId] = true
- this.loading.install = true
+ this.setLoading(appId, true)
+ this.setLoading('install', true)
return confirmPassword().then(() => {
return api.get(generateUrl(`/apps/app_api/apps/update/${appId}`))
.then(() => {
- this.loading.install = false
- this.loading[appId] = false
+ this.setLoading(appId, false)
+ this.setLoading('install', false)
const app = this.apps.find((app) => app.id === appId)
if (app) {
const version = app.update
@@ -229,8 +233,8 @@ export const useAppApiStore = defineStore('app-api-apps', {
return true
})
.catch((error) => {
- this.loading[appId] = false
- this.loading.install = false
+ this.setLoading(appId, false)
+ this.setLoading('install', false)
this.appsApiFailure({ appId, error })
})
})