2023-07-06 22:05:03 +08:00
|
|
|
<template>
|
|
|
|
<div>
|
|
|
|
<button class="ml-2 btn"
|
|
|
|
id="share-button"
|
|
|
|
type="button"
|
|
|
|
:class="shareClass"
|
|
|
|
:title="shareValue"
|
|
|
|
:disabled="disabled"
|
|
|
|
@click="openModal">
|
|
|
|
<span class="sn-icon sn-icon-shared"></span>
|
|
|
|
<span class="text-sm">
|
|
|
|
{{ shareValue }}
|
|
|
|
</span>
|
|
|
|
</button>
|
2023-09-12 20:11:34 +08:00
|
|
|
<div ref="modal">
|
|
|
|
<shareModalContainer :shared="share"
|
|
|
|
:open="visibleShareModal"
|
|
|
|
:shareableLinkUrl="shareableLinkUrl"
|
|
|
|
:characterLimit="255"
|
|
|
|
@enable="enableShare"
|
|
|
|
@disable="disableShare"
|
|
|
|
@close="closeModal"/>
|
|
|
|
</div>
|
2023-07-06 22:05:03 +08:00
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import shareModalContainer from './components/shareable_link_modal.vue'
|
|
|
|
export default {
|
|
|
|
name: "ShareLinkContainer",
|
|
|
|
components: { shareModalContainer },
|
|
|
|
props: {
|
|
|
|
shared: {
|
|
|
|
type: Boolean,
|
|
|
|
default: false
|
|
|
|
},
|
|
|
|
shareableLinkUrl: {
|
|
|
|
type: String,
|
|
|
|
required: true
|
|
|
|
},
|
|
|
|
disabled: {
|
|
|
|
type: Boolean,
|
2023-08-04 20:37:32 +08:00
|
|
|
default: false
|
2023-07-06 22:05:03 +08:00
|
|
|
}
|
|
|
|
},
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
share: false,
|
|
|
|
visibleShareModal: false
|
|
|
|
};
|
|
|
|
},
|
|
|
|
created() {
|
|
|
|
this.share = this.shared;
|
|
|
|
},
|
|
|
|
computed: {
|
|
|
|
shareClass() {
|
|
|
|
return this.share ? 'btn-shared' : 'btn-secondary';
|
|
|
|
},
|
|
|
|
shareValue() {
|
|
|
|
return this.i18n.t(this.share ? 'my_modules.shareable_links.shared' : 'my_modules.shareable_links.share');
|
|
|
|
}
|
|
|
|
},
|
2023-09-12 20:11:34 +08:00
|
|
|
mounted() {
|
|
|
|
// move modal to body to avoid z-index issues
|
|
|
|
$('body').append($(this.$refs.modal));
|
|
|
|
},
|
2023-07-06 22:05:03 +08:00
|
|
|
methods:{
|
|
|
|
enableShare() {
|
|
|
|
this.share = true;
|
|
|
|
},
|
|
|
|
disableShare() {
|
|
|
|
this.share = false;
|
|
|
|
},
|
|
|
|
openModal() {
|
|
|
|
this.visibleShareModal = true;
|
|
|
|
},
|
|
|
|
closeModal() {
|
|
|
|
this.visibleShareModal = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
</script>
|