|
162 | 162 | } |
163 | 163 | }; |
164 | 164 |
|
165 | | - console.log('on create - assetviwer'); |
| 165 | + let transitionName = $state<string | null>('hero'); |
166 | 166 |
|
167 | | - let transitionName = $state<string | null>('good'); |
168 | | -
|
169 | | - $inspect(transitionName).with((a, b) => console.log('trans', a, b)); |
170 | | - $inspect(asset).with(console.log); |
171 | 167 | let addInfoTransition; |
172 | 168 | let finished; |
173 | 169 | onMount(async () => { |
174 | | - debugger; |
175 | 170 | addInfoTransition = () => { |
176 | | - console.log('adding info'); |
177 | 171 | detailPanelTransitionName = 'info'; |
178 | 172 | }; |
179 | 173 | eventManager.on('TransitionToAssetViewer', addInfoTransition); |
180 | 174 | eventManager.on('TransitionToTimeline', addInfoTransition); |
181 | 175 | finished = () => { |
182 | | - console.log('removing info'); |
183 | 176 | detailPanelTransitionName = null; |
184 | 177 | transitionName = null; |
185 | | - console.log('clearning tasnition name in asset viwer'); |
186 | 178 | }; |
187 | 179 | eventManager.on('Finished', finished); |
188 | | -
|
189 | | - console.log('on mount - assetviwer'); |
190 | 180 | eventManager.emit('AssetViewerLoaded'); |
191 | | - eventManager.on('Finished', () => { |
192 | | - debugger; |
193 | | - }); |
194 | 181 | unsubscribes.push( |
195 | 182 | websocketEvents.on('on_upload_success', (asset) => onAssetUpdate({ event: 'upload', asset })), |
196 | 183 | websocketEvents.on('on_asset_update', (asset) => onAssetUpdate({ event: 'update', asset })), |
|
232 | 219 | } |
233 | 220 |
|
234 | 221 | activityManager.reset(); |
235 | | - console.log('offing'); |
236 | 222 | eventManager.off('TransitionToAssetViewer', addInfoTransition!); |
237 | 223 | eventManager.off('TransitionToTimeline', addInfoTransition!); |
238 | 224 | eventManager.off('Finished', finished!); |
|
263 | 249 | }; |
264 | 250 |
|
265 | 251 | const closeViewer = () => { |
266 | | - transitionName = 'good'; |
| 252 | + transitionName = 'hero'; |
267 | 253 | onClose(asset); |
268 | 254 | }; |
269 | 255 |
|
|
292 | 278 | }); |
293 | 279 | }), |
294 | 280 | ); |
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 | | - // }); |
318 | 281 |
|
319 | 282 | e?.stopPropagation(); |
320 | 283 |
|
|
341 | 304 | } |
342 | 305 | } |
343 | 306 | }; |
344 | | - onDestroy(() => { |
345 | | - console.log('destryo'); |
346 | | - }); |
347 | 307 |
|
348 | 308 | // const showEditorHandler = () => { |
349 | 309 | // if (isShowActivity) { |
|
481 | 441 | }); |
482 | 442 | let viewerHeight = $state<number>(0); |
483 | 443 | let detailPanelTransitionName = $state<string | null>(null); |
| 444 | + let loaded = $state(false); |
484 | 445 | </script> |
485 | 446 |
|
486 | 447 | <OnEvents onAssetReplace={handleAssetReplace} /> |
|
496 | 457 | > |
497 | 458 | <!-- Top navigation bar --> |
498 | 459 | {#if $slideshowState === SlideshowState.None && !isShowEditor} |
499 | | - <div class="col-span-4 col-start-1 row-span-1 row-start-1 transition-transform"> |
| 460 | + <div |
| 461 | + class="col-span-4 col-start-1 row-span-1 row-start-1 transition-transform" |
| 462 | + style:view-transition-name="exclude" |
| 463 | + > |
500 | 464 | <AssetViewerNavBar |
501 | 465 | {asset} |
502 | 466 | {album} |
|
550 | 514 | bind:clientHeight={viewerHeight} |
551 | 515 | class="z-[-1] relative col-start-1 col-span-4 row-start-1 row-span-full flex items-center" |
552 | 516 | > |
553 | | - <div data-transition-asset style:view-transition-name={transitionName} class="grow"> |
| 517 | + <div data-transition-asset style:view-transition-name={transitionName} class={['mx-auto max-h-dvh']}> |
554 | 518 | {#if previewStackedAsset} |
555 | 519 | {#key previewStackedAsset.id} |
556 | 520 | {#if previewStackedAsset.type === AssetTypeEnum.Image} |
557 | 521 | <PhotoViewer |
558 | 522 | bind:zoomToggle |
559 | 523 | bind:copyImage |
| 524 | + onPhotoLoaded={() => { |
| 525 | + loaded = true; |
| 526 | + }} |
560 | 527 | asset={previewStackedAsset} |
561 | 528 | {preloadAssets} |
562 | 529 | onPreviousAsset={() => navigateAsset('previous')} |
|
603 | 570 | <PhotoViewer |
604 | 571 | bind:zoomToggle |
605 | 572 | bind:copyImage |
| 573 | + onPhotoLoaded={() => { |
| 574 | + loaded = true; |
| 575 | + }} |
606 | 576 | {asset} |
607 | 577 | {preloadAssets} |
608 | 578 | onPreviousAsset={() => navigateAsset('previous')} |
|
0 commit comments