diff options
Diffstat (limited to 'apps/files/src/store/viewConfig.ts')
-rw-r--r-- | apps/files/src/store/viewConfig.ts | 103 |
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 +} + |