mirror of
				https://github.com/immich-app/immich.git
				synced 2025-10-25 16:04:21 -04:00 
			
		
		
		
	fix(web): redirect to parent folder if asset viewer was open before reload (#2863)
* fix(web): redirect to parent folder if asset viewer was open before reload * chore(web): use route constants in all routes
This commit is contained in:
		
							parent
							
								
									cc45564d84
								
							
						
					
					
						commit
						c404ea20ee
					
				| @ -18,6 +18,7 @@ export enum AppRoute { | |||||||
| 	SEARCH = '/search', | 	SEARCH = '/search', | ||||||
| 	MAP = '/map', | 	MAP = '/map', | ||||||
| 	USER_SETTINGS = '/user-settings', | 	USER_SETTINGS = '/user-settings', | ||||||
|  | 	MEMORY = '/memory', | ||||||
| 
 | 
 | ||||||
| 	AUTH_LOGIN = '/auth/login', | 	AUTH_LOGIN = '/auth/login', | ||||||
| 	AUTH_LOGOUT = '/auth/logout', | 	AUTH_LOGOUT = '/auth/logout', | ||||||
|  | |||||||
| @ -1,18 +1,19 @@ | |||||||
| import { redirect } from '@sveltejs/kit'; | import { redirect } from '@sveltejs/kit'; | ||||||
| export const prerender = false; | export const prerender = false; | ||||||
| import type { PageLoad } from './$types'; | import type { PageLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
| 
 | 
 | ||||||
| export const load: PageLoad = async ({ params, parent }) => { | export const load: PageLoad = async ({ params, parent }) => { | ||||||
| 	const { user } = await parent(); | 	const { user } = await parent(); | ||||||
| 	if (!user) { | 	if (!user) { | ||||||
| 		throw redirect(302, '/auth/login'); | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	const albumId = params['albumId']; | 	const albumId = params['albumId']; | ||||||
| 
 | 
 | ||||||
| 	if (albumId) { | 	if (albumId) { | ||||||
| 		throw redirect(302, `/albums/${albumId}`); | 		throw redirect(302, `${AppRoute.ALBUMS}/${albumId}`); | ||||||
| 	} else { | 	} else { | ||||||
| 		throw redirect(302, `/photos`); | 		throw redirect(302, AppRoute.PHOTOS); | ||||||
| 	} | 	} | ||||||
| }; | }; | ||||||
|  | |||||||
							
								
								
									
										13
									
								
								web/src/routes/(user)/archive/photos/[assetId]/+page.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								web/src/routes/(user)/archive/photos/[assetId]/+page.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,13 @@ | |||||||
|  | import { redirect } from '@sveltejs/kit'; | ||||||
|  | export const prerender = false; | ||||||
|  | import type { PageLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
|  | 
 | ||||||
|  | export const load: PageLoad = async ({ parent }) => { | ||||||
|  | 	const { user } = await parent(); | ||||||
|  | 	if (!user) { | ||||||
|  | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	throw redirect(302, AppRoute.ARCHIVE); | ||||||
|  | }; | ||||||
| @ -1,10 +1,11 @@ | |||||||
| import { redirect } from '@sveltejs/kit'; | import { redirect } from '@sveltejs/kit'; | ||||||
| import type { PageServerLoad } from './$types'; | import type { PageServerLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
| 
 | 
 | ||||||
| export const load = (async ({ locals, parent }) => { | export const load = (async ({ locals, parent }) => { | ||||||
| 	const { user } = await parent(); | 	const { user } = await parent(); | ||||||
| 	if (!user) { | 	if (!user) { | ||||||
| 		throw redirect(302, '/auth/login'); | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	const { data: items } = await locals.api.searchApi.getExploreData(); | 	const { data: items } = await locals.api.searchApi.getExploreData(); | ||||||
|  | |||||||
| @ -2,13 +2,14 @@ import { redirect } from '@sveltejs/kit'; | |||||||
| export const prerender = false; | export const prerender = false; | ||||||
| 
 | 
 | ||||||
| import type { PageServerLoad } from './$types'; | import type { PageServerLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
| 
 | 
 | ||||||
| export const load: PageServerLoad = async ({ parent }) => { | export const load: PageServerLoad = async ({ parent }) => { | ||||||
| 	const { user } = await parent(); | 	const { user } = await parent(); | ||||||
| 
 | 
 | ||||||
| 	if (!user) { | 	if (!user) { | ||||||
| 		throw redirect(302, '/auth/login'); | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
| 	} else { | 	} else { | ||||||
| 		throw redirect(302, '/favorites'); | 		throw redirect(302, AppRoute.FAVORITES); | ||||||
| 	} | 	} | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -2,13 +2,14 @@ import { redirect } from '@sveltejs/kit'; | |||||||
| export const prerender = false; | export const prerender = false; | ||||||
| 
 | 
 | ||||||
| import type { PageServerLoad } from './$types'; | import type { PageServerLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
| 
 | 
 | ||||||
| export const load: PageServerLoad = async ({ parent }) => { | export const load: PageServerLoad = async ({ parent }) => { | ||||||
| 	const { user } = await parent(); | 	const { user } = await parent(); | ||||||
| 
 | 
 | ||||||
| 	if (!user) { | 	if (!user) { | ||||||
| 		throw redirect(302, '/auth/login'); | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
| 	} else { | 	} else { | ||||||
| 		throw redirect(302, '/memory'); | 		throw redirect(302, AppRoute.MEMORY); | ||||||
| 	} | 	} | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -2,13 +2,14 @@ import { redirect } from '@sveltejs/kit'; | |||||||
| export const prerender = false; | export const prerender = false; | ||||||
| 
 | 
 | ||||||
| import type { PageServerLoad } from './$types'; | import type { PageServerLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
| 
 | 
 | ||||||
| export const load: PageServerLoad = async ({ parent }) => { | export const load: PageServerLoad = async ({ parent }) => { | ||||||
| 	const { user } = await parent(); | 	const { user } = await parent(); | ||||||
| 
 | 
 | ||||||
| 	if (!user) { | 	if (!user) { | ||||||
| 		throw redirect(302, '/auth/login'); | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
| 	} else { | 	} else { | ||||||
| 		throw redirect(302, '/memory'); | 		throw redirect(302, AppRoute.MEMORY); | ||||||
| 	} | 	} | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -1,10 +1,11 @@ | |||||||
| import { redirect } from '@sveltejs/kit'; | import { redirect } from '@sveltejs/kit'; | ||||||
| import type { PageServerLoad } from './$types'; | import type { PageServerLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
| 
 | 
 | ||||||
| export const load = (async ({ locals, parent }) => { | export const load = (async ({ locals, parent }) => { | ||||||
| 	const { user } = await parent(); | 	const { user } = await parent(); | ||||||
| 	if (!user) { | 	if (!user) { | ||||||
| 		throw redirect(302, '/auth/login'); | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	const { data: people } = await locals.api.personApi.getAllPeople(); | 	const { data: people } = await locals.api.personApi.getAllPeople(); | ||||||
|  | |||||||
| @ -1,10 +1,11 @@ | |||||||
| import { redirect } from '@sveltejs/kit'; | import { redirect } from '@sveltejs/kit'; | ||||||
| import type { PageServerLoad } from './$types'; | import type { PageServerLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
| 
 | 
 | ||||||
| export const load = (async ({ locals, parent, params }) => { | export const load = (async ({ locals, parent, params }) => { | ||||||
| 	const { user } = await parent(); | 	const { user } = await parent(); | ||||||
| 	if (!user) { | 	if (!user) { | ||||||
| 		throw redirect(302, '/auth/login'); | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	const { data: person } = await locals.api.personApi.getPerson({ id: params.personId }); | 	const { data: person } = await locals.api.personApi.getPerson({ id: params.personId }); | ||||||
|  | |||||||
| @ -0,0 +1,14 @@ | |||||||
|  | import { redirect } from '@sveltejs/kit'; | ||||||
|  | export const prerender = false; | ||||||
|  | import type { PageLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
|  | 
 | ||||||
|  | export const load: PageLoad = async ({ params, parent }) => { | ||||||
|  | 	const { user } = await parent(); | ||||||
|  | 	if (!user) { | ||||||
|  | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	const personId = params['personId']; | ||||||
|  | 	throw redirect(302, `${AppRoute.PEOPLE}/${personId}`); | ||||||
|  | }; | ||||||
| @ -2,13 +2,14 @@ import { redirect } from '@sveltejs/kit'; | |||||||
| export const prerender = false; | export const prerender = false; | ||||||
| 
 | 
 | ||||||
| import type { PageServerLoad } from './$types'; | import type { PageServerLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
| 
 | 
 | ||||||
| export const load: PageServerLoad = async ({ parent }) => { | export const load: PageServerLoad = async ({ parent }) => { | ||||||
| 	const { user } = await parent(); | 	const { user } = await parent(); | ||||||
| 
 | 
 | ||||||
| 	if (!user) { | 	if (!user) { | ||||||
| 		throw redirect(302, '/auth/login'); | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
| 	} else { | 	} else { | ||||||
| 		throw redirect(302, '/photos'); | 		throw redirect(302, AppRoute.PHOTOS); | ||||||
| 	} | 	} | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -1,10 +1,11 @@ | |||||||
| import { redirect } from '@sveltejs/kit'; | import { redirect } from '@sveltejs/kit'; | ||||||
| import type { PageServerLoad } from './$types'; | import type { PageServerLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
| 
 | 
 | ||||||
| export const load = (async ({ locals, parent, url }) => { | export const load = (async ({ locals, parent, url }) => { | ||||||
| 	const { user } = await parent(); | 	const { user } = await parent(); | ||||||
| 	if (!user) { | 	if (!user) { | ||||||
| 		throw redirect(302, '/auth/login'); | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	const term = url.searchParams.get('q') || url.searchParams.get('query') || undefined; | 	const term = url.searchParams.get('q') || url.searchParams.get('query') || undefined; | ||||||
|  | |||||||
							
								
								
									
										13
									
								
								web/src/routes/(user)/search/photos/[assetId]/+page.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								web/src/routes/(user)/search/photos/[assetId]/+page.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,13 @@ | |||||||
|  | import { redirect } from '@sveltejs/kit'; | ||||||
|  | export const prerender = false; | ||||||
|  | import type { PageLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
|  | 
 | ||||||
|  | export const load: PageLoad = async ({ parent }) => { | ||||||
|  | 	const { user } = await parent(); | ||||||
|  | 	if (!user) { | ||||||
|  | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	throw redirect(302, AppRoute.SEARCH); | ||||||
|  | }; | ||||||
| @ -2,18 +2,19 @@ export const prerender = false; | |||||||
| 
 | 
 | ||||||
| import { redirect } from '@sveltejs/kit'; | import { redirect } from '@sveltejs/kit'; | ||||||
| import type { PageServerLoad } from './$types'; | import type { PageServerLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
| 
 | 
 | ||||||
| export const load = (async ({ parent, locals: { api } }) => { | export const load = (async ({ parent, locals: { api } }) => { | ||||||
| 	const { user } = await parent(); | 	const { user } = await parent(); | ||||||
| 	if (user) { | 	if (user) { | ||||||
| 		throw redirect(302, '/photos'); | 		throw redirect(302, AppRoute.PHOTOS); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	const { data } = await api.userApi.getUserCount({ admin: true }); | 	const { data } = await api.userApi.getUserCount({ admin: true }); | ||||||
| 
 | 
 | ||||||
| 	if (data.userCount > 0) { | 	if (data.userCount > 0) { | ||||||
| 		// Redirect to login page if an admin is already registered.
 | 		// Redirect to login page if an admin is already registered.
 | ||||||
| 		throw redirect(302, '/auth/login'); | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	return { | 	return { | ||||||
|  | |||||||
| @ -1,14 +1,15 @@ | |||||||
| import { redirect } from '@sveltejs/kit'; | import { redirect } from '@sveltejs/kit'; | ||||||
| import type { PageServerLoad } from './$types'; | import type { PageServerLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
| 
 | 
 | ||||||
| export const load: PageServerLoad = async ({ parent }) => { | export const load: PageServerLoad = async ({ parent }) => { | ||||||
| 	const { user } = await parent(); | 	const { user } = await parent(); | ||||||
| 
 | 
 | ||||||
| 	if (!user) { | 	if (!user) { | ||||||
| 		throw redirect(302, '/auth/login'); | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
| 	} else if (!user.isAdmin) { | 	} else if (!user.isAdmin) { | ||||||
| 		throw redirect(302, '/photos'); | 		throw redirect(302, AppRoute.PHOTOS); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	throw redirect(302, '/admin/user-management'); | 	throw redirect(302, AppRoute.ADMIN_USER_MANAGEMENT); | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -1,13 +1,14 @@ | |||||||
| import { redirect } from '@sveltejs/kit'; | import { redirect } from '@sveltejs/kit'; | ||||||
| import type { PageServerLoad } from './$types'; | import type { PageServerLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
| 
 | 
 | ||||||
| export const load = (async ({ parent, locals: { api } }) => { | export const load = (async ({ parent, locals: { api } }) => { | ||||||
| 	const { user } = await parent(); | 	const { user } = await parent(); | ||||||
| 
 | 
 | ||||||
| 	if (!user) { | 	if (!user) { | ||||||
| 		throw redirect(302, '/auth/login'); | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
| 	} else if (!user.isAdmin) { | 	} else if (!user.isAdmin) { | ||||||
| 		throw redirect(302, '/photos'); | 		throw redirect(302, AppRoute.PHOTOS); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	const { data: stats } = await api.serverInfoApi.getStats(); | 	const { data: stats } = await api.serverInfoApi.getStats(); | ||||||
|  | |||||||
| @ -1,13 +1,14 @@ | |||||||
| import { redirect } from '@sveltejs/kit'; | import { redirect } from '@sveltejs/kit'; | ||||||
| import type { PageServerLoad } from './$types'; | import type { PageServerLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
| 
 | 
 | ||||||
| export const load: PageServerLoad = async ({ parent }) => { | export const load: PageServerLoad = async ({ parent }) => { | ||||||
| 	const { user } = await parent(); | 	const { user } = await parent(); | ||||||
| 
 | 
 | ||||||
| 	if (!user) { | 	if (!user) { | ||||||
| 		throw redirect(302, '/auth/login'); | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
| 	} else if (!user.isAdmin) { | 	} else if (!user.isAdmin) { | ||||||
| 		throw redirect(302, '/photos'); | 		throw redirect(302, AppRoute.PHOTOS); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	return { | 	return { | ||||||
|  | |||||||
| @ -1,13 +1,14 @@ | |||||||
| import { redirect } from '@sveltejs/kit'; | import { redirect } from '@sveltejs/kit'; | ||||||
| import type { PageServerLoad } from './$types'; | import type { PageServerLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
| 
 | 
 | ||||||
| export const load = (async ({ parent, locals: { api } }) => { | export const load = (async ({ parent, locals: { api } }) => { | ||||||
| 	const { user } = await parent(); | 	const { user } = await parent(); | ||||||
| 
 | 
 | ||||||
| 	if (!user) { | 	if (!user) { | ||||||
| 		throw redirect(302, '/auth/login'); | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
| 	} else if (!user.isAdmin) { | 	} else if (!user.isAdmin) { | ||||||
| 		throw redirect(302, '/photos'); | 		throw redirect(302, AppRoute.PHOTOS); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	const { data: allUsers } = await api.userApi.getAllUsers({ isAll: false }); | 	const { data: allUsers } = await api.userApi.getAllUsers({ isAll: false }); | ||||||
|  | |||||||
| @ -1,11 +1,12 @@ | |||||||
| import { redirect } from '@sveltejs/kit'; | import { redirect } from '@sveltejs/kit'; | ||||||
| import type { PageServerLoad } from './$types'; | import type { PageServerLoad } from './$types'; | ||||||
|  | import { AppRoute } from '$lib/constants'; | ||||||
| 
 | 
 | ||||||
| export const load = (async ({ locals: { api } }) => { | export const load = (async ({ locals: { api } }) => { | ||||||
| 	const { data } = await api.userApi.getUserCount({ admin: true }); | 	const { data } = await api.userApi.getUserCount({ admin: true }); | ||||||
| 	if (data.userCount != 0) { | 	if (data.userCount != 0) { | ||||||
| 		// Admin has been registered, redirect to login
 | 		// Admin has been registered, redirect to login
 | ||||||
| 		throw redirect(302, '/auth/login'); | 		throw redirect(302, AppRoute.AUTH_LOGIN); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	return { | 	return { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user