memories/src/components/Settings.vue

145 lines
3.7 KiB
Vue
Raw Normal View History

2022-08-20 00:18:04 +00:00
<!--
- @copyright Copyright (c) 2019 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/>.
-
-->
<template>
2022-10-28 19:08:34 +00:00
<div>
<label for="timeline-path">{{ t("memories", "Timeline Path") }}</label>
<input
id="timeline-path"
@click="chooseTimelinePath"
v-model="config_timelinePath"
type="text"
/>
2022-08-20 00:18:04 +00:00
2022-10-28 19:08:34 +00:00
<label for="folders-path">{{ t("memories", "Folders Path") }}</label>
<input
id="folders-path"
@click="chooseFoldersPath"
v-model="config_foldersPath"
type="text"
/>
2022-10-28 19:08:34 +00:00
<NcCheckboxRadioSwitch
:checked.sync="config_showHidden"
@update:checked="updateShowHidden"
type="switch"
>
{{ t("memories", "Show hidden folders") }}
</NcCheckboxRadioSwitch>
2022-09-16 22:42:29 +00:00
2022-10-28 19:08:34 +00:00
<NcCheckboxRadioSwitch
:checked.sync="config_squareThumbs"
@update:checked="updateSquareThumbs"
type="switch"
>
{{ t("memories", "Square grid mode") }}
</NcCheckboxRadioSwitch>
<MultiPathSelectionModal
ref="multiPathModal"
:title="pathSelTitle"
@close="saveTimelinePath"
/>
2022-10-28 19:08:34 +00:00
</div>
2022-08-20 00:18:04 +00:00
</template>
2022-08-20 09:06:55 +00:00
<style scoped>
2022-10-28 19:08:34 +00:00
input[type="text"] {
width: 100%;
2022-08-20 00:18:04 +00:00
}
</style>
2022-09-13 01:48:05 +00:00
<script lang="ts">
2022-12-10 09:01:44 +00:00
import { defineComponent } from "vue";
2022-08-20 00:18:04 +00:00
import { getFilePickerBuilder } from "@nextcloud/dialogs";
2022-11-24 21:07:09 +00:00
const NcCheckboxRadioSwitch = () =>
import("@nextcloud/vue/dist/Components/NcCheckboxRadioSwitch");
2022-09-16 22:42:29 +00:00
import MultiPathSelectionModal from "./modal/MultiPathSelectionModal.vue";
2022-12-10 09:01:44 +00:00
export default defineComponent({
name: "Settings",
2022-10-28 19:08:34 +00:00
components: {
NcCheckboxRadioSwitch,
MultiPathSelectionModal,
2022-10-28 19:08:34 +00:00
},
2022-12-10 09:01:44 +00:00
computed: {
2022-12-10 17:58:30 +00:00
pathSelTitle(): string {
2022-12-10 09:01:44 +00:00
return this.t("memories", "Choose Timeline Paths");
},
},
methods: {
async chooseFolder(title: string, initial: string) {
const picker = getFilePickerBuilder(title)
.setMultiSelect(false)
.setModal(true)
.setType(1)
.addMimeTypeFilter("httpd/unix-directory")
.allowDirectories()
.startAt(initial)
.build();
return await picker.pick();
},
async chooseTimelinePath() {
(<any>this.$refs.multiPathModal).open(
this.config_timelinePath.split(";")
);
},
async saveTimelinePath(paths: string[]) {
if (!paths || !paths.length) return;
const newPath = paths.join(";");
if (newPath !== this.config_timelinePath) {
this.config_timelinePath = newPath;
await this.updateSetting("timelinePath");
}
},
async chooseFoldersPath() {
let newPath = await this.chooseFolder(
this.t("memories", "Choose the root for the folders view"),
this.config_foldersPath
);
if (newPath === "") newPath = "/";
if (newPath !== this.config_foldersPath) {
this.config_foldersPath = newPath;
await this.updateSetting("foldersPath");
}
},
async updateSquareThumbs() {
await this.updateSetting("squareThumbs");
},
async updateShowHidden() {
await this.updateSetting("showHidden");
},
},
});
2022-08-20 00:18:04 +00:00
</script>