diff --git a/apps/frontend/src/components/ui/create-project-version/components/McVersionPicker.vue b/apps/frontend/src/components/ui/create-project-version/components/McVersionPicker.vue index 8387f7236..2f5758b54 100644 --- a/apps/frontend/src/components/ui/create-project-version/components/McVersionPicker.vue +++ b/apps/frontend/src/components/ui/create-project-version/components/McVersionPicker.vue @@ -155,7 +155,7 @@ function groupVersions(gameVersions: GameVersion[]) { const groups: Record = {} - let currentGroupKey = getSnapshotGroupKey(gameVersions.find((v) => v.major)?.version || '') + let currentGroupKey gameVersions.forEach((gameVersion) => { if (gameVersion.version_type === 'release') { diff --git a/apps/frontend/src/providers/version/manage-version-modal.ts b/apps/frontend/src/providers/version/manage-version-modal.ts index e72a16eb8..9ddf366a1 100644 --- a/apps/frontend/src/providers/version/manage-version-modal.ts +++ b/apps/frontend/src/providers/version/manage-version-modal.ts @@ -426,9 +426,12 @@ export function createManageVersionContext( } // Stage visibility computeds (inlined) - const noEnvironmentProject = computed( - () => projectType.value !== 'mod' && projectType.value !== 'modpack', - ) + const noEnvironmentProject = computed(() => { + const hasModLoaders = draftVersion.value.loaders.some((loader) => + PROJECT_TYPE_LOADERS.mod.includes(loader), + ) + return !hasModLoaders && projectType.value !== 'modpack' + }) const noDependenciesProject = computed(() => projectType.value === 'modpack') const getProject = async (projectId: string) => { diff --git a/packages/utils/projects.ts b/packages/utils/projects.ts index 0f5f12ebf..2210850db 100644 --- a/packages/utils/projects.ts +++ b/packages/utils/projects.ts @@ -126,12 +126,13 @@ export function formatVersionsForDisplay( // show all snapshots if there's no release versions if (releaseVersionsAsRanges.length === 0) { - const snapshotVersionsAsRanges = groupConsecutiveIndices( - inputVersions.filter((projVer) => - allSnapshots.some((gameVer) => gameVer.version === projVer), - ), - allSnapshots, + const snapshotVersions = inputVersions.filter((projVer) => + allSnapshots.some((gameVer) => gameVer.version === projVer), ) + const snapshotVersionsAsRanges = + snapshotVersions.length > 3 + ? groupConsecutiveIndices(snapshotVersions, allSnapshots) + : snapshotVersions output = [...snapshotVersionsAsRanges, ...output] } else { output = [...releaseVersionsAsRanges, ...output]