aboutsummaryrefslogtreecommitdiffstats
path: root/apps/files/src/store/viewConfig.ts
diff options
context:
space:
mode:
Diffstat (limited to 'apps/files/src/store/viewConfig.ts')
-rw-r--r--apps/files/src/store/viewConfig.ts103
1 files changed, 103 insertions, 0 deletions
diff --git a/apps/files/src/store/viewConfig.ts b/apps/files/src/store/viewConfig.ts
new file mode 100644
index 00000000000..d7a5ab1daa6
--- /dev/null
+++ b/apps/files/src/store/viewConfig.ts
@@ -0,0 +1,103 @@
+/**
+ * @copyright Copyright (c) 2023 John Molakvoæ <skjnldsv@protonmail.com>
+ *
+ * @author John Molakvoæ <skjnldsv@protonmail.com>
+ *
+ * @license AGPL-3.0-or-later
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+/* eslint-disable */
+import { defineStore } from 'pinia'
+import { emit, subscribe } from '@nextcloud/event-bus'
+import { generateUrl } from '@nextcloud/router'
+import { loadState } from '@nextcloud/initial-state'
+import axios from '@nextcloud/axios'
+import Vue from 'vue'
+
+import { ViewConfigs, ViewConfigStore, ViewId } from '../types.ts'
+import { ViewConfig } from '../types'
+
+const viewConfig = loadState('files', 'viewConfigs', {}) as ViewConfigs
+
+export const useViewConfigStore = () => {
+ const store = defineStore('viewconfig', {
+ state: () => ({
+ viewConfig,
+ } as ViewConfigStore),
+
+ getters: {
+ getConfig: (state) => (view: ViewId): ViewConfig => state.viewConfig[view] || {},
+ },
+
+ actions: {
+ /**
+ * Update the view config local store
+ */
+ onUpdate(view: ViewId, key: string, value: boolean) {
+ if (!this.viewConfig[view]) {
+ Vue.set(this.viewConfig, view, {})
+ }
+ Vue.set(this.viewConfig[view], key, value)
+ },
+
+ /**
+ * Update the view config local store AND on server side
+ */
+ async update(view: ViewId, key: string, value: boolean) {
+ axios.put(generateUrl(`/apps/files/api/v1/views/${view}/${key}`), {
+ value,
+ })
+
+ emit('files:viewconfig:updated', { view, key, value })
+ },
+
+ /**
+ * Set the sorting key AND sort by ASC
+ * The key param must be a valid key of a File object
+ * If not found, will be searched within the File attributes
+ */
+ setSortingBy(key: string = 'basename', view: string = 'files') {
+ // Save new config
+ this.update(view, 'sorting_mode', key)
+ this.update(view, 'sorting_direction', 'asc')
+ },
+
+ /**
+ * Toggle the sorting direction
+ */
+ toggleSortingDirection(view: string = 'files') {
+ const config = this.getConfig(view) || { 'sorting_direction': 'asc' }
+ const newDirection = config.sorting_direction === 'asc' ? 'desc' : 'asc'
+
+ // Save new config
+ this.update(view, 'sorting_direction', newDirection)
+ }
+ }
+ })
+
+ const viewConfigStore = store()
+
+ // Make sure we only register the listeners once
+ if (!viewConfigStore._initialized) {
+ subscribe('files:viewconfig:updated', function({ view, key, value }: { view: ViewId, key: string, value: boolean }) {
+ viewConfigStore.onUpdate(view, key, value)
+ })
+ viewConfigStore._initialized = true
+ }
+
+ return viewConfigStore
+}
+