Skip to content

Commit

Permalink
fixes: per comments; refactor into composition api (ts)
Browse files Browse the repository at this point in the history
  • Loading branch information
Ivanov N committed Dec 28, 2024
1 parent 3a04588 commit 026ca96
Show file tree
Hide file tree
Showing 2 changed files with 83 additions and 58 deletions.
139 changes: 82 additions & 57 deletions src/components/ShareURIDialog.vue
Original file line number Diff line number Diff line change
@@ -1,30 +1,30 @@
<template>
<v-dialog v-model="show" eager width="320" :class="className">
<v-dialog v-model="show" eager width="320" :class="classes.root">
<v-card>
<v-card-title :class="`${className}__dialog-title`" class="a-text-header">
{{ $t('home.share_uri', { crypto }) }}
<v-card-title :class="classes.dialogTitle" class="a-text-header">
{{ t('home.share_uri', { crypto }) }}
</v-card-title>
<v-divider class="a-divider" />
<v-card-text class="pa-0">
<v-list>
<v-list-item @click="copyAddress">
<v-list-item-title :class="`${className}__list-item-title`">
{{ $t('home.copy_address') }}
<v-list-item-title :class="classes.listItemTitle">
{{ t('home.copy_address') }}
</v-list-item-title>
</v-list-item>
<v-list-item v-if="isADM" @click="copyURI">
<v-list-item-title :class="`${className}__list-item-title`">
{{ $t('home.copy_uri') }}
<v-list-item-title :class="classes.listItemTitle">
{{ t('home.copy_uri') }}
</v-list-item-title>
</v-list-item>
<v-list-item @click="openQRCodeRenderer">
<v-list-item-title :class="`${className}__list-item-title`">
{{ $t('home.show_qr_code') }}
<v-list-item-title :class="classes.listItemTitle">
{{ t('home.show_qr_code') }}
</v-list-item-title>
</v-list-item>
<v-list-item v-if="!isErc" @click="openInExplorer">
<v-list-item-title :class="`${className}__list-item-title`">
{{ $t('home.explorer') }}
<v-list-item-title :class="classes.listItemTitle">
{{ t('home.explorer') }}
</v-list-item-title>
</v-list-item>
</v-list>
Expand All @@ -34,75 +34,100 @@
</v-dialog>
</template>

<script>
<script lang="ts">
import { ref, computed, defineComponent, PropType } from 'vue'
import { useStore } from 'vuex'
import { useI18n } from 'vue-i18n'
import { CryptoSymbol, isErc20 } from '@/lib/constants'
import QrcodeRendererDialog from '@/components/QrcodeRendererDialog.vue'
import copyToClipboard from 'copy-to-clipboard'
import { generateURI } from '@/lib/uri'
import { isErc20 } from '@/lib/constants'
import { getExplorerAddressUrl } from '@/config/utils'
export default {
components: { QrcodeRendererDialog },
const className = 'share-uri-dialog'
const classes = {
root: className,
dialogTitle: `${className}__dialog-title`,
listItemTitle: `${className}__list-item-title`
}
export default defineComponent({
components: {
QrcodeRendererDialog
},
props: {
modelValue: {
type: Boolean,
required: true
},
address: {
required: true,
type: String
type: String,
required: true
},
crypto: {
required: true,
type: String
type: String as PropType<CryptoSymbol>,
required: true
},
isADM: {
required: true,
type: Boolean
},
modelValue: {
required: true,
type: Boolean
}
},
emits: ['update:modelValue'],
data: () => ({
className: 'share-uri-dialog',
showQrcodeRendererDialog: false
}),
computed: {
show: {
setup(props, { emit }) {
const { t } = useI18n()
const store = useStore()
const showQrcodeRendererDialog = ref(false)
const show = computed({
get() {
return this.modelValue
return props.modelValue
},
set(value) {
this.$emit('update:modelValue', value)
emit('update:modelValue', value)
}
},
uri() {
return generateURI(this.crypto, this.address)
},
isErc() {
return isErc20(this.crypto)
})
const uri = computed(() => generateURI(props.crypto, props.address, ''))
const isErc = computed(() => isErc20(props.crypto))
const copyAddress = () => {
copyToClipboard(props.address)
store.dispatch('snackbar/show', { message: t('home.copied') })
show.value = false
}
},
methods: {
copyAddress() {
copyToClipboard(this.address)
this.$store.dispatch('snackbar/show', { message: this.$t('home.copied') })
this.show = false
},
copyURI() {
copyToClipboard(this.uri)
this.$store.dispatch('snackbar/show', { message: this.$t('home.copied') })
this.show = false
},
openQRCodeRenderer() {
this.showQrcodeRendererDialog = true
this.show = false
},
openInExplorer() {
const explorerLink = getExplorerAddressUrl(this.crypto, this.address)
const copyURI = () => {
copyToClipboard(uri.value)
store.dispatch('snackbar/show', { message: t('home.copied') })
show.value = false
}
const openQRCodeRenderer = () => {
showQrcodeRendererDialog.value = true
show.value = false
}
const openInExplorer = () => {
const explorerLink = getExplorerAddressUrl(props.crypto, props.address)
window.open(explorerLink, '_blank', 'resizable,scrollbars,status,noopener')
}
return {
classes,
t,
showQrcodeRendererDialog,
show,
uri,
isErc,
copyAddress,
copyURI,
openQRCodeRenderer,
openInExplorer
}
}
}
})
</script>

<style lang="scss">
Expand Down
2 changes: 1 addition & 1 deletion src/config/utils/getExplorerAddressUrl.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import config from '../index'
* @param {string} crypto like 'adm' or 'eth'
* @param {string} address Crypto address
*/
export function getExplorerAddressUrl(crypto: string, address: number): string {
export function getExplorerAddressUrl(crypto: string, address: string): string {
const explorerAddress = config[crypto.toLowerCase()].explorerAddress

if (!explorerAddress) {
Expand Down

0 comments on commit 026ca96

Please sign in to comment.