2016-10-29 03:08:03 +11:00
|
|
|
<template>
|
2021-06-17 23:29:46 +10:00
|
|
|
<button
|
2020-06-29 21:48:22 +10:00
|
|
|
v-if="usePlaceholder"
|
2021-06-17 23:29:46 +10:00
|
|
|
class="Attachment -placeholder button-unstyled"
|
|
|
|
:class="classNames"
|
2019-07-05 17:17:44 +10:00
|
|
|
@click="openModal"
|
|
|
|
>
|
|
|
|
<a
|
2019-01-27 02:45:03 +11:00
|
|
|
v-if="type !== 'html'"
|
2019-07-05 17:17:44 +10:00
|
|
|
class="placeholder"
|
|
|
|
target="_blank"
|
|
|
|
:href="attachment.url"
|
2020-06-29 21:48:22 +10:00
|
|
|
:alt="attachment.description"
|
|
|
|
:title="attachment.description"
|
2021-06-18 09:04:01 +10:00
|
|
|
@click.prevent=""
|
2019-01-27 02:45:03 +11:00
|
|
|
>
|
2020-10-21 08:01:28 +11:00
|
|
|
<FAIcon :icon="placeholderIconClass" />
|
2021-06-18 23:11:16 +10:00
|
|
|
<b>{{ nsfw ? "NSFW / " : "" }}</b>{{ this.edit ? '' : placeholderName }}
|
2019-01-27 02:45:03 +11:00
|
|
|
</a>
|
2021-06-18 23:11:16 +10:00
|
|
|
<div
|
|
|
|
class="attachment-buttons"
|
|
|
|
v-if="edit || remove"
|
|
|
|
>
|
|
|
|
<button
|
|
|
|
v-if="remove"
|
|
|
|
class="button-unstyled attachment-button"
|
|
|
|
@click.prevent="onRemove"
|
|
|
|
>
|
|
|
|
<FAIcon icon="trash-alt" />
|
|
|
|
</button>
|
|
|
|
</div>
|
|
|
|
<div
|
|
|
|
v-if="size !== 'hide' && !hideDescription && (edit || localDescription)"
|
|
|
|
class="description-container"
|
|
|
|
:class="{ '-static': !edit }"
|
|
|
|
>
|
|
|
|
<input
|
|
|
|
v-if="edit"
|
|
|
|
v-model="localDescription"
|
|
|
|
type="text"
|
|
|
|
class="description-field"
|
|
|
|
:placeholder="$t('post_status.media_description')"
|
|
|
|
@keydown.enter.prevent=""
|
|
|
|
>
|
|
|
|
<p v-else>
|
|
|
|
{{ localDescription }}
|
|
|
|
</p>
|
|
|
|
</div>
|
2021-06-17 23:29:46 +10:00
|
|
|
</button>
|
2019-01-15 04:23:13 +11:00
|
|
|
<div
|
2021-06-17 23:29:46 +10:00
|
|
|
class="Attachment"
|
|
|
|
:class="classNames"
|
2021-06-18 09:04:01 +10:00
|
|
|
v-else
|
2019-01-15 04:23:13 +11:00
|
|
|
>
|
2021-06-17 23:29:46 +10:00
|
|
|
<div
|
2021-06-18 09:04:01 +10:00
|
|
|
class="attachment-wrapper"
|
|
|
|
v-show="!isEmpty"
|
2019-01-15 04:23:13 +11:00
|
|
|
>
|
2021-06-18 09:04:01 +10:00
|
|
|
<a
|
|
|
|
v-if="hidden"
|
|
|
|
class="image-container"
|
|
|
|
:href="attachment.url"
|
2019-02-18 16:03:26 +11:00
|
|
|
:alt="attachment.description"
|
2021-06-18 09:04:01 +10:00
|
|
|
:title="attachment.description"
|
|
|
|
@click.prevent.stop="toggleHidden"
|
|
|
|
>
|
|
|
|
<img
|
|
|
|
:key="nsfwImage"
|
|
|
|
class="nsfw"
|
|
|
|
:src="nsfwImage"
|
|
|
|
>
|
|
|
|
<FAIcon
|
|
|
|
v-if="type === 'video'"
|
|
|
|
class="play-icon"
|
|
|
|
icon="play-circle"
|
|
|
|
/>
|
|
|
|
</a>
|
|
|
|
<div
|
|
|
|
class="attachment-buttons"
|
|
|
|
v-if="!hidden"
|
|
|
|
>
|
|
|
|
<button
|
|
|
|
v-if="type === 'flash' && flashLoaded"
|
|
|
|
class="button-unstyled attachment-button"
|
|
|
|
@click.prevent="stopFlash"
|
|
|
|
>
|
|
|
|
<FAIcon icon="stop" />
|
|
|
|
</button>
|
|
|
|
<button
|
|
|
|
v-if="!useModal"
|
|
|
|
class="button-unstyled attachment-button"
|
|
|
|
@click.prevent="openModalForce"
|
|
|
|
>
|
|
|
|
<FAIcon icon="search-plus" />
|
|
|
|
</button>
|
|
|
|
<button
|
|
|
|
v-if="nsfw && hideNsfwLocal"
|
|
|
|
class="button-unstyled attachment-button"
|
|
|
|
@click.prevent="toggleHidden"
|
|
|
|
>
|
|
|
|
<FAIcon icon="times" />
|
|
|
|
</button>
|
|
|
|
<button
|
|
|
|
v-if="remove"
|
|
|
|
class="button-unstyled attachment-button"
|
|
|
|
@click.prevent="onRemove"
|
|
|
|
>
|
|
|
|
<FAIcon icon="trash-alt" />
|
|
|
|
</button>
|
|
|
|
</div>
|
2016-10-29 03:08:03 +11:00
|
|
|
|
2021-06-18 09:04:01 +10:00
|
|
|
<a
|
|
|
|
v-if="type === 'image' && (!hidden || preloadImage)"
|
|
|
|
class="image-container"
|
|
|
|
:class="{'-hidden': hidden && preloadImage }"
|
|
|
|
:href="attachment.url"
|
|
|
|
target="_blank"
|
|
|
|
@click.stop.prevent="openModal"
|
|
|
|
>
|
|
|
|
<StillImage
|
|
|
|
class="image"
|
|
|
|
:referrerpolicy="referrerpolicy"
|
|
|
|
:mimetype="attachment.mimetype"
|
|
|
|
:src="attachment.large_thumb_url || attachment.url"
|
|
|
|
:image-load-handler="onImageLoad"
|
|
|
|
:alt="attachment.description"
|
|
|
|
/>
|
|
|
|
</a>
|
2016-10-29 03:08:03 +11:00
|
|
|
|
2021-06-18 09:04:01 +10:00
|
|
|
<a
|
|
|
|
v-if="type === 'video' && !hidden"
|
|
|
|
class="video-container"
|
|
|
|
:href="attachment.url"
|
|
|
|
@click.stop.prevent="openModal"
|
|
|
|
>
|
|
|
|
<VideoAttachment
|
|
|
|
class="video"
|
|
|
|
:attachment="attachment"
|
|
|
|
:controls="!useModal"
|
|
|
|
@play="$emit('play')"
|
|
|
|
@pause="$emit('pause')"
|
|
|
|
/>
|
|
|
|
<FAIcon
|
|
|
|
v-if="useModal"
|
|
|
|
class="play-icon"
|
|
|
|
icon="play-circle"
|
|
|
|
/>
|
|
|
|
</a>
|
|
|
|
|
|
|
|
<a
|
|
|
|
v-if="type === 'audio' && !hidden"
|
|
|
|
class="audio-container"
|
|
|
|
:href="attachment.url"
|
|
|
|
@click.stop.prevent="openModal"
|
|
|
|
>
|
|
|
|
<audio
|
|
|
|
v-if="type === 'audio'"
|
|
|
|
:src="attachment.url"
|
|
|
|
:alt="attachment.description"
|
|
|
|
:title="attachment.description"
|
|
|
|
controls
|
|
|
|
@play="$emit('play')"
|
|
|
|
@pause="$emit('pause')"
|
|
|
|
/>
|
|
|
|
</a>
|
2016-11-23 05:45:18 +11:00
|
|
|
|
2019-07-05 17:17:44 +10:00
|
|
|
<div
|
2021-06-18 09:04:01 +10:00
|
|
|
v-if="type === 'html' && attachment.oembed"
|
|
|
|
class="oembed-container"
|
|
|
|
@click.prevent="linkClicked"
|
2019-07-05 17:17:44 +10:00
|
|
|
>
|
2021-06-18 09:04:01 +10:00
|
|
|
<div
|
|
|
|
v-if="attachment.thumb_url"
|
|
|
|
class="image"
|
|
|
|
>
|
|
|
|
<img :src="attachment.thumb_url">
|
|
|
|
</div>
|
|
|
|
<div class="text">
|
|
|
|
<!-- eslint-disable vue/no-v-html -->
|
|
|
|
<h1><a :href="attachment.url">{{ attachment.oembed.title }}</a></h1>
|
|
|
|
<div v-html="attachment.oembed.oembedHTML" />
|
|
|
|
<!-- eslint-enable vue/no-v-html -->
|
|
|
|
</div>
|
2016-10-29 10:38:41 +11:00
|
|
|
</div>
|
2021-04-10 02:09:22 +10:00
|
|
|
|
2021-06-18 09:04:01 +10:00
|
|
|
<a
|
|
|
|
v-if="type === 'flash' && !hidden"
|
|
|
|
class="flash-container"
|
|
|
|
:href="attachment.url"
|
|
|
|
@click.stop.prevent="openModal"
|
|
|
|
>
|
|
|
|
<Flash
|
|
|
|
class="flash"
|
|
|
|
ref="flash"
|
|
|
|
:src="attachment.large_thumb_url || attachment.url"
|
|
|
|
@playerOpened="setFlashLoaded(true)"
|
|
|
|
@playerClosed="setFlashLoaded(false)"
|
|
|
|
/>
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
<div
|
|
|
|
v-if="size !== 'hide' && !hideDescription && (edit || localDescription)"
|
|
|
|
class="description-container"
|
|
|
|
:class="{ '-static': !edit }"
|
2021-06-17 23:29:46 +10:00
|
|
|
>
|
2021-06-18 09:04:01 +10:00
|
|
|
<input
|
|
|
|
v-if="edit"
|
|
|
|
v-model="localDescription"
|
|
|
|
type="text"
|
|
|
|
class="description-field"
|
|
|
|
:placeholder="$t('post_status.media_description')"
|
|
|
|
@keydown.enter.prevent=""
|
|
|
|
>
|
|
|
|
<p v-else>
|
|
|
|
{{ localDescription }}
|
|
|
|
</p>
|
|
|
|
</div>
|
2016-10-29 03:08:03 +11:00
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script src="./attachment.js"></script>
|
2016-10-29 10:38:41 +11:00
|
|
|
|
2021-06-17 23:29:46 +10:00
|
|
|
<style src="./attachment.scss" lang="scss"></style>
|