summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/Photos.vue13
-rw-r--r--src/components/File.vue17
-rw-r--r--src/components/Settings/CroppedLayoutSettings.vue48
-rw-r--r--src/mixins/GridConfig.js2
-rw-r--r--src/mixins/UserConfig.js64
5 files changed, 138 insertions, 6 deletions
diff --git a/src/Photos.vue b/src/Photos.vue
index d812132e..f9598fa8 100644
--- a/src/Photos.vue
+++ b/src/Photos.vue
@@ -39,6 +39,11 @@
:title="t('photos', 'Locations')"
icon="icon-address" />
</template>
+ <template #footer>
+ <AppNavigationSettings :title="t('photos', 'Settings')">
+ <CroppedLayoutSettings />
+ </AppNavigationSettings>
+ </template>
</AppNavigation>
<AppContent :class="{ 'icon-loading': loading }">
<router-view v-show="!loading" :loading.sync="loading" />
@@ -55,23 +60,29 @@
</template>
<script>
+import { getCurrentUser } from '@nextcloud/auth'
+
import Content from '@nextcloud/vue/dist/Components/Content'
import AppContent from '@nextcloud/vue/dist/Components/AppContent'
import AppNavigation from '@nextcloud/vue/dist/Components/AppNavigation'
import AppNavigationItem from '@nextcloud/vue/dist/Components/AppNavigationItem'
+import AppNavigationSettings from '@nextcloud/vue/dist/Components/AppNavigationSettings'
+
+import CroppedLayoutSettings from './components/Settings/CroppedLayoutSettings'
import svgplaceholder from './assets/file-placeholder.svg'
import imgplaceholder from './assets/image.svg'
import videoplaceholder from './assets/video.svg'
import isMapsInstalled from './services/IsMapsInstalled'
-import { getCurrentUser } from '@nextcloud/auth'
export default {
name: 'Photos',
components: {
Content,
+ CroppedLayoutSettings,
AppContent,
AppNavigation,
AppNavigationItem,
+ AppNavigationSettings,
},
data() {
return {
diff --git a/src/components/File.vue b/src/components/File.vue
index 591a78b9..73c7dffe 100644
--- a/src/components/File.vue
+++ b/src/components/File.vue
@@ -21,7 +21,10 @@
-->
<template>
- <a :class="{'file--clear': !loaded}"
+ <a :class="{
+ 'file--clear': !loaded,
+ 'file--cropped': croppedLayout,
+ }"
class="file"
:href="davPath"
:aria-label="ariaLabel"
@@ -54,10 +57,12 @@
import { generateRemoteUrl, generateUrl } from '@nextcloud/router'
import { getCurrentUser } from '@nextcloud/auth'
+import UserConfig from '../mixins/UserConfig'
+
export default {
name: 'File',
+ mixins: [UserConfig],
inheritAttrs: false,
-
props: {
item: {
type: Object,
@@ -85,7 +90,7 @@ export default {
return this.item.injected.mime.startsWith('image')
},
src() {
- return generateUrl(`/core/preview?fileId=${this.item.injected.fileid}&x=${256}&y=${256}&a=false&v=${this.item.injected.etag}`)
+ return generateUrl(`/core/preview?fileId=${this.item.injected.fileid}&x=${256}&y=${256}&a=${!this.croppedLayout}&v=${this.item.injected.etag}`)
},
},
@@ -127,7 +132,11 @@ img {
width: 100%;
height: 100%;
- object-fit: cover;
+ object-fit: contain;
+
+ .file--cropped & {
+ object-fit: cover;
+ }
}
svg {
diff --git a/src/components/Settings/CroppedLayoutSettings.vue b/src/components/Settings/CroppedLayoutSettings.vue
new file mode 100644
index 00000000..d31cea05
--- /dev/null
+++ b/src/components/Settings/CroppedLayoutSettings.vue
@@ -0,0 +1,48 @@
+<!--
+ - @copyright Copyright (c) 2019 John Molakvoæ <skjnldsv@protonmail.com>
+ -
+ - @author John Molakvoæ <skjnldsv@protonmail.com>
+ -
+ - @license GNU AGPL version 3 or any later version
+ -
+ - 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>
+ <div class="section">
+ <h2>{{ t('photos', 'Layout') }}</h2>
+ <p>
+ <input
+ id="enable-cropped-layout"
+ v-model="croppedLayout"
+ type="checkbox"
+ class="checkbox"
+ @change="updateSetting('croppedLayout')">
+ <label for="enable-cropped-layout">{{ t('photos', 'Enable cropped layout') }}</label>
+ </p>
+ </div>
+</template>
+
+<script>
+import UserConfig from '../../mixins/UserConfig'
+
+export default {
+ name: 'CroppedLayoutSettings',
+
+ mixins: [
+ UserConfig,
+ ],
+}
+</script>
diff --git a/src/mixins/GridConfig.js b/src/mixins/GridConfig.js
index e7b18817..2663d854 100644
--- a/src/mixins/GridConfig.js
+++ b/src/mixins/GridConfig.js
@@ -36,7 +36,7 @@ export default {
getGridConfig.$on('changed', val => {
this.gridConfig = val
})
- console.debug('Current grid config', getGridConfig.gridConfig)
+ console.debug(`[${appName}]`, 'Grid config', Object.assign({}, getGridConfig.gridConfig))
this.gridConfig = getGridConfig.gridConfig
},
diff --git a/src/mixins/UserConfig.js b/src/mixins/UserConfig.js
new file mode 100644
index 00000000..efa123dc
--- /dev/null
+++ b/src/mixins/UserConfig.js
@@ -0,0 +1,64 @@
+/**
+ * @copyright Copyright (c) 2020 John Molakvoæ <skjnldsv@protonmail.com>
+ *
+ * @author John Molakvoæ <skjnldsv@protonmail.com>
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * 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/>.
+ *
+ */
+
+import { emit, subscribe, unsubscribe } from '@nextcloud/event-bus'
+import { generateUrl } from '@nextcloud/router'
+import { loadState } from '@nextcloud/initial-state'
+import axios from '@nextcloud/axios'
+
+const eventName = 'photos:user-config-changed'
+
+export default {
+ data() {
+ const croppedLayoutLocalStorage = localStorage.getItem('photos:croppedLayout')
+ return {
+ croppedLayout: croppedLayoutLocalStorage !== null
+ ? croppedLayoutLocalStorage === 'true'
+ : loadState('photos', 'croppedLayout') === 'true',
+ }
+ },
+
+ created() {
+ subscribe(eventName, this.updateLocalSetting)
+ },
+
+ beforeDestroy() {
+ unsubscribe(eventName, this.updateLocalSetting)
+ },
+
+ methods: {
+ updateLocalSetting({ setting, value }) {
+ this[setting] = value
+ },
+ updateSetting(setting) {
+ const value = this[setting]
+ // Long time save setting
+ axios.put(generateUrl('apps/photos/api/v1/config/' + setting), {
+ value: value.toString(),
+ })
+ // Current session save setting
+ localStorage.setItem('photos:' + setting, value)
+ // Visible elements update setting
+ emit(eventName, { setting, value })
+ },
+ },
+}