mirror of
https://github.com/immich-app/immich
synced 2025-11-07 17:27:20 +00:00
* refactor microservices to machine-learning * Update tGithub issue template with correct task syntax * Added microservices container * Communicate between service based on queue system * added dependency * Fixed problem with having to import BullQueue into the individual service * Added todo * refactor server into monorepo with microservices * refactor database and entity to library * added simple migration * Move migrations and database config to library * Migration works in library * Cosmetic change in logging message * added user dto * Fixed issue with testing not able to find the shared library * Clean up library mapping path * Added webp generator to microservices * Update Github Action build latest * Fixed issue NPM cannot install due to conflict witl Bull Queue * format project with prettier * Modified docker-compose file * Add GH Action for Staging build: * Fixed GH action job name * Modified GH Action to only build & push latest when pushing to main * Added Test 2e2 Github Action * Added Test 2e2 Github Action * Implemented microservice to extract exif * Added cronjob to scan and generate webp thumbnail at midnight * Refactor to ireduce hit time to database when running microservices * Added error handling to asset services that handle read file from disk * Added video transcoding queue to process one video at a time * Fixed loading spinner on web while loading covering the info panel * Add mechanism to show new release announcement to web and mobile app (#209) * Added changelog page * Fixed issues based on PR comments * Fixed issue with video transcoding run on the server * Change entry point content for backward combatibility when starting up server * Added announcement box * Added error handling to failed silently when the app version checking is not able to make the request to GITHUB * Added new version announcement overlay * Update message * Added messages * Added logic to check and show announcement * Add method to handle saving new version * Added button to dimiss the acknowledge message * Up version for deployment to the app store
75 lines
1.9 KiB
Svelte
75 lines
1.9 KiB
Svelte
<script lang="ts">
|
|
import { session } from '$app/stores';
|
|
import { serverEndpoint } from '$lib/constants';
|
|
import { fade } from 'svelte/transition';
|
|
|
|
import type { ImmichAsset, ImmichExif } from '$lib/models/immich-asset';
|
|
import { createEventDispatcher, onMount } from 'svelte';
|
|
import LoadingSpinner from '../shared/loading-spinner.svelte';
|
|
|
|
export let assetId: string;
|
|
|
|
let asset: ImmichAsset;
|
|
|
|
const dispatch = createEventDispatcher();
|
|
|
|
let videoPlayerNode: HTMLVideoElement;
|
|
let isVideoLoading = true;
|
|
|
|
onMount(async () => {
|
|
if ($session.user) {
|
|
const res = await fetch(serverEndpoint + '/asset/assetById/' + assetId, {
|
|
headers: {
|
|
Authorization: 'bearer ' + $session.user.accessToken,
|
|
},
|
|
});
|
|
asset = await res.json();
|
|
|
|
await loadVideoData();
|
|
}
|
|
});
|
|
|
|
const loadVideoData = async () => {
|
|
isVideoLoading = true;
|
|
const videoUrl = `/asset/file?aid=${asset.deviceAssetId}&did=${asset.deviceId}&isWeb=true`;
|
|
if ($session.user) {
|
|
try {
|
|
const res = await fetch(serverEndpoint + videoUrl, {
|
|
method: 'GET',
|
|
headers: {
|
|
Authorization: 'bearer ' + $session.user.accessToken,
|
|
},
|
|
});
|
|
|
|
const videoData = URL.createObjectURL(await res.blob());
|
|
videoPlayerNode.src = videoData;
|
|
|
|
videoPlayerNode.load();
|
|
|
|
videoPlayerNode.oncanplay = () => {
|
|
videoPlayerNode.muted = true;
|
|
videoPlayerNode.play();
|
|
videoPlayerNode.muted = false;
|
|
|
|
isVideoLoading = false;
|
|
};
|
|
|
|
return videoData;
|
|
} catch (e) {}
|
|
}
|
|
};
|
|
</script>
|
|
|
|
<div transition:fade={{ duration: 150 }} class="flex place-items-center place-content-center h-full select-none">
|
|
{#if asset}
|
|
<video controls class="h-full object-contain" bind:this={videoPlayerNode}>
|
|
<track kind="captions" />
|
|
</video>
|
|
|
|
{#if isVideoLoading}
|
|
<div class="absolute flex place-items-center place-content-center">
|
|
<LoadingSpinner />
|
|
</div>
|
|
{/if}
|
|
{/if}
|
|
</div>
|