Rewrite Modals/NewToot/Quote with composition API

This commit is contained in:
AkiraFukushima 2022-04-30 01:50:09 +09:00
parent 29f3776c08
commit ebc09cdf55
No known key found for this signature in database
GPG Key ID: B6E51BAC4DE1A957
6 changed files with 86 additions and 70 deletions

View File

@ -4,15 +4,21 @@ describe('emojify', () => {
const emoji = [
{
shortcode: 'python',
url: 'https://example.com/python'
static_url: 'https://example.com/python',
url: 'https://example.com/python',
visible_in_picker: true
},
{
shortcode: 'nodejs',
url: 'https://example.com/nodejs'
static_url: 'https://example.com/nodejs',
url: 'https://example.com/nodejs',
visible_in_picker: true
},
{
shortcode: 'slack',
url: 'https://example.com/slack'
static_url: 'https://example.com/slack',
url: 'https://example.com/slack',
visible_in_picker: true
}
]
describe('Does not contain shortcode', () => {

View File

@ -20,12 +20,14 @@
</div>
</template>
<script>
<script lang="ts">
import { defineComponent, toRefs } from 'vue'
import DisplayStyle from '~/src/constants/displayStyle'
import FailoverImg from '@/components/atoms/FailoverImg'
import FailoverImg from '@/components/atoms/FailoverImg.vue'
import emojify from '@/utils/emojify'
import { Entity } from 'megalodon'
export default {
export default defineComponent({
new: 'quote-target',
components: {
FailoverImg
@ -40,9 +42,10 @@ export default {
default: 0
}
},
methods: {
username(account) {
switch (this.displayNameStyle) {
setup(props) {
const { displayNameStyle } = toRefs(props)
const username = (account: Entity.Account) => {
switch (displayNameStyle.value) {
case DisplayStyle.DisplayNameAndUsername.value:
if (account.display_name !== '') {
return emojify(account.display_name, account.emojis)
@ -55,24 +58,30 @@ export default {
} else {
return account.acct
}
case DisplayStyle.Username.value:
default:
return account.acct
}
},
accountName(account) {
switch (this.displayNameStyle) {
}
const accountName = (account: Entity.Account) => {
switch (displayNameStyle.value) {
case DisplayStyle.DisplayNameAndUsername.value:
return `@${account.acct}`
case DisplayStyle.DisplayName.value:
case DisplayStyle.Username.value:
default:
return ''
}
},
emojiText(content, emojis) {
}
const emojiText = (content: string, emojis: Array<Entity.Emoji>) => {
return emojify(content, emojis)
}
return {
username,
accountName,
emojiText
}
}
}
})
</script>
<style lang="scss" scoped>

View File

@ -45,7 +45,6 @@
set="twitter"
:autoFocus="true"
@select="selectEmoji"
:custom="pickerEmojis"
:perLine="7"
:emojiSize="24"
:showPreview="false"
@ -96,7 +95,7 @@ export default defineComponent({
setup(props, ctx) {
const space = 'TimelineSpace/Modals/NewToot/Status'
const store = useStore()
const emojiIndex = new EmojiIndex(data)
const { modelValue } = toRefs(props)
const highlightedIndex = ref(0)
const statusRef = ref<HTMLTextAreaElement>()
@ -110,7 +109,10 @@ export default defineComponent({
})
const startIndex = computed(() => store.state.TimelineSpace.Modals.NewToot.Status.startIndex)
const matchWord = computed(() => store.state.TimelineSpace.Modals.NewToot.Status.matchWord)
const pickerEmojis = computed(() => store.getters[`${space}/pickerEmojis`])
const customEmojis = computed(() => store.getters[`${space}/pickerEmojis`])
const emojiIndex = new EmojiIndex(data, {
custom: customEmojis.value
})
const closeSuggest = () => {
store.dispatch(`${space}/${ACTION_TYPES.CLOSE_SUGGEST}`)
@ -223,7 +225,6 @@ export default defineComponent({
filteredAccounts,
filteredHashtags,
filteredSuggestion,
pickerEmojis,
openSuggest,
startSuggest,
suggestHighlight,

View File

@ -10,69 +10,72 @@
/>
</template>
<script>
<script lang="ts">
import { defineComponent, ref, toRefs, onMounted, watch } from 'vue'
import exifImageUrl from '@/components/utils/exifImageUrl'
export default {
export default defineComponent({
name: 'FailoverImg',
props: {
src: {
type: String,
default: '',
default: ''
},
title: {
type: String,
default: '',
default: ''
},
alt: {
type: String,
default: '',
default: ''
},
readExif: {
type: Boolean,
default: false,
default: false
},
failoverSrc: {
type: String,
default:
'',
},
},
data() {
return {
loading: true,
originalSrc: this.src,
''
}
},
async mounted() {
if (this.readExif) {
try {
const transformed = await exifImageUrl(this.src)
this.originalSrc = transformed
} catch (err) {
console.warn(err)
}
}
},
watch: {
src: async function (newSrc, _oldSrc) {
this.originalSrc = newSrc
if (this.readExif) {
setup(props) {
const { src, readExif, failoverSrc } = toRefs(props)
const loading = ref<boolean>(false)
const originalSrc = ref<string>(src.value)
onMounted(async () => {
if (readExif.value) {
try {
const transformed = await exifImageUrl(newSrc)
this.originalSrc = transformed
const transformed = await exifImageUrl(src.value)
originalSrc.value = transformed
} catch (err) {
console.warn(err)
}
}
},
},
methods: {
failover() {
this.originalSrc = this.failoverSrc
},
},
}
})
watch(src, async (newSrc, _oldSrc) => {
originalSrc.value = newSrc
if (readExif.value) {
try {
const transformed = await exifImageUrl(newSrc)
originalSrc.value = transformed
} catch (err) {}
}
})
const failover = () => {
originalSrc.value = failoverSrc.value
}
return {
loading,
originalSrc,
failover
}
}
})
</script>
<style lang="scss" scoped>

View File

@ -1,15 +1,10 @@
import loadImage from 'blueimp-load-image'
const parseExtension = (url) => {
const parseExtension = (url: string) => {
if (!url) {
return null
}
if (
url.match(/\.jpg$/) ||
url.match(/\.jpeg$/) ||
url.match(/\.JPG$/) ||
url.match(/\.JPEG$/)
) {
if (url.match(/\.jpg$/) || url.match(/\.jpeg$/) || url.match(/\.JPG$/) || url.match(/\.JPEG$/)) {
return 'image/jpeg'
} else if (url.match(/\.png$/) || url.match(/\.PNG$/)) {
return 'image/png'
@ -23,7 +18,7 @@ const parseExtension = (url) => {
return null
}
const exifImageUrl = (url) => {
const exifImageUrl = (url: string): Promise<string> => {
return new Promise((resolve, reject) => {
const extension = parseExtension(url)
if (!extension) {
@ -31,7 +26,7 @@ const exifImageUrl = (url) => {
}
loadImage(
url,
(canvas) => {
canvas => {
if (canvas.type === 'error') {
return reject(Error(`can not load image: ${url}`))
}
@ -41,7 +36,7 @@ const exifImageUrl = (url) => {
{
canvas: true,
meta: true,
orientation: true,
orientation: true
}
)
})

View File

@ -1,6 +1,8 @@
const emojify = (str, customEmoji = []) => {
import { Entity } from 'megalodon'
const emojify = (str: string, customEmoji: Array<Entity.Emoji> = []): string => {
let result = str
customEmoji.map((emoji) => {
customEmoji.map(emoji => {
const reg = new RegExp(`:${emoji.shortcode}:`, 'g')
const match = result.match(reg)
if (!match) return emoji