NGTools/uni_modules/uni-upgrade-center/pages/version/detail.vue
liaody 3d90da2569 pages.json 分文件配置
uni-module 更新升级
2024-10-09 22:44:03 +08:00

402 lines
14 KiB
Vue
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<template>
<view class="uni-container">
<view class="uni-header">
<view class="uni-group">
<view class="uni-title">包类型</view>
<view class="uni-sub-title" style="display: flex;justify-content: center;align-items: center;">
{{type_valuetotext[formData.type]}}
</view>
</view>
<view v-if="!isStable" class="uni-group">
<button class="uni-button" type="warn" size="mini" @click="deletePackage">删除</button>
</view>
</view>
<uni-forms ref="form" :value="formData" validateTrigger="bind" :labelWidth="labelWidth">
<uni-forms-item name="appid" label="AppID" required>
<uni-easyinput :disabled="true" v-model="formData.appid" trim="both" />
</uni-forms-item>
<uni-forms-item name="name" label="应用名称">
<uni-easyinput :disabled="true" v-model="formData.name" trim="both" />
</uni-forms-item>
<uni-forms-item name="title" label="更新标题">
<uni-easyinput :disabled="detailsState" placeholder="更新标题" v-model="formData.title" />
</uni-forms-item>
<uni-forms-item name="contents" label="更新内容" required>
<textarea auto-height style="box-sizing: content-box;" :disabled="detailsState"
@input="binddata('contents', $event.detail.value)" class="uni-textarea-border"
:value="formData.contents" @update:value="val => formData.contents = val"></textarea>
</uni-forms-item>
<uni-forms-item name="platform" label="平台" required>
<uni-data-checkbox :disabled="true" :multiple="true" v-model="formData.platform"
:localdata="platformLocaldata" />
</uni-forms-item>
<uni-forms-item name="version" label="版本号" required>
<uni-easyinput :disabled="true" v-model="formData.version" placeholder="当前包版本号,必须大于当前已上线版本号" />
</uni-forms-item>
<uni-forms-item v-if="isWGT" key="min_uni_version" name="min_uni_version" label="原生App最低版本"
:required="isWGT">
<uni-easyinput :disabled="detailsState" placeholder="原生App最低版本" v-model="formData.min_uni_version" />
<show-info :content="minUniVersionContent"></show-info>
</uni-forms-item>
<uni-forms-item label="存储选择" v-if="!detailsState">
<view class="flex">
<radio-group @change="e => uniFilePickerProvider = e.detail.value" style="width: 100%;">
<view class="flex" style="flex-wrap: nowrap;">
上传至:
<label>
<radio value="unicloud" :checked="uniFilePickerProvider === 'unicloud'"/><text>内置存储</text>
</label>
<label style="margin-left: 20rpx;">
<radio value="extStorage" :checked="uniFilePickerProvider === 'extStorage'"/><text>扩展存储</text>
</label>
</view>
</radio-group>
<text class="uni-sub-title" style="margin-top: 10px;font-size: 12px;color: #666;width: 100%;">内置存储是服务空间开通后自带的云存储,不支持自定义域名,不支持阶梯计费</text>
<text class="uni-sub-title" style="margin-top: 10px;font-size: 12px;color: #666;">扩展存储支持自定义域名、阶梯计费,越用越便宜、功能更强大</text>
<text class="uni-sub-title" style="margin-top: 10px;font-size: 12px;color: #2979ff;cursor: pointer;text-decoration: underline; margin-left: 10px;" @click="toUrl('https://doc.dcloud.net.cn/uniCloud/ext-storage/service.html')">扩展存储开通文档</text>
</view>
</uni-forms-item>
<uni-forms-item label="自定义域名" v-if="uniFilePickerProvider === 'extStorage' && !detailsState">
<view class="flex" style="flex-direction: column;align-items:flex-start;">
<uni-easyinput placeholder="请输入扩展存储自定义域名" v-model="domain" :maxlength="-1" style="width: 550px;"/>
<text class="uni-sub-title" style="margin-top: 10px;font-size: 12px;color: #666;">输入扩展存储绑定的域名,在服务空间-云存储-扩展存储页面可查看cdn.example.com</text>
</view>
</uni-forms-item>
<uni-forms-item v-if="!isiOS && !detailsState" :label="'上传'+fileExtname[0]+'包'">
<uni-file-picker v-model="appFileList" :file-extname="fileExtname" :disabled="hasPackage"
returnType="object" file-mediatype="all" limit="1" @success="packageUploadSuccess" :provider="uniFilePickerProvider"
@delete="packageDelete">
<view class="flex">
<button type="primary" size="mini" @click="selectFile" style="margin: 0px;">选择文件</button>
</view>
</uni-file-picker>
<text v-if="hasPackage"
style="padding-left: 20px;color: #a8a8a8;">{{Number(appFileList.size / 1024 / 1024).toFixed(2)}}M</text>
</uni-forms-item>
<uni-forms-item key="url" name="url" :label="isiOS ? 'AppStore' : '下载链接'" required>
<view class="flex" style="flex-direction: column;align-items:flex-start;flex: 1;">
<view class="flex" style="width: 100%;">
<uni-easyinput :disabled="detailsState" placeholder="下载链接" v-model="formData.url" :maxlength="-1" />
<text style="margin-left: 10px;color: #2979ff;cursor: pointer;text-decoration: underline;" v-if="formData.url" @click="toUrl(formData.url)">测试下载</text>
</view>
<text style="margin-top: 10px;font-size: 12px;color: #666;" v-if="formData.url && !detailsState">建议点击【测试下载】能正常下载后,再进行发布</text>
</view>
</uni-forms-item>
<uni-forms-item v-if="!isiOS && !isWGT && formData.store_list.length" label="Android应用市场" key="store_list"
name="store_list" labelWidth="120">
<view style="flex: 1;">
<view v-for="(item,index) in formData.store_list" :key="item.id">
<uni-card style="margin: 0px 0px 20px 0px;">
<view style="display: flex;">
<checkbox-group style="user-select: none;"
@change="({detail:{value}}) => {item.enable = !!value.length}">
<label class="title_padding">
<checkbox :disabled="detailsState" value="scheme" :checked="item.enable" />
<text>是否启用</text>
</label>
</checkbox-group>
</view>
<uni-forms-item label="商店名称">
<uni-easyinput disabled v-model="item.name" trim="both"></uni-easyinput>
</uni-forms-item>
<uni-forms-item label="Scheme">
<uni-easyinput disabled v-model="item.scheme" trim="both"></uni-easyinput>
</uni-forms-item>
<uni-forms-item label="优先级">
<uni-easyinput :disabled="detailsState" v-model="item.priority" type="number">
</uni-easyinput>
<show-info :top="-100" :left="-180" :content="priorityContent"></show-info>
</uni-forms-item>
</uni-card>
</view>
</view>
</uni-forms-item>
<uni-forms-item v-if="isWGT" key="is_silently" name="is_silently" label="静默更新">
<switch :disabled="detailsState"
@change="binddata('is_silently', $event.detail.value),formData.is_silently=$event.detail.value"
:checked="formData.is_silently" />
<show-info :top="-80" :content="silentlyContent"></show-info>
</uni-forms-item>
<uni-forms-item v-if="!isiOS" key="is_mandatory" name="is_mandatory" label="强制更新">
<switch :disabled="detailsState"
@change="binddata('is_mandatory', $event.detail.value),formData.is_mandatory=$event.detail.value"
:checked="formData.is_mandatory" />
<show-info width="230" :top="-30" :content="mandatoryContent"></show-info>
</uni-forms-item>
<uni-forms-item name="stable_publish" label="上线发行">
<switch :disabled="detailsState || isStable"
@change="binddata('stable_publish', $event.detail.value),formData.stable_publish=$event.detail.value"
:checked="formData.stable_publish" />
<show-info v-if="isStable" :top="-50" width="350" :content="stablePublishContent"></show-info>
<show-info v-else :top="-40" :content="stablePublishContent2"></show-info>
</uni-forms-item>
<uni-forms-item name="create_date" label="上传时间">
<uni-dateformat format="yyyy-MM-dd hh:mm:ss" :date="formData.create_date" :threshold="[0, 0]" />
</uni-forms-item>
<uni-forms-item v-show="false" name="type" label="安装包类型">
<uni-data-checkbox v-model="formData.type" :localdata="formOptions.type_localdata" />
</uni-forms-item>
<view class="uni-button-group">
<button type="primary" class="uni-button" style="width: 100px;" @click="detailsState = false"
v-if="detailsState">修改</button>
<button type="primary" class="uni-button" style="width: 100px;" @click="submit"
v-if="!detailsState">提交</button>
<button type="warn" class="uni-button" style="width: 100px;" @click="cancelEdit"
v-if="!detailsState">取消</button>
<navigator open-type="navigateBack" style="margin-left: 15px;">
<button class="uni-button" style="width: 100px;">返回</button>
</navigator>
</view>
</uni-forms>
</view>
</template>
<script>
import {
validator,
enumConverter
} from '@/js_sdk/validator/opendb-app-versions.js';
import addAndDetail, {
fields
} from '../mixin/version_add_detail_mixin.js'
import {
deepClone,
appVersionListDbName
} from '../utils.js'
const db = uniCloud.database();
const dbCmd = db.command;
const dbCollectionName = appVersionListDbName;
const platform_iOS = 'iOS';
const platform_Android = 'Android';
function getValidator(fields) {
let reuslt = {}
for (let key in validator) {
if (fields.includes(key)) {
reuslt[key] = validator[key]
}
}
return reuslt
}
export default {
mixins: [addAndDetail],
data() {
return {
showStableInfo: false,
isStable: true, // 是否是线上发行版
originalData: {}, // 原始数据,用于恢复状态
detailsState: true, // 查看状态,
uniFilePickerProvider: 'unicloud',
domain: ""
}
},
async onLoad(e) {
let { domain, provider } = this.getCloudStorageConfig();
if (domain) this.domain = domain;
if (provider) this.uniFilePickerProvider = provider;
const id = e.id
this.formDataId = id
await this.getDetail(id)
this.isStable = this.formData.stable_publish;
this.latestStableData = await this.getLatestVersion();
if (this.isWGT) {
this.rules.min_uni_version.rules.push({
"required": true
})
}
},
onUnload() {
// 临时处理,后面会再优化
this.setCloudStorage({
provider: null
});
},
watch: {
"domain"(val) {
this.setCloudStorage({
domain: val
});
if (this.formData.url) {
// 替换 this.formData.url 内的域名
if (!val) val = "请输入自定义域名"
this.formData.url = this.formData.url.replace(/^(https?:\/\/)[^\/]+/, `$1${val}`);
}
},
uniFilePickerProvider(val){
this.setCloudStorage({
provider: val
});
}
},
methods: {
/**
* 触发表单提交
*/
submit() {
uni.showLoading({
mask: true
})
this.$refs.form.validate(['store_list']).then((res) => {
if (res.store_list) {
res.store_list.forEach(item => {
item.priority = parseFloat(item.priority)
})
}
this.submitForm(res)
}).catch((errors) => {
uni.hideLoading()
})
},
async submitForm(value) {
const collectionDB = db.collection(dbCollectionName)
// 使用 clientDB 提交数据
collectionDB.doc(this.formDataId).update(value).then(async (res) => {
// 如果不是线上发行版,则在设置为上线发行时,需将之前的已上线版设为下线
if (!this.isStable && value.stable_publish === true && this.latestStableData) {
await collectionDB.doc(this.latestStableData._id).update({
stable_publish: false
})
}
uni.showToast({
title: '修改成功'
})
this.getOpenerEventChannel().emit('refreshData')
setTimeout(() => uni.navigateBack(), 500)
}).catch((err) => {
uni.showModal({
content: err.message || '请求服务失败',
showCancel: false
})
}).finally(() => {
uni.hideLoading()
})
},
/**
* 获取表单数据
* @param {Object} id
*/
getDetail(id) {
uni.showLoading({
mask: true
})
return db.collection(dbCollectionName)
.doc(id)
.field(fields)
.get()
.then((res) => {
const data = res.result.data[0]
if (data) {
if (!data.store_list) data.store_list = []
this.formData = data
this.originalData = deepClone(this.formData)
}
}).catch((err) => {
uni.showModal({
content: err.message || '请求服务失败',
showCancel: false
})
}).finally(() => {
uni.hideLoading()
})
},
deletePackage() {
uni.showModal({
title: '提示',
content: '是否删除该版本',
success: res => {
if (res.confirm) {
uni.showLoading({
mask: true
})
db.collection(dbCollectionName).doc(this.formDataId).remove()
.then(() => {
uni.showToast({
title: '删除成功'
})
this.getOpenerEventChannel().emit('refreshData')
setTimeout(() => uni.navigateBack(), 500)
}).catch((err) => {
uni.showModal({
content: err.message || '请求服务失败',
showCancel: false
})
}).finally(() => {
uni.hideLoading()
})
}
}
});
},
async getLatestVersion() {
const where = {
appid: this.formData.appid,
type: this.formData.type,
stable_publish: true
};
if (!this.isWGT) {
where.platform = this.formData.platform[0]
}
const latestStableData = await db.collection(dbCollectionName).where(where).get()
return latestStableData.result.data.find(item => item.platform.toString() === this.formData.platform
.toString());
},
cancelEdit() {
let content = '';
!this.isiOS && this.hasPackage ? content += '\n将会删除已上传的包' : '';
uni.showModal({
title: '取消修改',
content,
success: res => {
if (res.confirm) {
this.formData = deepClone(this.originalData)
this.detailsState = true
if (this.hasPackage) {
this.deleteFile([this.appFileList.url])
}
}
}
});
}
}
}
</script>
<style lang="scss">
.show-stable-info {
position: absolute;
left: 165px;
padding: 5px 10px;
background-color: #f4f4f5;
color: #909399;
border-radius: 4px;
border: 1px solid #e9e9eb;
}
::v-deep .uni-forms-item__content {
display: flex;
align-items: center;
}
.uni-button-group {
& button {
margin-left: 15px;
}
& button:first-child {
margin-left: 0px;
}
}
</style>