qrcode loading data
This commit is contained in:
@@ -85,7 +85,7 @@
|
|||||||
chips
|
chips
|
||||||
hide-details>
|
hide-details>
|
||||||
<template v-slot:append>
|
<template v-slot:append>
|
||||||
<v-icon style="cursor: hand;" @click="setAllInbounds" icon="mdi-set-all" v-tooltip:top="$t('all')" />
|
<v-icon @click="setAllInbounds" icon="mdi-set-all" v-tooltip:top="$t('all')" />
|
||||||
</template>
|
</template>
|
||||||
</v-select>
|
</v-select>
|
||||||
</v-col>
|
</v-col>
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
<template>
|
<template>
|
||||||
<v-dialog transition="dialog-bottom-transition" width="400">
|
<v-dialog transition="dialog-bottom-transition" width="400">
|
||||||
<v-card class="rounded-lg" id="qrcode-modal">
|
<v-card class="rounded-lg" id="qrcode-modal" :loading="loading">
|
||||||
<v-card-title>
|
<v-card-title>
|
||||||
<v-row>
|
<v-row>
|
||||||
<v-col>QrCode</v-col>
|
<v-col>QrCode</v-col>
|
||||||
@@ -9,7 +9,13 @@
|
|||||||
</v-row>
|
</v-row>
|
||||||
</v-card-title>
|
</v-card-title>
|
||||||
<v-divider></v-divider>
|
<v-divider></v-divider>
|
||||||
<v-card-text style="overflow-y: auto; padding: 0">
|
<v-skeleton-loader
|
||||||
|
class="mx-auto border"
|
||||||
|
width="80%"
|
||||||
|
type="text, image, divider, text, image"
|
||||||
|
v-if="loading"
|
||||||
|
></v-skeleton-loader>
|
||||||
|
<v-card-text style="overflow-y: auto; padding: 0" :hidden="loading">
|
||||||
<v-tabs
|
<v-tabs
|
||||||
v-model="tab"
|
v-model="tab"
|
||||||
density="compact"
|
density="compact"
|
||||||
@@ -24,19 +30,19 @@
|
|||||||
<v-row>
|
<v-row>
|
||||||
<v-col style="text-align: center;">
|
<v-col style="text-align: center;">
|
||||||
<v-chip>{{ $t('setting.sub') }}</v-chip><br />
|
<v-chip>{{ $t('setting.sub') }}</v-chip><br />
|
||||||
<QrcodeVue :value="clientSub" :size="size" @click="copyToClipboard(clientSub)" :margin="1" style="border-radius: 1rem;" />
|
<QrcodeVue :value="clientSub" :size="size" @click="copyToClipboard(clientSub)" :margin="1" style="border-radius: 1rem; cursor: copy;" />
|
||||||
</v-col>
|
</v-col>
|
||||||
</v-row>
|
</v-row>
|
||||||
<v-row>
|
<v-row>
|
||||||
<v-col style="text-align: center;">
|
<v-col style="text-align: center;">
|
||||||
<v-chip>{{ $t('setting.jsonSub') }}</v-chip><br />
|
<v-chip>{{ $t('setting.jsonSub') }}</v-chip><br />
|
||||||
<QrcodeVue :value="clientSub + '?format=json'" :size="size" @click="copyToClipboard(clientSub + '?format=json')" :margin="1" style="border-radius: 1rem;" />
|
<QrcodeVue :value="clientSub + '?format=json'" :size="size" @click="copyToClipboard(clientSub + '?format=json')" :margin="1" style="border-radius: 1rem; cursor: copy;" />
|
||||||
</v-col>
|
</v-col>
|
||||||
</v-row>
|
</v-row>
|
||||||
<v-row>
|
<v-row>
|
||||||
<v-col style="text-align: center;">
|
<v-col style="text-align: center;">
|
||||||
<v-chip>SING-BOX</v-chip><br />
|
<v-chip>SING-BOX (scan only)</v-chip><br />
|
||||||
<QrcodeVue :value="singbox" :size="size" @click="copyToClipboard(singbox)" :margin="1" style="border-radius: .8rem;" />
|
<QrcodeVue :value="singbox" :size="size" :margin="1" style="border-radius: .8rem; cursor: not-allowed;" />
|
||||||
</v-col>
|
</v-col>
|
||||||
</v-row>
|
</v-row>
|
||||||
</v-window-item>
|
</v-window-item>
|
||||||
@@ -44,7 +50,7 @@
|
|||||||
<v-row v-for="l in clientLinks">
|
<v-row v-for="l in clientLinks">
|
||||||
<v-col style="text-align: center;">
|
<v-col style="text-align: center;">
|
||||||
<v-chip>{{ l.remark?? $t('client.' + l.type) }}</v-chip><br />
|
<v-chip>{{ l.remark?? $t('client.' + l.type) }}</v-chip><br />
|
||||||
<QrcodeVue :value="l.uri" :size="size" @click="copyToClipboard(l.uri)" :margin="1" style="border-radius: .5rem;" />
|
<QrcodeVue :value="l.uri" :size="size" @click="copyToClipboard(l.uri)" :margin="1" style="border-radius: .5rem; cursor: copy;" />
|
||||||
</v-col>
|
</v-col>
|
||||||
</v-row>
|
</v-row>
|
||||||
</v-window-item>
|
</v-window-item>
|
||||||
@@ -62,13 +68,21 @@ import { i18n } from '@/locales'
|
|||||||
import { push } from 'notivue'
|
import { push } from 'notivue'
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
props: ['index', 'visible'],
|
props: ['id', 'visible'],
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
tab: "sub",
|
tab: "sub",
|
||||||
|
client: <any>{},
|
||||||
|
loading: false,
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
async load() {
|
||||||
|
this.loading = true
|
||||||
|
const newData = await Data().loadClients(this.$props.id)
|
||||||
|
this.client = newData
|
||||||
|
this.loading = false
|
||||||
|
},
|
||||||
copyToClipboard(txt:string) {
|
copyToClipboard(txt:string) {
|
||||||
const hiddenButton = document.createElement('button')
|
const hiddenButton = document.createElement('button')
|
||||||
hiddenButton.className = 'clipboard-btn'
|
hiddenButton.className = 'clipboard-btn'
|
||||||
@@ -101,11 +115,6 @@ export default {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
clients() { return Data().clients },
|
|
||||||
client() {
|
|
||||||
if ( typeof this.$props.index != 'number' ) return <any>{}
|
|
||||||
return this.clients[this.$props.index]
|
|
||||||
},
|
|
||||||
clientSub() {
|
clientSub() {
|
||||||
return Data().subURI + this.client.name
|
return Data().subURI + this.client.name
|
||||||
},
|
},
|
||||||
@@ -126,6 +135,7 @@ export default {
|
|||||||
visible(v) {
|
visible(v) {
|
||||||
if (v) {
|
if (v) {
|
||||||
this.tab = "sub"
|
this.tab = "sub"
|
||||||
|
this.load()
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -20,7 +20,7 @@
|
|||||||
<QrCode
|
<QrCode
|
||||||
v-model="qrcode.visible"
|
v-model="qrcode.visible"
|
||||||
:visible="qrcode.visible"
|
:visible="qrcode.visible"
|
||||||
:index="qrcode.index"
|
:id="qrcode.id"
|
||||||
@close="closeQrCode"
|
@close="closeQrCode"
|
||||||
/>
|
/>
|
||||||
<Stats
|
<Stats
|
||||||
@@ -319,12 +319,11 @@ const delClient = async (id: number) => {
|
|||||||
|
|
||||||
const qrcode = ref({
|
const qrcode = ref({
|
||||||
visible: false,
|
visible: false,
|
||||||
index: 0,
|
id: 0,
|
||||||
})
|
})
|
||||||
|
|
||||||
const showQrCode = (id: number) => {
|
const showQrCode = (id: number) => {
|
||||||
const clientIndex = clients.value.findIndex(c => c.id === id)
|
qrcode.value.id = id
|
||||||
qrcode.value.index = clientIndex
|
|
||||||
qrcode.value.visible = true
|
qrcode.value.visible = true
|
||||||
}
|
}
|
||||||
const closeQrCode = () => {
|
const closeQrCode = () => {
|
||||||
|
|||||||
Reference in New Issue
Block a user