Newer
Older
<div class="balloon" :data-no-text="message.text == null">
<mk-note-html class="text" v-if="message.text" ref="text" :text="message.text" :i="os.i"/>
<div class="file" v-if="message.file">
<a :href="message.file.url" target="_blank" :title="message.file.name">
<img v-if="message.file.type.split('/')[0] == 'image'" :src="message.file.url" :alt="message.file.name"/>
<p v-else>{{ message.file.name }}</p>
</a>
</footer>
</div>
</div>
</template>
<script lang="ts">
import Vue from 'vue';
import parse from '../../../../../text/parse';
},
urls(): string[] {
if (this.message.text) {
const ast = parse(this.message.text);
return ast
.filter(t => (t.type == 'url' || t.type == 'link') && !t.silent)
.map(t => t.url);
} else {
return null;
}
@import '~const.styl'
root(isDark)
$me-balloon-color = $theme-color
width 54px
height 54px
border-radius 8px
transition all 0.1s ease
min-height 38px
border-radius 16px
&:before
content ""
pointer-events none
display block
position absolute
top 12px
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
&:hover
> .delete-button
display block
> .delete-button
display none
position absolute
z-index 1
top -4px
right -4px
margin 0
padding 0
cursor pointer
outline none
border none
border-radius 0
box-shadow none
background transparent
> img
vertical-align bottom
width 16px
height 16px
cursor pointer
> .read
user-select none
display block
position absolute
z-index 1
bottom -4px
left -12px
margin 0
font-size 11px
> .content
> .is-deleted
display block
margin 0
padding 0
overflow hidden
overflow-wrap break-word
font-size 1em
display block
margin 0
padding 8px 16px
overflow hidden
overflow-wrap break-word
font-size 1em
> a
display block
max-width 100%
max-height 512px
border-radius 16px
overflow hidden
text-decoration none
&:hover
text-decoration none
> p
background #ccc
> *
margin 0
width 100%
height 100%
> p
padding 30px
text-align center
color #555
background #ddd
> .mk-url-preview
margin 8px 0
&[data-no-text]
background transparent
&:not([data-no-text]):before
border-bottom solid 8px transparent
border-left solid 8px transparent
&[data-no-text]
background transparent
&:not([data-no-text]):before
right -14px
left auto
border-top solid 8px transparent
border-right solid 8px transparent
border-bottom solid 8px transparent
border-left solid 8px $me-balloon-color
> .content
> p.is-deleted
.message[data-darkmode]
root(true)
.message:not([data-darkmode])
root(false)