You've already forked AstralRinth
forked from didirus/AstralRinth
7d92e4ec7f
* feat: base content card component * fix: tooltips + colors * feat: fix orgs * feat: base content tab internals rewrite * feat: fix invalidmodal * feat: add ContentModpackCard * fix: extract types * draft: layout * feat: unlink modal * feat: impl content tab * fix: lint * fix: toggling * temp: disable updating stuff * feat: selection v-model * feat: bulk selection * feat: mods tab rough draft * feat: use fuse.js * feat: add project combobox * clean up project combobox * feat: start install to play modal * fix: events * feat: use v-on * feat: bulk actions + fix floating action bar width * feat: figma alignments * feat: migrate toggle to tailwind * fix: row borders * feat: disabled state * feat: virtual list impl for card table based on window scroll * fix: lint * feat: virtualization + smaller contentcard items * feat: use ContentCardTable + ContentCardItems * feat: fix gap + border issues on last elm * feat: cleanup + use proper searching * fix: use TeleportOverflowMenu * fix: fallback to svg if src is invalid on avatar component * fix: storybook * feat: start on updater modal * feat: finish content updater modal * feat: i18n pass * feat: impl modal * feat(app): backend changes for content tab refactor (#5237) * feat: include_changelog=false for updater modal * fix: hash overrides * feat: update checking for modpack * feat: qa * feat: modpack content modal * fix: padding in table to match modals + tightness * fix: lint * feat: delete modal * feat: fix toggle bugs * fix: prepr * fix: duplicate messages * qa: full width search * qa: use bg-surface-1.5 * qa: animation for filter pills * qa: standardize hover colors * fix: border-[1px] is border * qa: mass de-select actually mass selecting * qa: match figma designs for floating action bar * qa: modal fixes * q: modal fixes x2 * fix: table border * qa: confirm modals * qa: modal alignment * qa: re-add stuck heading + dedupe logic * qa: dedupe virtual scrolling + remove dead components * qa: responsiveness for content table + link fixes * qa: version column link, tooltips + lint fixes * qa: instance busy protections * fix: installation freeze bug * chore: remove old mods page * refactor: deduplicate layout * chore: delete old content page(s) * qa * qa * qa * feat: sort btn - to iterate * fix: ml * feat: date added * fix: lint * fix: formatting.ts removal * feat: get_dependencies_as_content_items * qa: final QA changes * refactor: deduplicate + polish content.rs * feat: hook up content.vue with v1 * feat: hide v1 content api behind frontend feature flag * fix: query keys + copy on empty state * chore: i18n pass * feat: reimpl unlink + upload endpoint * feat: use bulk endpoints v1 * fix: lint * fix: flags * fix: responsiveness via container queries * fix: lint * qa: 1 * qa: fixes * qa: fix ssr issues with browse content * qa: header page divider * qa: modals * fix: prepr * fix: issues * fix: lint * fix: toggle v1 ff * qa: 5 * qa: delete modal copy * feat: creation flow modals (#5383) * refactor: delete content v0 usages + impl * feat: qa + fixes * feat: installing banner using state event * feat: fix modpack card bugs + filtering issues * refactor: delete backups v0 api module * feat: v1 servers GET endpoint * fix: backups * feat: swap to kyros upload v1 addon * fix: use tanstack for loader.vue * feat: finish install from discovery modal * qa: bug fixes * feat: set up installation settings * fix: lint * fix: typos * fix: bugs * fix: disable inline content * feat: content tab improvements — upload UX, installation settings, and client-only indicators Upload cancellation and navigation guard: - Add ConfirmLeaveModal that prompts when navigating away during upload - Cancel in-flight XHR uploads when user confirms leaving the page - Add beforeunload handler to warn on browser/tab close during upload - Track uploadedBytes/totalBytes in UploadState for progress display - Replace Collapsible with Transition for upload progress admonition - Show byte progress and percentage in upload banner - Clamp upload progress to prevent exceeding 100% Installation settings (server.properties): - Add KnownPropertiesFields and PropertiesFields types to Archon types - Add buildProperties() to creation flow context to collect gamemode, difficulty, seed, world type, structures, and generator settings - Pass properties through installContent on onboarding, discovery, and ServerSetupModal flows Server setup and discovery flow improvements: - Migrate ServerSetupModal from servers_v0.reinstall to content_v1.installContent - Replace loaderApiNames lookup with toApiLoader() helper - Remove eraseDataOnInstall toggle — always use soft_override: false - Simplify modpack install on discovery page to use first available version and route through creation flow modal for both onboarding and non-onboarding - Differentiate post-install navigation: content page for onboarding, loader options for existing servers Modpack update flow: - Replace updateModpack() call with installContent() using soft_override: true to support version selection in the content updater modal Client-only mod indicators: - Add environment field to AddonVersion (reuses Labrinth.Projects.v3.Environment) - Add environment to ContentItem and isClientOnly to ContentCardTableItem - Show orange TriangleAlertIcon with tooltip on client-only mods in content table - Add "Client-only" filter pill to content filtering (controlled via showClientOnlyFilter on ContentManagerContext) - Apply client-only indicators in both ContentPageLayout and ModpackContentModal Misc: - Add CLAUDE.md note about using prepr commands for lint checks - Export ConfirmLeaveModal from instances barrel * fix: piping * fix: switch content disable for linked server instances * feat: client only filter * fix: prepr * feat: hasUpdate shape update * feat: bulk update endpoint impl for content in panel * feat: websocket state impl again with new phases * fix: ws * fix: use timeout fn for sync admon + fix content card layout scroll for browsers with overflow anchor bug * fix: qa bugs * fix: lint, a11y and i18n * refactor: set up layouts folder properly * fix: linked data cache stuff + lint * feat: move installationsettings to shared layout * fix: lint * fix: issues * feat: temp fuck staging up * fix: lockfile * fix: data sync issues on loader.vue * fix: lint * Hide shader configuration files from content list (#5499) * feat: workaround search problem + split out reset * fix: qa * fix: changelog not showing on first open * fix: qa + optimistic updating improvements * fix: prepr+lint * fix: qa * feat: qa * fix: lint * fix: lint * fix: build * fix: build * fix: type errors * fix: fade and JAVA_HOME passthrough * feat: qa * feat: impl diff shit * fix: qa * fix: app qa * feat: update diff modal * fix: endpoint * fix: qa * fix: qa * fix: use bulk in modpack modal * feat: abort signal impl + fix issues * fix: diff modal trunc * feat: qa * fix: qa * feat: tooltip content tab * fix: prepr * fix: dismiss on settings btn * feat: qa * feat: dont clear handlers on disconnect * fix: lint * fix: wrangler + introduce staging-archon env file --------- Signed-off-by: Calum H. <calum@modrinth.com> Co-authored-by: tdgao <mr.trumgao@gmail.com> Co-authored-by: Artyom Ezri <61311568+Artezon@users.noreply.github.com>
619 lines
15 KiB
TypeScript
619 lines
15 KiB
TypeScript
import type { Meta, StoryObj } from '@storybook/vue3-vite'
|
|
import { ref } from 'vue'
|
|
|
|
import ButtonStyled from '../../components/base/ButtonStyled.vue'
|
|
import ModpackContentModal from '../../layouts/shared/content-tab/components/modals/ModpackContentModal.vue'
|
|
import type { ContentItem } from '../../layouts/shared/content-tab/types'
|
|
|
|
// Sample modpack content items (representing mods included in a modpack)
|
|
const sodiumItem: ContentItem = {
|
|
file_name: 'sodium-fabric-0.8.2+mc1.21.1.jar',
|
|
file_path: '',
|
|
hash: '',
|
|
size: 1024000,
|
|
enabled: true,
|
|
project_type: 'mod',
|
|
project: {
|
|
id: 'AANobbMI',
|
|
slug: 'sodium',
|
|
title: 'Sodium',
|
|
icon_url:
|
|
'https://cdn.modrinth.com/data/AANobbMI/295862f4724dc3f78df3447ad6072b2dcd3ef0c9_96.webp',
|
|
},
|
|
version: {
|
|
id: '59wygFUQ',
|
|
version_number: 'mc1.21.1-0.8.2-fabric',
|
|
file_name: 'sodium-fabric-0.8.2+mc1.21.1.jar',
|
|
},
|
|
owner: {
|
|
id: 'DzLrfrbK',
|
|
name: 'IMS',
|
|
avatar_url: 'https://avatars3.githubusercontent.com/u/31803019?v=4',
|
|
type: 'user',
|
|
},
|
|
has_update: false,
|
|
update_version_id: null,
|
|
}
|
|
|
|
const lithiumItem: ContentItem = {
|
|
file_name: 'lithium-fabric-0.14.3+mc1.21.1.jar',
|
|
file_path: '',
|
|
hash: '',
|
|
size: 512000,
|
|
enabled: true,
|
|
project_type: 'mod',
|
|
project: {
|
|
id: 'gvQqBUqZ',
|
|
slug: 'lithium',
|
|
title: 'Lithium',
|
|
icon_url:
|
|
'https://cdn.modrinth.com/data/gvQqBUqZ/d6a1873d52b7d1c82b9a8d9b1889c9c1a29ae92d_96.webp',
|
|
},
|
|
version: {
|
|
id: 'abc123',
|
|
version_number: 'mc1.21.1-0.14.3',
|
|
file_name: 'lithium-fabric-0.14.3+mc1.21.1.jar',
|
|
},
|
|
owner: {
|
|
id: 'DzLrfrbK',
|
|
name: 'IMS',
|
|
avatar_url: 'https://avatars3.githubusercontent.com/u/31803019?v=4',
|
|
type: 'user',
|
|
},
|
|
has_update: false,
|
|
update_version_id: null,
|
|
}
|
|
|
|
const fabricApiItem: ContentItem = {
|
|
file_name: 'fabric-api-0.141.3+26.1.jar',
|
|
file_path: '',
|
|
hash: '',
|
|
size: 2048000,
|
|
enabled: true,
|
|
project_type: 'mod',
|
|
project: {
|
|
id: 'P7dR8mSH',
|
|
slug: 'fabric-api',
|
|
title: 'Fabric API',
|
|
icon_url: 'https://cdn.modrinth.com/data/P7dR8mSH/icon.png',
|
|
},
|
|
version: {
|
|
id: 'Lwa1Q6e4',
|
|
version_number: '0.141.3+26.1',
|
|
file_name: 'fabric-api-0.141.3+26.1.jar',
|
|
},
|
|
owner: {
|
|
id: 'BZoBsPo6',
|
|
name: 'FabricMC',
|
|
avatar_url: 'https://cdn.modrinth.com/data/P7dR8mSH/icon.png',
|
|
type: 'organization',
|
|
},
|
|
has_update: false,
|
|
update_version_id: null,
|
|
}
|
|
|
|
const modMenuItem: ContentItem = {
|
|
file_name: 'modmenu-16.0.0.jar',
|
|
file_path: '',
|
|
hash: '',
|
|
size: 256000,
|
|
enabled: true,
|
|
project_type: 'mod',
|
|
project: {
|
|
id: 'mOgUt4GM',
|
|
slug: 'modmenu',
|
|
title: 'Mod Menu',
|
|
icon_url: 'https://cdn.modrinth.com/data/mOgUt4GM/5a20ed1450a0e1e79a1fe04e61bb4e5878bf1d20.png',
|
|
},
|
|
version: {
|
|
id: 'QuU0ciaR',
|
|
version_number: '16.0.0',
|
|
file_name: 'modmenu-16.0.0.jar',
|
|
},
|
|
owner: {
|
|
id: 'u2',
|
|
name: 'Prospector',
|
|
type: 'user',
|
|
},
|
|
has_update: false,
|
|
update_version_id: null,
|
|
}
|
|
|
|
const irisItem: ContentItem = {
|
|
file_name: 'iris-1.8.0+mc1.21.1.jar',
|
|
file_path: '',
|
|
hash: '',
|
|
size: 1536000,
|
|
enabled: true,
|
|
project_type: 'mod',
|
|
project: {
|
|
id: 'YL57xq9U',
|
|
slug: 'iris',
|
|
title: 'Iris Shaders',
|
|
icon_url: 'https://cdn.modrinth.com/data/YL57xq9U/icon.png',
|
|
},
|
|
version: {
|
|
id: 'iris123',
|
|
version_number: '1.8.0+mc1.21.1',
|
|
file_name: 'iris-1.8.0+mc1.21.1.jar',
|
|
},
|
|
owner: {
|
|
id: 'coderbot',
|
|
name: 'coderbot',
|
|
type: 'user',
|
|
},
|
|
has_update: false,
|
|
update_version_id: null,
|
|
}
|
|
|
|
const entityModelFeaturesItem: ContentItem = {
|
|
file_name: 'entity-model-features-fabric-2.4.1+mc1.21.1.jar',
|
|
file_path: '',
|
|
hash: '',
|
|
size: 768000,
|
|
enabled: true,
|
|
project_type: 'mod',
|
|
project: {
|
|
id: 'emf123',
|
|
slug: 'entity-model-features',
|
|
title: '[EMF] Entity Model Features',
|
|
icon_url:
|
|
'https://cdn.modrinth.com/data/AANobbMI/295862f4724dc3f78df3447ad6072b2dcd3ef0c9_96.webp',
|
|
},
|
|
version: {
|
|
id: 'emfv1',
|
|
version_number: '2.4.1',
|
|
file_name: 'Entity_model_features_fabric_1.21.1-2.4.1.jar',
|
|
},
|
|
owner: {
|
|
id: 'traben',
|
|
name: 'Traben',
|
|
type: 'user',
|
|
},
|
|
has_update: false,
|
|
update_version_id: null,
|
|
}
|
|
|
|
const entityTextureFeaturesItem: ContentItem = {
|
|
file_name: 'entity-texture-features-fabric-6.2.9+mc1.21.1.jar',
|
|
file_path: '',
|
|
hash: '',
|
|
size: 640000,
|
|
enabled: true,
|
|
project_type: 'mod',
|
|
project: {
|
|
id: 'etf456',
|
|
slug: 'entity-texture-features',
|
|
title: '[ETF] Entity Texture Features',
|
|
icon_url: 'https://cdn.modrinth.com/data/mOgUt4GM/5a20ed1450a0e1e79a1fe04e61bb4e5878bf1d20.png',
|
|
},
|
|
version: {
|
|
id: 'etfv1',
|
|
version_number: '6.2.9',
|
|
file_name: 'Entity_texture_features_fabric_1.21.1-6.2.9.jar',
|
|
},
|
|
owner: {
|
|
id: 'traben',
|
|
name: 'Traben',
|
|
type: 'user',
|
|
},
|
|
has_update: false,
|
|
update_version_id: null,
|
|
}
|
|
|
|
// Shader pack item
|
|
const complementaryShaderItem: ContentItem = {
|
|
file_name: 'ComplementaryReimagined_r5.3.zip',
|
|
file_path: '',
|
|
hash: '',
|
|
size: 2048000,
|
|
enabled: true,
|
|
project_type: 'shader',
|
|
project: {
|
|
id: 'shader1',
|
|
slug: 'complementary-reimagined',
|
|
title: 'Complementary Reimagined',
|
|
icon_url: 'https://cdn.modrinth.com/data/HVnmMxH1/icon.png',
|
|
},
|
|
version: {
|
|
id: 'shaderv1',
|
|
version_number: 'r5.3',
|
|
file_name: 'ComplementaryReimagined_r5.3.zip',
|
|
},
|
|
owner: {
|
|
id: 'emin',
|
|
name: 'EminGT',
|
|
type: 'user',
|
|
},
|
|
has_update: false,
|
|
update_version_id: null,
|
|
}
|
|
|
|
const bslShaderItem: ContentItem = {
|
|
file_name: 'BSL_v8.2.09.zip',
|
|
file_path: '',
|
|
hash: '',
|
|
size: 1024000,
|
|
enabled: true,
|
|
project_type: 'shader',
|
|
project: {
|
|
id: 'shader2',
|
|
slug: 'bsl-shaders',
|
|
title: 'BSL Shaders',
|
|
icon_url: 'https://cdn.modrinth.com/data/Q1vvjJYV/icon.png',
|
|
},
|
|
version: {
|
|
id: 'shaderv2',
|
|
version_number: 'v8.2.09',
|
|
file_name: 'BSL_v8.2.09.zip',
|
|
},
|
|
owner: {
|
|
id: 'capt',
|
|
name: 'CaptTatsu',
|
|
type: 'user',
|
|
},
|
|
has_update: false,
|
|
update_version_id: null,
|
|
}
|
|
|
|
// Resource pack items
|
|
const faithfulItem: ContentItem = {
|
|
file_name: 'Faithful 32x - 1.21.zip',
|
|
file_path: '',
|
|
hash: '',
|
|
size: 8192000,
|
|
enabled: true,
|
|
project_type: 'resourcepack',
|
|
project: {
|
|
id: 'rp1',
|
|
slug: 'faithful-32x',
|
|
title: 'Faithful 32x',
|
|
icon_url: 'https://cdn.modrinth.com/data/tAnpCviC/icon.png',
|
|
},
|
|
version: {
|
|
id: 'rpv1',
|
|
version_number: '1.21',
|
|
file_name: 'Faithful 32x - 1.21.zip',
|
|
},
|
|
owner: {
|
|
id: 'faithful',
|
|
name: 'Faithful Resource Pack',
|
|
avatar_url: 'https://cdn.modrinth.com/data/tAnpCviC/icon.png',
|
|
type: 'organization',
|
|
},
|
|
has_update: false,
|
|
update_version_id: null,
|
|
}
|
|
|
|
const vanillaTweaksItem: ContentItem = {
|
|
file_name: 'VanillaTweaks_r3.zip',
|
|
file_path: '',
|
|
hash: '',
|
|
size: 512000,
|
|
enabled: true,
|
|
project_type: 'resourcepack',
|
|
project: {
|
|
id: 'rp2',
|
|
slug: 'vanilla-tweaks',
|
|
title: 'Vanilla Tweaks',
|
|
icon_url: null,
|
|
},
|
|
version: {
|
|
id: 'rpv2',
|
|
version_number: 'r3',
|
|
file_name: 'VanillaTweaks_r3.zip',
|
|
},
|
|
owner: {
|
|
id: 'xisuma',
|
|
name: 'Xisumavoid',
|
|
type: 'user',
|
|
},
|
|
has_update: false,
|
|
update_version_id: null,
|
|
}
|
|
|
|
const stayTrueItem: ContentItem = {
|
|
file_name: 'Stay_True_1.21.zip',
|
|
file_path: '',
|
|
hash: '',
|
|
size: 4096000,
|
|
enabled: true,
|
|
project_type: 'resourcepack',
|
|
project: {
|
|
id: 'rp3',
|
|
slug: 'stay-true',
|
|
title: 'Stay True',
|
|
icon_url: 'https://cdn.modrinth.com/data/HVnmMxH1/icon.png',
|
|
},
|
|
version: {
|
|
id: 'rpv3',
|
|
version_number: '1.21',
|
|
file_name: 'Stay_True_1.21.zip',
|
|
},
|
|
owner: {
|
|
id: 'hallowed',
|
|
name: 'HallowedST',
|
|
type: 'user',
|
|
},
|
|
has_update: false,
|
|
update_version_id: null,
|
|
}
|
|
|
|
// Mixed content (mods + shaders + resource packs)
|
|
const mixedModpackContent: ContentItem[] = [
|
|
sodiumItem,
|
|
lithiumItem,
|
|
fabricApiItem,
|
|
modMenuItem,
|
|
irisItem,
|
|
entityModelFeaturesItem,
|
|
entityTextureFeaturesItem,
|
|
complementaryShaderItem,
|
|
bslShaderItem,
|
|
faithfulItem,
|
|
vanillaTweaksItem,
|
|
stayTrueItem,
|
|
]
|
|
|
|
// Mods only
|
|
const modsOnlyContent: ContentItem[] = [
|
|
sodiumItem,
|
|
lithiumItem,
|
|
fabricApiItem,
|
|
modMenuItem,
|
|
irisItem,
|
|
entityModelFeaturesItem,
|
|
entityTextureFeaturesItem,
|
|
]
|
|
|
|
// Large modpack content (40+ items for testing scrolling)
|
|
const largeModpackContent: ContentItem[] = [
|
|
...mixedModpackContent,
|
|
...Array.from({ length: 35 }, (_, i) => ({
|
|
...sodiumItem,
|
|
file_name: `mod-${i + 1}-1.0.0.jar`,
|
|
project: {
|
|
id: `mod-${i + 1}`,
|
|
slug: `mod-${i + 1}`,
|
|
title: `Example Mod ${i + 1}`,
|
|
icon_url:
|
|
i % 3 === 0
|
|
? sodiumItem.project!.icon_url
|
|
: i % 3 === 1
|
|
? fabricApiItem.project!.icon_url
|
|
: modMenuItem.project!.icon_url,
|
|
},
|
|
version: {
|
|
id: `v${i + 1}`,
|
|
version_number: `1.${i}.0`,
|
|
file_name: `mod-${i + 1}-1.0.0.jar`,
|
|
},
|
|
owner: i % 2 === 0 ? sodiumItem.owner : fabricApiItem.owner,
|
|
})),
|
|
]
|
|
|
|
const meta = {
|
|
title: 'Instances/ModpackContentModal',
|
|
component: ModpackContentModal,
|
|
parameters: {
|
|
layout: 'centered',
|
|
},
|
|
} satisfies Meta<typeof ModpackContentModal>
|
|
|
|
export default meta
|
|
type Story = StoryObj<typeof meta>
|
|
|
|
// ============================================
|
|
// Basic Examples
|
|
// ============================================
|
|
|
|
export const Default: Story = {
|
|
render: () => ({
|
|
components: { ModpackContentModal, ButtonStyled },
|
|
setup() {
|
|
const modalRef = ref<InstanceType<typeof ModpackContentModal> | null>(null)
|
|
const openModal = () => modalRef.value?.show(mixedModpackContent)
|
|
return { modalRef, openModal }
|
|
},
|
|
template: /*html*/ `
|
|
<div>
|
|
<ButtonStyled color="brand">
|
|
<button @click="openModal">View Modpack Content (Mixed)</button>
|
|
</ButtonStyled>
|
|
<ModpackContentModal
|
|
ref="modalRef"
|
|
modpack-name="Cobblemon Official Modpack"
|
|
modpack-icon-url="https://cdn.modrinth.com/data/5FFgwNNP/icon.png"
|
|
/>
|
|
</div>
|
|
`,
|
|
}),
|
|
}
|
|
|
|
export const ModsOnly: Story = {
|
|
render: () => ({
|
|
components: { ModpackContentModal, ButtonStyled },
|
|
setup() {
|
|
const modalRef = ref<InstanceType<typeof ModpackContentModal> | null>(null)
|
|
const openModal = () => modalRef.value?.show(modsOnlyContent)
|
|
return { modalRef, openModal }
|
|
},
|
|
template: /*html*/ `
|
|
<div>
|
|
<ButtonStyled color="brand">
|
|
<button @click="openModal">View Modpack Content (Mods Only)</button>
|
|
</ButtonStyled>
|
|
<ModpackContentModal ref="modalRef" />
|
|
</div>
|
|
`,
|
|
}),
|
|
}
|
|
|
|
// ============================================
|
|
// Loading State
|
|
// ============================================
|
|
|
|
export const LoadingState: Story = {
|
|
render: () => ({
|
|
components: { ModpackContentModal, ButtonStyled },
|
|
setup() {
|
|
const modalRef = ref<InstanceType<typeof ModpackContentModal> | null>(null)
|
|
const openModal = () => {
|
|
modalRef.value?.showLoading()
|
|
// Simulate loading delay
|
|
setTimeout(() => {
|
|
modalRef.value?.show(mixedModpackContent)
|
|
}, 2000)
|
|
}
|
|
return { modalRef, openModal }
|
|
},
|
|
template: /*html*/ `
|
|
<div>
|
|
<ButtonStyled color="brand">
|
|
<button @click="openModal">View Content (With Loading)</button>
|
|
</ButtonStyled>
|
|
<ModpackContentModal
|
|
ref="modalRef"
|
|
modpack-name="Fabulously Optimized"
|
|
modpack-icon-url="https://cdn.modrinth.com/data/1KVo5zza/icon.png"
|
|
/>
|
|
</div>
|
|
`,
|
|
}),
|
|
}
|
|
|
|
// ============================================
|
|
// Empty State
|
|
// ============================================
|
|
|
|
export const EmptyContent: Story = {
|
|
render: () => ({
|
|
components: { ModpackContentModal, ButtonStyled },
|
|
setup() {
|
|
const modalRef = ref<InstanceType<typeof ModpackContentModal> | null>(null)
|
|
const openModal = () => modalRef.value?.show([])
|
|
return { modalRef, openModal }
|
|
},
|
|
template: /*html*/ `
|
|
<div>
|
|
<ButtonStyled color="brand">
|
|
<button @click="openModal">View Empty Modpack</button>
|
|
</ButtonStyled>
|
|
<ModpackContentModal ref="modalRef" />
|
|
</div>
|
|
`,
|
|
}),
|
|
}
|
|
|
|
// ============================================
|
|
// Large Content List
|
|
// ============================================
|
|
|
|
export const LargeModpack: Story = {
|
|
render: () => ({
|
|
components: { ModpackContentModal, ButtonStyled },
|
|
setup() {
|
|
const modalRef = ref<InstanceType<typeof ModpackContentModal> | null>(null)
|
|
const openModal = () => modalRef.value?.show(largeModpackContent)
|
|
return { modalRef, openModal }
|
|
},
|
|
template: /*html*/ `
|
|
<div>
|
|
<ButtonStyled color="brand">
|
|
<button @click="openModal">View Large Modpack (47 items)</button>
|
|
</ButtonStyled>
|
|
<ModpackContentModal
|
|
ref="modalRef"
|
|
modpack-name="All the Mods 10"
|
|
modpack-icon-url="https://cdn.modrinth.com/data/1KVo5zza/icon.png"
|
|
/>
|
|
</div>
|
|
`,
|
|
}),
|
|
}
|
|
|
|
// ============================================
|
|
// Search Functionality
|
|
// ============================================
|
|
|
|
export const SearchDemo: Story = {
|
|
render: () => ({
|
|
components: { ModpackContentModal, ButtonStyled },
|
|
setup() {
|
|
const modalRef = ref<InstanceType<typeof ModpackContentModal> | null>(null)
|
|
const openModal = () => modalRef.value?.show(mixedModpackContent)
|
|
return { modalRef, openModal }
|
|
},
|
|
template: /*html*/ `
|
|
<div class="flex flex-col gap-4 items-center">
|
|
<p class="text-sm text-secondary max-w-md text-center">
|
|
Click the button and try searching for "sodium", "shader", or "faithful" to test the search functionality.
|
|
</p>
|
|
<ButtonStyled color="brand">
|
|
<button @click="openModal">Test Search</button>
|
|
</ButtonStyled>
|
|
<ModpackContentModal ref="modalRef" />
|
|
</div>
|
|
`,
|
|
}),
|
|
}
|
|
|
|
// ============================================
|
|
// Filter Demo
|
|
// ============================================
|
|
|
|
export const FilterDemo: Story = {
|
|
render: () => ({
|
|
components: { ModpackContentModal, ButtonStyled },
|
|
setup() {
|
|
const modalRef = ref<InstanceType<typeof ModpackContentModal> | null>(null)
|
|
const openModal = () => modalRef.value?.show(mixedModpackContent)
|
|
return { modalRef, openModal }
|
|
},
|
|
template: /*html*/ `
|
|
<div class="flex flex-col gap-4 items-center">
|
|
<p class="text-sm text-secondary max-w-md text-center">
|
|
Click the button and try the filter chips (Mods, Shaders, Resource Packs) to filter content by type.
|
|
</p>
|
|
<ButtonStyled color="brand">
|
|
<button @click="openModal">Test Filters</button>
|
|
</ButtonStyled>
|
|
<ModpackContentModal ref="modalRef" />
|
|
</div>
|
|
`,
|
|
}),
|
|
}
|
|
|
|
// ============================================
|
|
// Mixed Owner Types
|
|
// ============================================
|
|
|
|
export const MixedOwnerTypes: Story = {
|
|
render: () => ({
|
|
components: { ModpackContentModal, ButtonStyled },
|
|
setup() {
|
|
const modalRef = ref<InstanceType<typeof ModpackContentModal> | null>(null)
|
|
// Mix of user and organization owners
|
|
const mixedContent = [
|
|
sodiumItem, // User owner
|
|
fabricApiItem, // Organization owner
|
|
modMenuItem, // User owner without avatar
|
|
faithfulItem, // Organization owner
|
|
]
|
|
const openModal = () => modalRef.value?.show(mixedContent)
|
|
return { modalRef, openModal }
|
|
},
|
|
template: /*html*/ `
|
|
<div class="flex flex-col gap-4 items-center">
|
|
<p class="text-sm text-secondary max-w-md text-center">
|
|
Shows content with different owner types: users (circular avatar) and organizations (rounded + icon).
|
|
</p>
|
|
<ButtonStyled color="brand">
|
|
<button @click="openModal">View Mixed Owners</button>
|
|
</ButtonStyled>
|
|
<ModpackContentModal ref="modalRef" />
|
|
</div>
|
|
`,
|
|
}),
|
|
}
|