memories/src/components/Settings.vue

92 lines
2.9 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-09-09 07:31:42 +00:00
<div>
2022-08-20 00:18:04 +00:00
<label for="timeline-path">{{ t('memories', 'Timeline Path') }}</label>
<input id="timeline-path"
2022-09-16 22:42:29 +00:00
v-model="config_timelinePath"
2022-08-20 00:18:04 +00:00
type="text">
<label for="folders-path">{{ t('memories', 'Folders Path') }}</label>
<input id="folders-path"
v-model="config_foldersPath"
type="text">
2022-09-16 22:42:29 +00:00
<NcCheckboxRadioSwitch :checked.sync="config_showHidden"
type="switch">
{{ t('memories', 'Show hidden folders') }}
</NcCheckboxRadioSwitch>
2022-10-16 03:18:11 +00:00
<NcCheckboxRadioSwitch :checked.sync="config_squareThumbs"
type="switch">
2022-10-17 23:55:58 +00:00
{{ t('memories', 'Square grid mode') }}
2022-10-16 03:18:11 +00:00
</NcCheckboxRadioSwitch>
2022-08-20 00:18:04 +00:00
<button @click="updateAll()">
{{ t('memories', 'Update') }}
</button>
2022-09-09 07:31:42 +00:00
</div>
2022-08-20 00:18:04 +00:00
</template>
2022-08-20 09:06:55 +00:00
<style scoped>
2022-08-20 00:18:04 +00:00
input[type=text] {
width: 100%;
}
</style>
2022-09-13 01:48:05 +00:00
<script lang="ts">
2022-09-13 02:06:35 +00:00
import { Component, Mixins } from 'vue-property-decorator';
2022-09-13 02:36:27 +00:00
import GlobalMixin from '../mixins/GlobalMixin';
2022-09-16 00:50:44 +00:00
import { showError } from '@nextcloud/dialogs'
2022-08-20 00:18:04 +00:00
import UserConfig from '../mixins/UserConfig'
2022-09-16 22:42:29 +00:00
import { NcCheckboxRadioSwitch } from '@nextcloud/vue'
@Component({
components: {
NcCheckboxRadioSwitch,
},
})
2022-09-13 02:36:27 +00:00
export default class Settings extends Mixins(UserConfig, GlobalMixin) {
2022-09-13 01:48:05 +00:00
async updateAll() {
2022-10-16 03:18:11 +00:00
// Update localStorage
localStorage.setItem('memories_squareThumbs', this.config_squareThumbs ? '1' : '0');
// Settings list
const settings = ['showHidden', 'timelinePath', 'foldersPath'];
// Update all
2022-10-22 17:41:34 +00:00
try {
const p = await Promise.all(settings.map(async (setting) => this.updateSetting(setting)));
if (p.some((r) => !r || r.status !== 200)) {
showError(this.t('memories', 'Error updating settings'));
} else {
window.location.reload();
}
} catch (e) {
showError(e?.response?.data?.message || this.t('memories', 'Error updating settings'));
2022-09-13 01:48:05 +00:00
}
}
2022-08-20 00:18:04 +00:00
}
</script>