123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 |
- {{define "qrcodeModal"}}
- <a-modal id="qrcode-modal" v-model="qrModal.visible" :title="qrModal.title"
- :closable="true"
- :class="themeSwitcher.currentTheme"
- :footer="null"
- width="300px">
- <a-tag color="green" style="margin-bottom: 10px;display: block;text-align: center;">
- {{ i18n "pages.inbounds.clickOnQRcode" }}
- </a-tag>
- <template v-if="app.subSettings.enable && qrModal.subId">
- <a-divider>{{ i18n "pages.settings.subSettings"}}</a-divider>
- <canvas @click="copyToClipboard('qrCode-sub',genSubLink(qrModal.client.subId))"
- id="qrCode-sub"
- class="qr-bg">
- </canvas>
- <a-divider>{{ i18n "pages.settings.subSettings"}} Json</a-divider>
- <canvas @click="copyToClipboard('qrCode-subJson',genSubJsonLink(qrModal.client.subId))"
- id="qrCode-subJson"
- style="width: 100%; height: 100%; display: flex; border-radius: 1rem;">
- </canvas>
- </template>
- <a-divider>{{ i18n "pages.inbounds.client" }}</a-divider>
- <template v-for="(row, index) in qrModal.qrcodes">
- <a-tag color="green" style="margin: 10px 0; display: block; text-align: center;">[[ row.remark ]]</a-tag>
- <canvas @click="copyToClipboard('qrCode-'+index, row.link)"
- :id="'qrCode-'+index"
- class="qr-bg"></canvas>
- </template>
- </a-modal>
- <script>
- const qrModal = {
- title: '',
- dbInbound: new DBInbound(),
- client: null,
- qrcodes: [],
- clipboard: null,
- visible: false,
- subId: '',
- show: function (title = '', dbInbound, client) {
- this.title = title;
- this.dbInbound = dbInbound;
- this.inbound = dbInbound.toInbound();
- this.client = client;
- this.subId = '';
- this.qrcodes = [];
- if (this.inbound.protocol == Protocols.WIREGUARD){
- this.inbound.genInboundLinks(dbInbound.remark).split('\r\n').forEach((l,index) =>{
- this.qrcodes.push({
- remark: "Peer " + (index+1),
- link: l
- });
- });
- } else {
- this.inbound.genAllLinks(this.dbInbound.remark, app.remarkModel, client).forEach(l => {
- this.qrcodes.push({
- remark: l.remark,
- link: l.link
- });
- });
- }
- this.visible = true;
- },
- close: function () {
- this.visible = false;
- },
- };
- const qrModalApp = new Vue({
- delimiters: ['[[', ']]'],
- el: '#qrcode-modal',
- data: {
- qrModal: qrModal,
- },
- methods: {
- copyToClipboard(elmentId, content) {
- this.qrModal.clipboard = new ClipboardJS('#' + elmentId, {
- text: () => content,
- });
- this.qrModal.clipboard.on('success', () => {
- app.$message.success('{{ i18n "copied" }}')
- this.qrModal.clipboard.destroy();
- });
- },
- setQrCode(elmentId, content) {
- new QRious({
- element: document.querySelector('#' + elmentId),
- size: 260,
- value: content,
- });
- },
- genSubLink(subID) {
- return app.subSettings.subURI+subID;
- },
- genSubJsonLink(subID) {
- return app.subSettings.subJsonURI+subID;
- }
- },
- updated() {
- if (qrModal.client && qrModal.client.subId) {
- qrModal.subId = qrModal.client.subId;
- this.setQrCode("qrCode-sub", this.genSubLink(qrModal.subId));
- this.setQrCode("qrCode-subJson", this.genSubJsonLink(qrModal.subId));
- }
- qrModal.qrcodes.forEach((element, index) => {
- this.setQrCode("qrCode-" + index, element.link);
- });
- }
- });
- </script>
- {{end}}
|