2023-05-16 16:13:20 +02:00
|
|
|
<script lang="ts">
|
2025-05-09 18:59:29 +02:00
|
|
|
import { getAssetControlContext } from '$lib/components/photos-page/asset-select-control-bar.svelte';
|
|
|
|
|
import { modalManager } from '$lib/managers/modal-manager.svelte';
|
|
|
|
|
import QrCodeModal from '$lib/modals/QrCodeModal.svelte';
|
|
|
|
|
import SharedLinkCreateModal from '$lib/modals/SharedLinkCreateModal.svelte';
|
|
|
|
|
import { makeSharedLinkUrl } from '$lib/utils';
|
2023-10-25 09:48:25 -04:00
|
|
|
import { mdiShareVariantOutline } from '@mdi/js';
|
2024-06-04 21:53:00 +02:00
|
|
|
import { t } from 'svelte-i18n';
|
2025-06-02 09:47:23 -05:00
|
|
|
import { IconButton } from '@immich/ui';
|
2023-05-16 16:13:20 +02:00
|
|
|
|
2023-08-03 10:11:02 -04:00
|
|
|
const { getAssets } = getAssetControlContext();
|
2023-05-16 16:13:20 +02:00
|
|
|
|
2025-05-09 18:59:29 +02:00
|
|
|
const handleClick = async () => {
|
|
|
|
|
const sharedLink = await modalManager.show(SharedLinkCreateModal, {
|
|
|
|
|
assetIds: [...getAssets()].map(({ id }) => id),
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
if (sharedLink) {
|
2025-05-09 22:23:00 +02:00
|
|
|
await modalManager.show(QrCodeModal, { title: $t('view_link'), value: makeSharedLinkUrl(sharedLink.key) });
|
2025-05-09 18:59:29 +02:00
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
</script>
|
2023-05-16 16:13:20 +02:00
|
|
|
|
2025-06-02 09:47:23 -05:00
|
|
|
<IconButton
|
|
|
|
|
shape="round"
|
|
|
|
|
color="secondary"
|
|
|
|
|
variant="ghost"
|
|
|
|
|
aria-label={$t('share')}
|
|
|
|
|
icon={mdiShareVariantOutline}
|
|
|
|
|
onclick={handleClick}
|
|
|
|
|
/>
|