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-19 19:26:32 +00:00
|
|
|
|
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>
|
2022-11-16 08:16:01 +00:00
|
|
|
|
|
|
|
<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-10-28 19:08:34 +00:00
|
|
|
import { Component, Mixins } from "vue-property-decorator";
|
|
|
|
import GlobalMixin from "../mixins/GlobalMixin";
|
|
|
|
import UserConfig from "../mixins/UserConfig";
|
2022-08-20 00:18:04 +00:00
|
|
|
|
2022-11-16 08:16:01 +00:00
|
|
|
import { getFilePickerBuilder } from "@nextcloud/dialogs";
|
2022-10-28 19:08:34 +00:00
|
|
|
import { NcCheckboxRadioSwitch } from "@nextcloud/vue";
|
2022-09-16 22:42:29 +00:00
|
|
|
|
2022-11-16 08:16:01 +00:00
|
|
|
import MultiPathSelectionModal from "./modal/MultiPathSelectionModal.vue";
|
|
|
|
|
2022-09-16 22:42:29 +00:00
|
|
|
@Component({
|
2022-10-28 19:08:34 +00:00
|
|
|
components: {
|
|
|
|
NcCheckboxRadioSwitch,
|
2022-11-16 08:16:01 +00:00
|
|
|
MultiPathSelectionModal,
|
2022-10-28 19:08:34 +00:00
|
|
|
},
|
2022-09-16 22:42:29 +00:00
|
|
|
})
|
2022-09-13 02:36:27 +00:00
|
|
|
export default class Settings extends Mixins(UserConfig, GlobalMixin) {
|
2022-11-16 08:16:01 +00:00
|
|
|
get pathSelTitle() {
|
|
|
|
return this.t("memories", "Choose Timeline Paths");
|
|
|
|
}
|
|
|
|
|
2022-10-28 19:08:34 +00:00
|
|
|
async chooseFolder(title: string, initial: string) {
|
|
|
|
const picker = getFilePickerBuilder(title)
|
|
|
|
.setMultiSelect(false)
|
|
|
|
.setModal(true)
|
|
|
|
.setType(1)
|
|
|
|
.addMimeTypeFilter("httpd/unix-directory")
|
|
|
|
.allowDirectories()
|
|
|
|
.startAt(initial)
|
|
|
|
.build();
|
2022-10-25 01:58:49 +00:00
|
|
|
|
2022-10-28 19:08:34 +00:00
|
|
|
return await picker.pick();
|
|
|
|
}
|
2022-10-16 03:18:11 +00:00
|
|
|
|
2022-10-28 19:08:34 +00:00
|
|
|
async chooseTimelinePath() {
|
2022-11-16 08:16:01 +00:00
|
|
|
(<any>this.$refs.multiPathModal).open(this.config_timelinePath.split(";"));
|
|
|
|
}
|
|
|
|
|
|
|
|
async saveTimelinePath(paths: string[]) {
|
|
|
|
if (!paths || !paths.length) return;
|
|
|
|
|
|
|
|
const newPath = paths.join(";");
|
2022-10-28 19:08:34 +00:00
|
|
|
if (newPath !== this.config_timelinePath) {
|
|
|
|
this.config_timelinePath = newPath;
|
|
|
|
await this.updateSetting("timelinePath");
|
2022-10-25 01:58:49 +00:00
|
|
|
}
|
2022-10-28 19:08:34 +00:00
|
|
|
}
|
2022-10-19 19:26:32 +00:00
|
|
|
|
2022-10-28 19:08:34 +00:00
|
|
|
async chooseFoldersPath() {
|
2022-11-15 15:12:27 +00:00
|
|
|
let newPath = await this.chooseFolder(
|
2022-10-28 19:08:34 +00:00
|
|
|
this.t("memories", "Choose the root for the folders view"),
|
|
|
|
this.config_foldersPath
|
|
|
|
);
|
2022-11-15 15:12:27 +00:00
|
|
|
if (newPath === "") newPath = "/";
|
2022-10-28 19:08:34 +00:00
|
|
|
if (newPath !== this.config_foldersPath) {
|
|
|
|
this.config_foldersPath = newPath;
|
|
|
|
await this.updateSetting("foldersPath");
|
2022-09-13 01:48:05 +00:00
|
|
|
}
|
2022-10-28 19:08:34 +00:00
|
|
|
}
|
2022-10-25 01:58:49 +00:00
|
|
|
|
2022-10-28 19:08:34 +00:00
|
|
|
async updateSquareThumbs() {
|
|
|
|
await this.updateSetting("squareThumbs");
|
|
|
|
}
|
2022-10-25 01:58:49 +00:00
|
|
|
|
2022-10-28 19:08:34 +00:00
|
|
|
async updateShowHidden() {
|
|
|
|
await this.updateSetting("showHidden");
|
|
|
|
}
|
2022-08-20 00:18:04 +00:00
|
|
|
}
|
|
|
|
</script>
|