100 lines
1.9 KiB
Vue
100 lines
1.9 KiB
Vue
<template>
|
||
<u-modal
|
||
v-model="show"
|
||
:class="customClass"
|
||
:style="$u.toStyle(customStyle)"
|
||
:show-cancel-button="true"
|
||
:confirm-text="t('uFullScreen.upgrade')"
|
||
:title="title || t('uFullScreen.title')"
|
||
@cancel="cancel"
|
||
@confirm="confirm"
|
||
>
|
||
<view class="u-update-content">
|
||
<rich-text :nodes="content"></rich-text>
|
||
</view>
|
||
</u-modal>
|
||
</template>
|
||
|
||
<script lang="ts">
|
||
export default {
|
||
name: 'u-full-screen',
|
||
options: {
|
||
addGlobalClass: true,
|
||
// #ifndef MP-TOUTIAO
|
||
virtualHost: true,
|
||
// #endif
|
||
styleIsolation: 'shared'
|
||
}
|
||
};
|
||
</script>
|
||
|
||
<script setup lang="ts">
|
||
import { FullScreenProps } from './types';
|
||
import { ref, onMounted } from 'vue';
|
||
import { $u, useLocale } from '../../';
|
||
|
||
/**
|
||
* 压窗屏升级弹窗组件
|
||
* @description 用于APP弹窗遮盖导航栏和底部tabbar,提示新版本升级内容
|
||
* @property {boolean} show 是否显示弹窗
|
||
* @property {string} content 升级内容,支持富文本
|
||
*/
|
||
defineProps(FullScreenProps);
|
||
|
||
/**
|
||
* 是否显示弹窗
|
||
*/
|
||
const show = ref(false);
|
||
/**
|
||
* 升级内容,支持富文本
|
||
*/
|
||
|
||
const { t } = useLocale();
|
||
|
||
/**
|
||
* 页面加载完成后自动显示弹窗
|
||
*/
|
||
onMounted(() => {
|
||
show.value = true;
|
||
});
|
||
|
||
/**
|
||
* 取消按钮点击事件
|
||
* @description 关闭弹窗并返回上一页
|
||
*/
|
||
function cancel() {
|
||
closeModal();
|
||
}
|
||
|
||
/**
|
||
* 升级按钮点击事件
|
||
* @description 关闭弹窗并返回上一页
|
||
*/
|
||
function confirm() {
|
||
closeModal();
|
||
}
|
||
|
||
/**
|
||
* 关闭弹窗方法
|
||
* @description 返回上一页
|
||
*/
|
||
function closeModal() {
|
||
uni.navigateBack();
|
||
}
|
||
</script>
|
||
|
||
<style scoped lang="scss">
|
||
@import '../../libs/css/style.components.scss';
|
||
|
||
.u-full-content {
|
||
background-color: var(--u-type-success);
|
||
}
|
||
|
||
.u-update-content {
|
||
font-size: 26rpx;
|
||
color: $u-content-color;
|
||
line-height: 1.7;
|
||
padding: 30rpx;
|
||
}
|
||
</style>
|