|
41 | 41 | import { fly, slide } from 'svelte/transition'; |
42 | 42 |
|
43 | 43 | import { eventManager } from '$lib/managers/event-manager.svelte'; |
| 44 | + import { viewTransitionManager } from '$lib/managers/ViewTransitionManager.svelte'; |
44 | 45 | import Thumbnail from '../assets/thumbnail/thumbnail.svelte'; |
45 | 46 | import ActivityStatus from './activity-status.svelte'; |
46 | 47 | import ActivityViewer from './activity-viewer.svelte'; |
|
164 | 165 | console.log('on create - assetviwer'); |
165 | 166 |
|
166 | 167 | let transitionName = $state<string | null>('good'); |
| 168 | +
|
167 | 169 | $inspect(transitionName).with((a, b) => console.log('trans', a, b)); |
168 | 170 | $inspect(asset).with(console.log); |
| 171 | + let addInfoTransition; |
| 172 | + let finished; |
169 | 173 | onMount(async () => { |
| 174 | + debugger; |
| 175 | + addInfoTransition = () => { |
| 176 | + console.log('adding info'); |
| 177 | + detailPanelTransitionName = 'info'; |
| 178 | + }; |
| 179 | + eventManager.on('TransitionToAssetViewer', addInfoTransition); |
| 180 | + eventManager.on('TransitionToTimeline', addInfoTransition); |
| 181 | + finished = () => { |
| 182 | + console.log('removing info'); |
| 183 | + detailPanelTransitionName = null; |
| 184 | + transitionName = null; |
| 185 | + console.log('clearning tasnition name in asset viwer'); |
| 186 | + }; |
| 187 | + eventManager.on('Finished', finished); |
| 188 | +
|
170 | 189 | console.log('on mount - assetviwer'); |
171 | 190 | eventManager.emit('AssetViewerLoaded'); |
172 | 191 | eventManager.on('Finished', () => { |
173 | 192 | debugger; |
174 | | - transitionName = null; |
175 | | - console.log('clearning tasnition name in asset viwer'); |
176 | 193 | }); |
177 | 194 | unsubscribes.push( |
178 | 195 | websocketEvents.on('on_upload_success', (asset) => onAssetUpdate({ event: 'upload', asset })), |
|
215 | 232 | } |
216 | 233 |
|
217 | 234 | activityManager.reset(); |
| 235 | + console.log('offing'); |
| 236 | + eventManager.off('TransitionToAssetViewer', addInfoTransition!); |
| 237 | + eventManager.off('TransitionToTimeline', addInfoTransition!); |
| 238 | + eventManager.off('Finished', finished!); |
218 | 239 | }); |
219 | 240 |
|
220 | 241 | const handleGetAllAlbums = async () => { |
|
260 | 281 | return; |
261 | 282 | } |
262 | 283 | } |
263 | | - transitionName = order; |
264 | 284 |
|
265 | | - const navigatingPromise = new Promise((resolve) => { |
266 | | - eventManager.once('loaded', () => { |
267 | | - resolve(); |
268 | | - }); |
269 | | -
|
270 | | - console.log('BEFORE VIEW TRANS'); |
271 | | - debugger; |
272 | | - const transition = document.startViewTransition(async () => { |
273 | | - console.log('IN VIEW TRANS'); |
274 | | - console.log('emit', 'StartViewTransition'); |
275 | | - eventManager.emit('StartViewTransition'); |
276 | | - console.log('starting'); |
277 | | - debugger; |
278 | | -
|
279 | | - await navigatingPromise; |
280 | | - debugger; |
281 | | - console.log('AFTER VIEW TRANS!'); |
282 | | - }); |
283 | | - transition.updateCallbackDone.then(() => { |
284 | | - console.log('DONE VIEW TRANS!'); |
285 | | - eventManager.emit('EndViewTransition'); |
286 | | - }); |
287 | | - }); |
| 285 | + transitionName = order; |
| 286 | + detailPanelTransitionName = 'onTop'; |
| 287 | +
|
| 288 | + viewTransitionManager.startTransition( |
| 289 | + new Promise<void>((resolve) => { |
| 290 | + eventManager.once('RenderLoaded', () => { |
| 291 | + resolve(); |
| 292 | + }); |
| 293 | + }), |
| 294 | + ); |
| 295 | + // const navigatingPromise = new Promise((resolve) => { |
| 296 | + // eventManager.once('loaded', () => { |
| 297 | + // resolve(); |
| 298 | + // }); |
| 299 | +
|
| 300 | + // console.log('BEFORE VIEW TRANS'); |
| 301 | + // debugger; |
| 302 | + // const transition = document.startViewTransition(async () => { |
| 303 | + // console.log('IN VIEW TRANS'); |
| 304 | + // console.log('emit', 'StartViewTransition'); |
| 305 | + // eventManager.emit('StartViewTransition'); |
| 306 | + // console.log('starting'); |
| 307 | + // debugger; |
| 308 | +
|
| 309 | + // await navigatingPromise; |
| 310 | + // debugger; |
| 311 | + // console.log('AFTER VIEW TRANS!'); |
| 312 | + // }); |
| 313 | + // transition.updateCallbackDone.then(() => { |
| 314 | + // console.log('DONE VIEW TRANS!'); |
| 315 | + // eventManager.emit('EndViewTransition'); |
| 316 | + // }); |
| 317 | + // }); |
288 | 318 |
|
289 | 319 | e?.stopPropagation(); |
290 | 320 |
|
|
311 | 341 | } |
312 | 342 | } |
313 | 343 | }; |
| 344 | + onDestroy(() => { |
| 345 | + console.log('destryo'); |
| 346 | + }); |
314 | 347 |
|
315 | 348 | // const showEditorHandler = () => { |
316 | 349 | // if (isShowActivity) { |
|
447 | 480 | } |
448 | 481 | }); |
449 | 482 | let viewerHeight = $state<number>(0); |
| 483 | + let detailPanelTransitionName = $state<string | null>(null); |
450 | 484 | </script> |
451 | 485 |
|
452 | 486 | <OnEvents onAssetReplace={handleAssetReplace} /> |
|
626 | 660 | <div |
627 | 661 | transition:slide={{ axis: 'x', duration: 150 }} |
628 | 662 | id="detail-panel" |
629 | | - style:view-transition-name="info" |
| 663 | + style:view-transition-name={detailPanelTransitionName} |
630 | 664 | class="row-start-1 row-span-4 w-[360px] overflow-y-auto transition-all dark:border-l dark:border-s-immich-dark-gray bg-light" |
631 | 665 | translate="yes" |
632 | 666 | > |
|
0 commit comments