Some work on the popup

Some more work on the modal

Some more work done

Some initial work on adding the QR code

Some more changes

Done
This commit is contained in:
Sal Rahman 2023-08-21 21:41:40 -07:00 committed by 老周部落
parent 9a077c4beb
commit bb984a8608
No known key found for this signature in database
GPG key ID: C72181CD85C6B738
6 changed files with 99 additions and 0 deletions

View file

@ -1157,6 +1157,7 @@ addRe: "Add \"re:\" at the beginning of comment in reply to a post with a conten
confirm: "Confirm" confirm: "Confirm"
importZip: "Import ZIP" importZip: "Import ZIP"
exportZip: "Export ZIP" exportZip: "Export ZIP"
getQrCode: "Get QR code"
emojiPackCreator: "Emoji pack creator" emojiPackCreator: "Emoji pack creator"
indexable: "Indexable" indexable: "Indexable"
indexableDescription: "Allow built-in search to show your public posts" indexableDescription: "Allow built-in search to show your public posts"

View file

@ -928,6 +928,8 @@ colored: "Coloré"
label: "Étiquette" label: "Étiquette"
localOnly: "Local seulement" localOnly: "Local seulement"
account: "Comptes" account: "Comptes"
getQrCode: "Obtenir le code QR"
_emailUnavailable: _emailUnavailable:
used: "Adresse non disponible" used: "Adresse non disponible"
format: "Le format de cette adresse de courriel est invalide" format: "Le format de cette adresse de courriel est invalide"

View file

@ -28,6 +28,7 @@
"@types/matter-js": "0.19.6", "@types/matter-js": "0.19.6",
"@types/prismjs": "^1.26.3", "@types/prismjs": "^1.26.3",
"@types/punycode": "2.1.4", "@types/punycode": "2.1.4",
"@types/qrcode": "1.5.1",
"@types/seedrandom": "3.0.8", "@types/seedrandom": "3.0.8",
"@types/textarea-caret": "^3.0.3", "@types/textarea-caret": "^3.0.3",
"@types/throttle-debounce": "5.0.2", "@types/throttle-debounce": "5.0.2",
@ -60,13 +61,17 @@
"insert-text-at-cursor": "0.3.0", "insert-text-at-cursor": "0.3.0",
"json5": "2.2.3", "json5": "2.2.3",
"katex": "0.16.10", "katex": "0.16.10",
"long": "^5.2.3",
"libopenmpt-wasm": "github:TheEssem/libopenmpt-packaging#build", "libopenmpt-wasm": "github:TheEssem/libopenmpt-packaging#build",
"matter-js": "0.19.0", "matter-js": "0.19.0",
"mfm-js": "0.24.0", "mfm-js": "0.24.0",
"multer": "1.4.4-lts.1",
"moment": "2.30.1", "moment": "2.30.1",
"photoswipe": "5.4.3", "photoswipe": "5.4.3",
"prismjs": "1.29.0", "prismjs": "1.29.0",
"punycode": "2.3.1", "punycode": "2.3.1",
"qrcode": "1.5.3",
"qrcode-vue3": "^1.6.8",
"rollup": "4.14.2", "rollup": "4.14.2",
"s-age": "1.1.2", "s-age": "1.1.2",
"sass": "1.75.0", "sass": "1.75.0",

View file

@ -0,0 +1,70 @@
<template>
<MkModal ref="modal" :z-priority="'middle'" @closed="$emit('closed')">
<div :class="$style.root">
<div :class="$style.title">
<QRCodeVue3
:value="qrCode"
/>
</div>
<MkButton :class="$style.gotIt" primary full @click="gotIt()">{{
i18n.ts.gotIt
}}</MkButton>
</div>
</MkModal>
</template>
<script lang="ts" setup>
import { shallowRef } from "vue";
import MkModal from "@/components/MkModal.vue";
import MkButton from "@/components/MkButton.vue";
import { i18n } from "@/i18n";
import QRCodeVue3 from "qrcode-vue3";
// const profileUrl = window.location.href;
const props = defineProps<{
qrCode: string
}>();
const modal = shallowRef<InstanceType<typeof MkModal>>();
const gotIt = () => {
modal.value.close();
};
</script>
<style lang="scss" module>
.root {
margin: auto;
position: relative;
padding: 32px;
min-width: 320px;
max-width: 480px;
box-sizing: border-box;
text-align: center;
background: var(--panel);
border-radius: var(--radius);
> img {
border-radius: 10px;
max-height: 100%;
max-width: 100%;
}
}
.title {
font-weight: bold;
> p {
margin: 0;
}
}
.time {
font-size: 0.8rem;
}
.gotIt {
margin: 8px 0 0 0;
}
</style>

View file

@ -7,6 +7,7 @@ import type { Component, MaybeRef, Ref } from "vue";
import { defineAsyncComponent, markRaw, ref } from "vue"; import { defineAsyncComponent, markRaw, ref } from "vue";
import { i18n } from "./i18n"; import { i18n } from "./i18n";
import MkDialog from "@/components/MkDialog.vue"; import MkDialog from "@/components/MkDialog.vue";
import FfQrCode from "@/components/FfQrCode.vue";
import MkPostFormDialog from "@/components/MkPostFormDialog.vue"; import MkPostFormDialog from "@/components/MkPostFormDialog.vue";
import MkToast from "@/components/MkToast.vue"; import MkToast from "@/components/MkToast.vue";
import MkWaitingDialog from "@/components/MkWaitingDialog.vue"; import MkWaitingDialog from "@/components/MkWaitingDialog.vue";
@ -1003,6 +1004,19 @@ export function post(
}); });
} }
export async function displayQrCode(qrCode: string) {
(await new Promise<(() => void) | undefined>((resolve) => {
let dispose: (() => void) | undefined;
popup(FfQrCode, { qrCode }, {
closed: () => {
resolve(dispose);
}
}).then((res) => {
dispose = res.dispose
})
}))?.();
}
export const deckGlobalEvents = new EventEmitter(); export const deckGlobalEvents = new EventEmitter();
/* /*

View file

@ -290,6 +290,13 @@ export function getUserMenu(user, router: Router = mainRouter) {
os.post({ specified: user }); os.post({ specified: user });
}, },
}, },
{
icon: "ph-qr-code ph-bold ph-lg",
text: i18n.ts.getQrCode,
action: () => {
os.displayQrCode(window.location.href)
}
},
isSignedIn(me) && me.id !== user.id isSignedIn(me) && me.id !== user.id
? { ? {
type: "link", type: "link",