aboutsummaryrefslogtreecommitdiffstats
path: root/apps/settings/src
diff options
context:
space:
mode:
authorAndrey Borysenko <andrey18106x@gmail.com>2024-10-14 16:46:35 +0300
committerAndrey Borysenko <andrey18106x@gmail.com>2024-10-29 20:54:07 +0200
commit46e643b72af60032a634435a1f4d7ca8799daee5 (patch)
tree02eef5519f242c06d875e83e65987475ee795d9d /apps/settings/src
parent2f25546fda4eca3bcabe5fc9f32fffde54977a86 (diff)
downloadnextcloud-server-46e643b72af60032a634435a1f4d7ca8799daee5.tar.gz
nextcloud-server-46e643b72af60032a634435a1f4d7ca8799daee5.zip
fix(ci): resolve eslint errors
Signed-off-by: Andrey Borysenko <andrey18106x@gmail.com>
Diffstat (limited to 'apps/settings/src')
-rw-r--r--apps/settings/src/app-types.ts14
-rw-r--r--apps/settings/src/components/AppList.vue23
-rw-r--r--apps/settings/src/components/AppList/AppDaemonBadge.vue2
-rw-r--r--apps/settings/src/components/AppList/AppItem.vue6
-rw-r--r--apps/settings/src/components/AppStoreSidebar/AppDeployDaemonTab.vue1
-rw-r--r--apps/settings/src/components/AppStoreSidebar/AppDetailsTab.vue6
-rw-r--r--apps/settings/src/mixins/AppManagement.js22
-rw-r--r--apps/settings/src/store/app_api_apps.js5
-rw-r--r--apps/settings/src/store/apps.js2
-rw-r--r--apps/settings/src/store/index.js4
-rw-r--r--apps/settings/src/views/AppStore.vue9
-rw-r--r--apps/settings/src/views/AppStoreSidebar.vue2
12 files changed, 53 insertions, 43 deletions
diff --git a/apps/settings/src/app-types.ts b/apps/settings/src/app-types.ts
index 77a1b6797f3..3ce2aa1648c 100644
--- a/apps/settings/src/app-types.ts
+++ b/apps/settings/src/app-types.ts
@@ -53,13 +53,6 @@ export interface IAppstoreApp {
releases?: IAppstoreAppRelease[]
}
-export interface IAppstoreExApp extends IAppstoreApp {
- daemon: IDeployDaemon,
- status: IExAppStatus,
- error: string,
- app_api: boolean,
-}
-
export interface IComputeDevice {
id: string,
label: string,
@@ -90,3 +83,10 @@ export interface IExAppStatus {
init_start_time: number,
type: string,
}
+
+export interface IAppstoreExApp extends IAppstoreApp {
+ daemon: IDeployDaemon,
+ status: IExAppStatus,
+ error: string,
+ app_api: boolean,
+}
diff --git a/apps/settings/src/components/AppList.vue b/apps/settings/src/components/AppList.vue
index 6a43e55dd47..6062e61d906 100644
--- a/apps/settings/src/components/AppList.vue
+++ b/apps/settings/src/components/AppList.vue
@@ -168,7 +168,10 @@ export default {
return this.apps.filter(app => app.update).length
},
loading() {
- return this.$store.getters.loading('list')
+ if (!this.$store.getters['appApiApps/isAppApiEnabled']) {
+ return this.$store.getters.loading('list')
+ }
+ return this.$store.getters.loading('list') || this.$store.getters['appApiApps/loading']('list')
},
hasPendingUpdate() {
return this.apps.filter(app => app.update).length > 0
@@ -177,7 +180,9 @@ export default {
return this.hasPendingUpdate && this.useListView
},
apps() {
- const apps = this.$store.getters.getAllApps
+ // Exclude ExApps from the list if AppAPI is disabled
+ const exApps = this.$store.getters.isAppApiEnabled ? this.$store.getters['appApiApps/getAllApps'] : []
+ const apps = [...this.$store.getters.getAllApps, ...exApps]
.filter(app => app.name.toLowerCase().search(this.search.toLowerCase()) !== -1)
.sort(function(a, b) {
const sortStringA = '' + (a.active ? 0 : 1) + (a.update ? 0 : 1) + a.name
@@ -304,12 +309,14 @@ export default {
const limit = pLimit(1)
this.apps
.filter(app => app.update)
- .map((app) => limit(() => {
- if (app?.app_api) {
- this.$store.dispatch('app_api_apps/updateApp', { appId: app.id })
- }
- this.update(app.id)
- }))
+ .map(app => limit(() => {
+ let type = 'updateApp'
+ if (app?.app_api) {
+ type = 'app_api_apps/updateApp'
+ }
+ this.$store.dispatch(type, { appId: app.id })
+ }),
+ )
},
},
}
diff --git a/apps/settings/src/components/AppList/AppDaemonBadge.vue b/apps/settings/src/components/AppList/AppDaemonBadge.vue
index 1a46d3c7ebb..1a5cd5bbea3 100644
--- a/apps/settings/src/components/AppList/AppDaemonBadge.vue
+++ b/apps/settings/src/components/AppList/AppDaemonBadge.vue
@@ -16,7 +16,7 @@ import NcIconSvgWrapper from '@nextcloud/vue/dist/Components/NcIconSvgWrapper.js
import { mdiFileChart } from '@mdi/js'
import type { IDeployDaemon } from '../../app-types.ts'
-const props = defineProps<{
+defineProps<{
daemon?: IDeployDaemon
}>()
</script>
diff --git a/apps/settings/src/components/AppList/AppItem.vue b/apps/settings/src/components/AppList/AppItem.vue
index f44ff3a3a7d..d7c4d1bdc71 100644
--- a/apps/settings/src/components/AppList/AppItem.vue
+++ b/apps/settings/src/components/AppList/AppItem.vue
@@ -16,9 +16,9 @@
:headers="getDataItemHeaders(`app-table-col-icon`)">
<div v-if="(listView && !app.preview && !app?.app_api) || (!listView && !screenshotLoaded && !app?.app_api)" class="icon-settings-dark" />
<NcIconSvgWrapper v-else-if="(listView && app?.app_api && !app.preview) || (!listView && !screenshotLoaded && app?.app_api)"
- :path="mdiCogOutline()"
- :size="listView ? 24 : 48"
- style="min-width: auto; min-height: auto; height: 100%;"/>
+ :path="mdiCogOutline()"
+ :size="listView ? 24 : 48"
+ style="min-width: auto; min-height: auto; height: 100%;" />
<svg v-else-if="listView && app.preview && !app?.app_api"
width="32"
diff --git a/apps/settings/src/components/AppStoreSidebar/AppDeployDaemonTab.vue b/apps/settings/src/components/AppStoreSidebar/AppDeployDaemonTab.vue
index 6f223f821d3..8eb8f943ea4 100644
--- a/apps/settings/src/components/AppStoreSidebar/AppDeployDaemonTab.vue
+++ b/apps/settings/src/components/AppStoreSidebar/AppDeployDaemonTab.vue
@@ -34,7 +34,6 @@ defineProps<{
}>()
</script>
-
<style scoped lang="scss">
.daemon {
padding: 20px;
diff --git a/apps/settings/src/components/AppStoreSidebar/AppDetailsTab.vue b/apps/settings/src/components/AppStoreSidebar/AppDetailsTab.vue
index a3723dc3a79..b732c5b82f5 100644
--- a/apps/settings/src/components/AppStoreSidebar/AppDetailsTab.vue
+++ b/apps/settings/src/components/AppStoreSidebar/AppDetailsTab.vue
@@ -79,9 +79,9 @@
@click="forceEnable(app.id)">
</div>
<NcCheckboxRadioSwitch v-if="app.canUnInstall"
- :checked="removeData"
- :disabled="installing || isLoading || !defaultDeployDaemonAccessible"
- @update:checked="toggleRemoveData">
+ :checked="removeData"
+ :disabled="installing || isLoading || !defaultDeployDaemonAccessible"
+ @update:checked="toggleRemoveData">
{{ t('settings', 'Delete data on remove') }}
</NcCheckboxRadioSwitch>
</div>
diff --git a/apps/settings/src/mixins/AppManagement.js b/apps/settings/src/mixins/AppManagement.js
index ae7ab7b096c..4edfa741d07 100644
--- a/apps/settings/src/mixins/AppManagement.js
+++ b/apps/settings/src/mixins/AppManagement.js
@@ -13,13 +13,13 @@ export default {
},
installing() {
if (this.app?.app_api) {
- return this.app && this.$store.getters['app_api_apps/loading']('install')
+ return this.app && this.$store.getters['appApiApps/loading']('install')
}
return this.$store.getters.loading('install')
},
isLoading() {
if (this.app?.app_api) {
- return this.app && this.$store.getters['app_api_apps/loading'](this.app.id)
+ return this.app && this.$store.getters['appApiApps/loading'](this.app.id)
}
return this.app && this.$store.getters.loading(this.app.id)
},
@@ -108,9 +108,9 @@ export default {
return true
}
if (this.app?.daemon?.accepts_deploy_id === 'docker-install') {
- return this.$store.getters['app_api_apps/getDaemonAccessible'] === true
+ return this.$store.getters['appApiApps/getDaemonAccessible'] === true
}
- return this.$store.getters['app_api_apps/getDaemonAccessible']
+ return this.$store.getters['appApiApps/getDaemonAccessible']
}
return true
},
@@ -136,7 +136,7 @@ export default {
if (this.app?.app_api) {
return false
}
- return this.app.groups.length || this.groupCheckedAppsData;
+ return this.app.groups.length || this.groupCheckedAppsData
},
setGroupLimit() {
if (this.app?.app_api) {
@@ -179,7 +179,7 @@ export default {
forceEnable(appId) {
let type = 'forceEnableApp'
if (this.app?.app_api) {
- type = 'app_api_apps/forceEnableApp'
+ type = 'appApiApps/forceEnableApp'
}
this.$store.dispatch(type, { appId, groups: [] })
.then((response) => { rebuildNavigation() })
@@ -188,7 +188,7 @@ export default {
enable(appId) {
let type = 'enableApp'
if (this.app?.app_api) {
- type = 'app_api_apps/enableApp'
+ type = 'appApiApps/enableApp'
}
this.$store.dispatch(type, { appId, groups: [] })
.then((response) => { rebuildNavigation() })
@@ -197,7 +197,7 @@ export default {
disable(appId) {
let type = 'disableApp'
if (this.app?.app_api) {
- type = 'app_api_apps/disableApp'
+ type = 'appApiApps/disableApp'
}
this.$store.dispatch(type, { appId })
.then((response) => { rebuildNavigation() })
@@ -207,7 +207,7 @@ export default {
let type = 'uninstallApp'
let payload = { appId }
if (this.app?.app_api) {
- type = 'app_api_apps/uninstallApp'
+ type = 'appApiApps/uninstallApp'
payload = { appId, removeData }
}
this.$store.dispatch(type, payload)
@@ -217,7 +217,7 @@ export default {
install(appId) {
let type = 'enableApp'
if (this.app?.app_api) {
- type = 'app_api_apps/enableApp'
+ type = 'appApiApps/enableApp'
}
this.$store.dispatch(type, { appId })
.then((response) => { rebuildNavigation() })
@@ -226,7 +226,7 @@ export default {
update(appId) {
let type = 'updateApp'
if (this.app?.app_api) {
- type = 'app_api_apps/updateApp'
+ type = 'appApiApps/updateApp'
}
this.$store.dispatch(type, { appId })
.catch((error) => { showError(error) })
diff --git a/apps/settings/src/store/app_api_apps.js b/apps/settings/src/store/app_api_apps.js
index 4e505e6d8c8..390f1f4db1a 100644
--- a/apps/settings/src/store/app_api_apps.js
+++ b/apps/settings/src/store/app_api_apps.js
@@ -392,5 +392,8 @@ const actions = {
export default {
namespaced: true, // we will use AppAPI store module explicitly, since methods names are the same, we need to scope it
- state, mutations, getters, actions
+ state,
+ mutations,
+ getters,
+ actions,
}
diff --git a/apps/settings/src/store/apps.js b/apps/settings/src/store/apps.js
index 5de9628f947..7364f96fae2 100644
--- a/apps/settings/src/store/apps.js
+++ b/apps/settings/src/store/apps.js
@@ -102,7 +102,7 @@ const mutations = {
state.apps.find(app => app.id === appId).installed = false
state.apps.find(app => app.id === appId).canUnInstall = false
state.apps.find(app => app.id === appId).canInstall = true
- if (app.id === 'app_api') {
+ if (appId === 'app_api') {
state.appApiEnabled = false
}
},
diff --git a/apps/settings/src/store/index.js b/apps/settings/src/store/index.js
index 2cf8767b904..62dab7246fc 100644
--- a/apps/settings/src/store/index.js
+++ b/apps/settings/src/store/index.js
@@ -7,7 +7,7 @@ import Vue from 'vue'
import Vuex, { Store } from 'vuex'
import users from './users.js'
import apps from './apps.js'
-import app_api_apps from './app_api_apps.js'
+import appApiApps from './app_api_apps.js'
import settings from './users-settings.js'
import oc from './oc.js'
import { showError } from '@nextcloud/dialogs'
@@ -36,7 +36,7 @@ export const useStore = () => {
modules: {
users,
apps,
- app_api_apps,
+ appApiApps,
settings,
oc,
},
diff --git a/apps/settings/src/views/AppStore.vue b/apps/settings/src/views/AppStore.vue
index 5be2b118b9f..0c922ce7296 100644
--- a/apps/settings/src/views/AppStore.vue
+++ b/apps/settings/src/views/AppStore.vue
@@ -59,17 +59,18 @@ onBeforeMount(() => {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
(instance?.proxy as any).$store.dispatch('getCategories', { shouldRefetchCategories: true });
// eslint-disable-next-line @typescript-eslint/no-explicit-any
- (instance?.proxy as any).$store.dispatch('getAllApps');
+ (instance?.proxy as any).$store.dispatch('getAllApps')
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
if ((instance?.proxy as any).$store.getters.isAppApiEnabled) {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
- (instance?.proxy as any).$store.dispatch('app_api_apps/getAllApps');
+ (instance?.proxy as any).$store.dispatch('appApiApps/getAllApps');
// eslint-disable-next-line @typescript-eslint/no-explicit-any
- (instance?.proxy as any).$store.dispatch('app_api_apps/updateAppsStatus');
+ (instance?.proxy as any).$store.dispatch('appApiApps/updateAppsStatus')
}
})
onBeforeUnmount(() => {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
- clearInterval((instance?.proxy as any).$store.getters('app_api_apps/getStatusUpdater'));
+ clearInterval((instance?.proxy as any).$store.getters('appApiApps/getStatusUpdater'))
})
</script>
diff --git a/apps/settings/src/views/AppStoreSidebar.vue b/apps/settings/src/views/AppStoreSidebar.vue
index fc2b94d8ee0..bb60e425308 100644
--- a/apps/settings/src/views/AppStoreSidebar.vue
+++ b/apps/settings/src/views/AppStoreSidebar.vue
@@ -65,7 +65,7 @@ const legacyStore = useStore()
const appId = computed(() => route.params.id ?? '')
const app = computed(() => {
if (legacyStore.getters.isAppApiEnabled) {
- const exApp = legacyStore.getters['app_api_apps/getAllApps']
+ const exApp = legacyStore.getters['appApiApps/getAllApps']
.find((app) => app.id === appId.value) ?? null
if (exApp) {
return exApp