金久信后台管理系统
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

278 lines
8.2 KiB

<template>
<vk-data-dialog
v-model="value.show"
:title="page.title"
:top="page.top"
:width="page.width"
:close-on-click-modal="true"
:destroy-on-close="true"
mode="form"
@open="onOpen"
@closed="onClose"
>
<!-- 页面主体内容开始 -->
<vk-data-form
ref="form1"
v-model="form1.data"
:form-type="value.mode"
:rules="form1.props.rules"
:action="form1.props.action"
:columns="form1.props.columns"
:loading.sync="form1.props.loading"
:labelWidth="form1.props.labelWidth"
:show-cancel="page.showCancel"
:cancel-text="page.cancelText"
:submit-text="page.submitText"
@success="onFormSuccess"
></vk-data-form>
<!-- 页面主体内容结束 -->
</vk-data-dialog>
</template>
<script>
var pageName = "";
var vk = uni.vk; // vk实例
var originalForms = {}; // 表单初始化数据
var defaultFormData = {
appid:"",
name:"",
title:"",
contents:"",
platform:[],
platformRadio:"",
type:"",
version:"",
min_uni_version:"",
url:"",
stable_publish:false,
is_silently:false,
is_mandatory:false,
create_env:"upgrade-center",
store_list:[],
};
export default {
props: {
value: {
Type: Object,
default: function() {
return {
show: false,
mode: "",
item: {
stable_publish:""
},
options:{}
};
}
}
},
data: function() {
// 组件创建时,进行数据初始化
return {
page: {
title: "标题",
submitText: "确定",
cancelText: "关闭",
showCancel: true,
top: "2vh",
width: "900px"
},
form1:{
// 表单请求数据,此处可以设置默认值
data: defaultFormData,
// 表单属性
props: {
// 表单请求地址
action:"",
// 表单字段显示规则
columns:[
{ key: "appid", title: "AppID", type: "text", disabled:true },
{ key: "name", title: "应用名称", type: "text", disabled:true },
{ key: "title", title: "更新标题", type: "text" },
{
key:"contents", title:"更新内容", type:"textarea",
autosize:{ minRows:4, maxRows:10 },
maxlength:2000,
showWordLimit:true,
},
{
key:"platformRadio", title:"平台", type:"radio",
itemWidth:80,
data:[
{ value:"Android", label:"安卓" },
{ value:"iOS", label:"苹果" }
],
showRule:"type==native_app",
disabled:["update"]
},
{
key:"platform", title:"平台", type:"checkbox",
itemWidth:80,
data:[
{ value:"Android", label:"安卓" },
{ value:"iOS", label:"苹果" }
],
showRule:"type==wgt",
disabled:["update"]
},
{ key: "version", title: "版本号", type: "text", tips:"必须大于当前线上发行的版本号", disabled:["update"] },
{ key: "min_uni_version", title: "原生App最低版本", type: "text", showRule:"type==wgt" },
{ key: "url", title: "AppStore", type: "text",
showRule:(formData)=>{
return formData.platformRadio === "iOS" && formData.type === "native_app";
}
},
{ key:"apk", title:"上传apk包", type:"file", limit:1, accept:".apk",
showRule:(formData)=>{
return formData.platformRadio === "Android" && formData.type === "native_app";
},
watch: ({ value, formData, column, index, $set }) => {
$set("url", value);
},
tips:"上传apk包到当前服务空间的云存储中,上传成功后,会自动使用云存储地址填充下载链接"
},
{ key:"wgt", title:"上传wgt包", type:"file", limit:1, accept:".wgt",
showRule:(formData)=>{
return formData.type === "wgt";
},
watch: ({ value, formData, column, index, $set }) => {
$set("url", value);
},
tips:"上传wgt包到当前服务空间的云存储中,上传成功后,会自动使用云存储地址填充下载链接"
},
{ key: "url", title: "下载链接", type: "text",
showRule:(formData)=>{
return formData.platformRadio === "Android" || formData.type === "wgt";
}
},
{
key:"store_list", title:"Android应用市场", type:"array<object>",
showRule:(formData)=>{
return formData.platformRadio === "Android" && formData.type === "native_app" && formData.store_list && formData.store_list.length>0 ? true : false;
},
rowKey:"id",
showAdd:false,
showClear:false,
showSort:true,
// 新增一行时,该行的默认值
defaultValue:{
},
rightBtns:['delete'],
// 每行每个字段对应的渲染规则
columns:[
{ key:"enable", title:"是否启用", type:"switch", width:80 },
{
key:"name", title:"商店名称", type:"text", minWidth:180,
disabled: true
},
{
key:"scheme", title:"Scheme", type:"text", minWidth:280,
disabled: true
},
]
},
{ key:"is_silently", title:"静默更新", type:"switch", activeValue:true, inactiveValue:false, showRule:"type==wgt" },
{ key:"is_mandatory", title:"强制更新", type:"switch", activeValue:true, inactiveValue:false },
{ key:"stable_publish", title:"上线发行", type:"switch", activeValue:true, inactiveValue:false,
disabled: (formData)=>{
return this.value.item.stable_publish && this.value.mode === "update";
}
}
],
// 表单验证规则
rules:{
appid: [
// 必填
{ required: true, message: "appid不能为空", trigger: ['blur','change'] }
],
contents: [
// 必填
{ required: true, message: "更新内容不能为空", trigger: ['blur','change'] }
],
platform: [
// 必填
{ required: true, message: "平台不能为空", trigger: ['blur','change'] }
],
platformRadio: [
// 必填
{ required: true, message: "平台不能为空", trigger: ['blur','change'] }
],
version: [
// 必填
{ required: true, message: "版本号不能为空", trigger: ['blur','change'] },
{ validator: vk.pubfn.validator("version"), message: '版本号格式必须为:xx.xx.xx(3个数字组成,数字范围1-99,0-99,0-99) 如1.0.1 不可以是1.0.01', trigger: 'blur' }
],
min_uni_version: [
// 必填
{ required: true, message: "最低版本号不能为空", trigger: ['blur','change'] },
{ validator: vk.pubfn.validator("version"), message: '版本号格式必须为:xx.xx.xx(3个数字组成,数字范围1-99,0-99,0-99) 如1.0.1 不可以是1.0.01', trigger: 'blur' }
],
url: [
// 必填
{ required: true, message: "链接不能为空", trigger: ['blur','change'] }
],
},
// add 代表添加 update 代表修改
formType:"",
// 左侧label的宽度
labelWidth: "140px",
}
},
};
},
mounted() {
this.init();
},
methods: {
// 初始化
init() {
let { value } = this;
this.$emit("input", value);
originalForms["form1"] = vk.pubfn.copyObject(this.form1);
},
// 监听 - 页面打开
onOpen() {
let { value={} } = this;
let { item={} } = value;
// 每次打开时,重新设置表单的值 = value.item 的值,item通过 vk.pubfn.openForm('表单名',{ item:{ _id:"1" } }) 传递值
if(value.mode === "update"){
this.form1.props.action = "admin/system/app-upgrade-center/sys/addUpdate";
this.page.title = pageName + "修改";
this.page.submitText = "修改";
if (item.type === "native_app") {
item.platformRadio = item.platform[0];
}
this.form1.data = vk.pubfn.objectAssign(vk.pubfn.copyObject(defaultFormData), vk.pubfn.copyObject(item));
}else{
this.form1.props.action = "admin/system/app-upgrade-center/sys/addUpdate";
this.page.title = pageName + "添加";
this.page.submitText = "添加";
this.form1.data = vk.pubfn.objectAssign(vk.pubfn.copyObject(defaultFormData), vk.pubfn.copyObject(item));
}
},
// 监听 - 页面关闭
onClose() {
this.resetForm();
},
// 监听 - 提交成功后
onFormSuccess() {
this.value.show = false; // 关闭页面
this.$emit("success");
},
// 表单重置
resetForm(){
vk.pubfn.resetForm(originalForms, this);
},
},
watch: {
},
// 计算属性
computed: {
}
};
</script>
<style lang="scss" scoped></style>