123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 |
- <template>
- <div>
- <div v-if="pageStatus == 0">配置加载中...</div>
- <div v-else-if="pageStatus == 1">此页面不对此账号开放</div>
- <div v-else-if="pageStatus == 2">没有此页内容的配置权限,请检查集团上的配置</div>
- <div v-else-if="pageStatus == 3">加载发生错误</div>
- <div v-else-if="pageStatus == 4" class="app-container">
- 你好
- <slot></slot>
- </div>
- </div>
- </template>
- <script>
- import { scrollTo } from "@/utils/scroll-to";
- import vueQr from "vue-qr";
- import html2canvas from "html2canvas";
- export default {
- name: "PermissionContainer",
- data() {
- return {
- pageStatus:4,
- };
- },
- props: {
- // page: {
- // type: Number,
- // default: 1,
- // },
- // limit: {
- // type: Number,
- // default: 10,
- // },
- // pageSizes: {
- // type: Array,
- // default() {
- // return [10, 20, 30, 50];
- // },
- // },
- // layout: {
- // type: String,
- // default: "total, sizes, prev, pager, next, jumper",
- // },
- // background: {
- // type: Boolean,
- // default: true,
- // },
- // autoScroll: {
- // type: Boolean,
- // default: true,
- // },
- // hidden: {
- // type: Boolean,
- // default: false,
- // },
- // pagerCount: {
- // type: Number,
- // default: 7,
- // },
- // text: {
- // type: String,
- // required: true,
- // },
- // name:{
- // type: String,
- // required: true,
- // }
- },
- components: {
- vueQr,
- },
- computed: {
- // currentPage: {
- // get() {
- // return this.page;
- // },
- // set(val) {
- // this.$emit("update:page", val);
- // },
- // },
- // pageSize: {
- // get() {
- // return this.limit;
- // },
- // set(val) {
- // this.$emit("update:limit", val);
- // },
- // },
- },
- methods: {
- downloadImg() {
- try {
- window.pageYoffset = 0;
- document.documentElement.scrollTop = 0;
- document.body.scrollTop = 0;
- html2canvas(document.getElementById("qrDiv_QrCode"), {
- allowTaint: false,
- }).then((canvas) => {
- const a = document.createElement("a");
- const event = new MouseEvent("click");
- a.download = this.name;
- a.href = canvas.toDataURL();
- a.dispatchEvent(event);
- this.$emit("downloadImg")
- });
- } catch (error) {
- this.msgError("导出二维码失败,请刷新重试~")
- }
- },
- exportQr(text) {
- this.text = "https://goto.huijy.net/" + this.deptId + "/" + trimEqualStr;
- this.exportQrDialog = true;
- },
- handleSizeChange(val) {
- this.$emit("pagination", { page: this.currentPage, limit: val });
- if (this.autoScroll) {
- scrollTo(0, 800);
- }
- },
- handleCurrentChange(val) {
- this.$emit("pagination", { page: val, limit: this.pageSize });
- if (this.autoScroll) {
- scrollTo(0, 800);
- }
- },
- },
- };
- </script>
- <style scoped>
- </style>
|