Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/nextcloud/photos.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLouis Chemineau <louis@chmn.me>2022-06-14 18:11:59 +0300
committerLouis Chemineau <louis@chmn.me>2022-08-22 20:44:47 +0300
commit926a4de3af5c1e7da84cabf0be3e0f9e84db0f6d (patch)
treec2eac19b1ffa178787f87c4a5456e876584cd6da /src/components/TiledRows.vue
parent7f9168ff9da760005014b60b4f57b2e0e3aece5c (diff)
Introduce tiled layout in the timelinephotos2
Signed-off-by: Louis Chemineau <louis@chmn.me>
Diffstat (limited to 'src/components/TiledRows.vue')
-rw-r--r--src/components/TiledRows.vue41
1 files changed, 41 insertions, 0 deletions
diff --git a/src/components/TiledRows.vue b/src/components/TiledRows.vue
new file mode 100644
index 00000000..d5c4a665
--- /dev/null
+++ b/src/components/TiledRows.vue
@@ -0,0 +1,41 @@
+<!--
+ - @copyright Copyright (c) 2022 Louis Chemineau <louis@chmn.me>
+ -
+ - @author Louis Chemineau <louis@chmn.me>
+ -
+ - @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 functional>
+ <ul>
+ <div v-for="row of props.rows"
+ :key="row.key"
+ class="tiled-row"
+ :style="{height: `${row.height}px`}">
+ <li v-for="item of row.items"
+ :key="item.id"
+ :style="{ width: item.ratio ? `${row.height * item.ratio}px` : '100%', height: `${row.height}px`}">
+ <slot :row="row" :item="item" />
+ </li>
+ </div>
+ </ul>
+</template>
+<style lang="scss" scoped>
+.tiled-row {
+ display: flex;
+}
+</style>