2025-01-03 12:42:39 +00:00
|
|
|
<script setup lang="ts">
|
|
|
|
import { computed, ref } from 'vue'
|
|
|
|
|
|
|
|
import { type Track, type User } from '~/types'
|
|
|
|
|
|
|
|
import Card from '~/components/ui/Card.vue'
|
|
|
|
import Layout from '~/components/ui/Layout.vue'
|
|
|
|
import Toggle from '~/components/ui/Toggle.vue'
|
|
|
|
import Spacer from '~/components/ui/layout/Spacer.vue'
|
|
|
|
import Button from '~/components/ui/Button.vue'
|
|
|
|
import Activity from '~/components/ui/Activity.vue'
|
2025-01-03 13:36:06 +00:00
|
|
|
import LayoutSection from '~/components/ui/layout/Section.vue'
|
2025-01-03 12:42:39 +00:00
|
|
|
|
|
|
|
const alignLeft = ref(false)
|
|
|
|
|
|
|
|
const attributes = computed(() => ({
|
|
|
|
style: alignLeft.value ? 'justify-content: start' : ''
|
|
|
|
}))
|
|
|
|
|
|
|
|
const track: Track = {
|
|
|
|
id: 0,
|
|
|
|
fid: "",
|
|
|
|
|
|
|
|
title: 'Some lovely track',
|
|
|
|
description: {
|
|
|
|
content_type: 'text/markdown',
|
|
|
|
text: `**New:** Music for the eyes!`
|
|
|
|
},
|
|
|
|
cover: {
|
|
|
|
uuid: "",
|
|
|
|
urls: {
|
|
|
|
original: 'https://images.unsplash.com/photo-1524650359799-842906ca1c06?ixlib=rb-1.2.1&dl=te-nguyen-Wt7XT1R6sjU-unsplash.jpg&w=640&q=80&fm=jpg&crop=entropy&cs=tinysrgb',
|
|
|
|
medium_square_crop: 'https://images.unsplash.com/photo-1524650359799-842906ca1c06?ixlib=rb-1.2.1&dl=te-nguyen-Wt7XT1R6sjU-unsplash.jpg&w=640&q=80&fm=jpg&crop=entropy&cs=tinysrgb',
|
|
|
|
large_square_crop: 'https://images.unsplash.com/photo-1524650359799-842906ca1c06?ixlib=rb-1.2.1&dl=te-nguyen-Wt7XT1R6sjU-unsplash.jpg&w=640&q=80&fm=jpg&crop=entropy&cs=tinysrgb'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
tags: ["example"],
|
|
|
|
uploads: [],
|
|
|
|
downloads_count: 1927549377,
|
|
|
|
artist_credit: [{
|
|
|
|
artist: {
|
|
|
|
id: 0,
|
|
|
|
fid: "",
|
|
|
|
|
|
|
|
name: "The Artist",
|
|
|
|
description: {
|
|
|
|
content_type: 'text/markdown',
|
|
|
|
text: `I'm a musician based on the internet.
|
|
|
|
|
|
|
|
Find all my music on [Funkwhale](https://funkwhale.audio)!`},
|
|
|
|
tags: [],
|
|
|
|
|
|
|
|
content_category: 'music',
|
|
|
|
albums: [],
|
|
|
|
tracks_count: 1,
|
|
|
|
attributed_to: {
|
|
|
|
id: 0,
|
|
|
|
summary: "",
|
|
|
|
preferred_username: "User12345",
|
|
|
|
full_username: "User12345",
|
|
|
|
is_local: false,
|
|
|
|
domain: "myDomain.io"
|
|
|
|
},
|
|
|
|
is_local: false,
|
|
|
|
is_playable: true
|
|
|
|
},
|
|
|
|
credit: "",
|
|
|
|
joinphrase: " and ",
|
|
|
|
index: 22
|
|
|
|
}],
|
|
|
|
disc_number: 7,
|
|
|
|
|
|
|
|
listen_url: "https://funkwhale.audio",
|
|
|
|
creation_date: "12345",
|
|
|
|
attributed_to: {
|
|
|
|
id: 0,
|
|
|
|
summary: "",
|
|
|
|
preferred_username: "User12345",
|
|
|
|
full_username: "User12345",
|
|
|
|
is_local: false,
|
|
|
|
domain: "myDomain.io"
|
|
|
|
},
|
|
|
|
|
|
|
|
is_playable: true,
|
|
|
|
is_local: false
|
|
|
|
}
|
|
|
|
|
|
|
|
const user: User = {
|
|
|
|
id: 12,
|
|
|
|
avatar: {
|
|
|
|
uuid: "",
|
|
|
|
urls: {
|
|
|
|
original: 'https://images.unsplash.com/photo-1524650359799-842906ca1c06?ixlib=rb-1.2.1&dl=te-nguyen-Wt7XT1R6sjU-unsplash.jpg&w=640&q=80&fm=jpg&crop=entropy&cs=tinysrgb',
|
|
|
|
medium_square_crop: 'https://images.unsplash.com/photo-1524650359799-842906ca1c06?ixlib=rb-1.2.1&dl=te-nguyen-Wt7XT1R6sjU-unsplash.jpg&w=640&q=80&fm=jpg&crop=entropy&cs=tinysrgb',
|
|
|
|
large_square_crop: 'https://images.unsplash.com/photo-1524650359799-842906ca1c06?ixlib=rb-1.2.1&dl=te-nguyen-Wt7XT1R6sjU-unsplash.jpg&w=640&q=80&fm=jpg&crop=entropy&cs=tinysrgb'
|
|
|
|
}
|
|
|
|
},
|
|
|
|
email: "user12345@example.org",
|
|
|
|
summary: { text: "Hi! I'm Example from The Internet.", content_type: "text" },
|
|
|
|
username: "user12345",
|
|
|
|
full_username: "user12345",
|
|
|
|
instance_support_message_display_date: "?",
|
|
|
|
funkwhale_support_message_display_date: "?",
|
|
|
|
is_superuser: true,
|
|
|
|
privacy_level: "everyone"
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
|
|
|
|
# Layout section
|
|
|
|
|
|
|
|
<Layout flex>
|
|
|
|
<Toggle v-model="alignLeft" label="Left-align the layout"/>
|
|
|
|
</Layout>
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
<div class="preview" style="margin: 0 -40px; padding: 0 25px;">
|
|
|
|
|
2025-01-03 13:36:06 +00:00
|
|
|
<LayoutSection :alignLeft="alignLeft" small-items h3="Cards (small items)" :action="{ text:'more...', to:'/' }">
|
2025-01-03 12:42:39 +00:00
|
|
|
<Card small title="Relatively Long Album Name">
|
|
|
|
Artist Name
|
|
|
|
13 tracks
|
|
|
|
</Card>
|
|
|
|
<Card small title="Relatively Long Album Name">
|
|
|
|
Artist Name
|
|
|
|
13 tracks
|
|
|
|
</Card>
|
|
|
|
<Card small title="Relatively Long Album Name">
|
|
|
|
Artist Name
|
|
|
|
13 tracks
|
|
|
|
</Card>
|
2025-01-03 13:36:06 +00:00
|
|
|
</LayoutSection>
|
2025-01-03 12:42:39 +00:00
|
|
|
|
2025-01-03 13:36:06 +00:00
|
|
|
<LayoutSection :alignLeft="alignLeft" medium-items h3="Activities (medium items)" :action="{ text:'more...', to:'/' }">
|
2025-01-03 12:42:39 +00:00
|
|
|
<Activity :track="track" :user="user" />
|
|
|
|
<Activity :track="track" :user="user" />
|
|
|
|
<Activity :track="track" :user="user" />
|
2025-01-03 13:36:06 +00:00
|
|
|
</LayoutSection>
|
|
|
|
|
2025-01-03 12:42:39 +00:00
|
|
|
</div>
|