diff --git a/unitool.js b/unitool.js index c1f0320..03625d2 100644 --- a/unitool.js +++ b/unitool.js @@ -126,7 +126,7 @@ export default { // 响应式方案:仅仅根据当前设备类型,如果是 PC 大屏幕,则始终显示 topWindow 并且隐藏顶部 navibar 和底部 tabBar。 if (pagesJson?.topWindow || !envar?.showBarsOnPC) { // 如果页头不是通过 pagesJson.topWindow 而是作为组件来引入个别页面,那么定义配置参数 showBarsOnPC 来控制。 - if (uni.getSystemInfoSync().model === 'PC') { + if (uni.getSystemInfoSync().deviceType === 'pc') { if (window.innerWidth > (pagesJson?.topWindow?.matchMedia?.minWidth || 0)) { uni.hideTabBar() // 不知为何,同一个二级页面,如果第二次进入,就仍然会显示 navibar, 必须通过 setTimeout 执行才能彻底隐藏。 @@ -341,7 +341,10 @@ export default { let filePath, cloudPath, - systemInfo = this.getSystemInfo() + systemInfo = uni + .getSystemInfoSync() + .system.toLowerCase() + .replace(/\s+/g, '') if (mediaType === 'image') { let [errorChoose, { tempFilePaths, tempFiles } = {}] = await uni.chooseImage({ count, sizeType, sourceType }) // uni.showModal({ title: 'tempFilePaths[0]=' + tempFilePaths[0] }) @@ -349,20 +352,20 @@ export default { // #ifndef H5 // let [errorGetImageInfo, { path, width, height, orientation, type }] = await uni.getImageInfo({ src: filePath }) // cloudPath = path // 完整路径,包含后缀名。形如 file:///var/mobile/Containers/Data/Application/55A76332-44F5-4D5F-A9F6-3F857D584883/Documents/Pandora/apps/D064A425A8BEC13F9D8F741B98B37BC5/doc/uniapp_temp_1598593902955/compressed/1598593925815.png - cloudPath = `APP_${systemInfo.platform}__${filePath}` // 在 iOS 上是 "_doc/uniapp_temp_1598593902955/compressed/1598593925815.png", 有时还包含从 file:/// 开始的完整路径名 + cloudPath = `APP_${systemInfo}__${filePath}` // 在 iOS 上是 "_doc/uniapp_temp_1598593902955/compressed/1598593925815.png", 有时还包含从 file:/// 开始的完整路径名 // #endif // #ifdef H5 - cloudPath = `H5_${systemInfo.platform}_${systemInfo.browser}__${tempFiles[0].name}` // name is available in H5 only. 只包含文件名和后缀名,不包含路径。 + cloudPath = `H5_${systemInfo}_${this.parse_ua_to_browser()}__${tempFiles[0].name}` // name is available in H5 only. 只包含文件名和后缀名,不包含路径。 // #endif } else if (mediaType === 'video') { let [errorChoose, { tempFilePath, tempFile, duration, size, width, height, name }] = await uni.chooseVideo({ sourceType, maxDuration }) // uni.showModal({ title: 'tempFilePath=' + tempFilePath }) filePath = tempFilePath // 在 iOS 上形如 "file:///var/mobile/Containers/Data/Application/55A76332-44F5-4D5F-A9F6-3F857D584883/Documents/Pandora/apps/26B43CD2F587D37FC6799108434A6F84/doc/uniapp_temp_1598596171580/gallery/IMG_3082.MOV" // #ifndef H5 - cloudPath = `APP_${systemInfo.platform}_dur${duration}__${filePath}` + cloudPath = `APP_${systemInfo}_dur${duration}__${filePath}` // #endif // #ifdef H5 - cloudPath = `H5_${systemInfo.platform}_${systemInfo.browser}_dur${duration}__${name}` // tempFile and name are H5 only + cloudPath = `H5_${systemInfo}_${this.parse_ua_to_browser()}_dur${duration}__${name}` // tempFile and name are H5 only // #endif // iOS 上测试,filePath 为 *.MOV,而阿里云只允许 *.mp4, 所以添加 .mp4 后缀。参见 https://uniapp.dcloud.net.cn/uniCloud/storage?id=clouduploadfile // 20200915测试,阿里云支持上传 *.mov 了。 @@ -426,41 +429,25 @@ export default { // #endif }, - getSystemInfo () { - let systemInfo = uni.getSystemInfoSync() - // model=PC|iPhone|iPad|Nexus 6|..., - // platform=ios|android|mac|windows|linux|other, - // system=iOS 11.0|Android 4.0|Other 0|... 等等 - + parse_ua_to_browser () { + let userAgent = '' // #ifdef H5 - systemInfo.environment = 'h5' - let userAgent = window.navigator.userAgent.toLowerCase() - systemInfo.browser = - /msie/.test(userAgent) && !/opera/.test(userAgent) - ? 'msie' - : /opera/.test(userAgent) - ? 'opera' - : /version.*safari/.test(userAgent) - ? 'safari' - : /chrome/.test(userAgent) - ? 'chrome' - : /gecko/.test(userAgent) && !/webkit/.test(userAgent) - ? 'firefox' - : /micromessenger/.test(userAgent) - ? 'wechat' - : 'unknown' + userAgent = window.navigator.userAgent.toLowerCase() + return /msie/.test(userAgent) && !/opera/.test(userAgent) + ? 'msie' + : /opera/.test(userAgent) + ? 'opera' + : /version.*safari/.test(userAgent) + ? 'safari' + : /chrome/.test(userAgent) + ? 'chrome' + : /gecko/.test(userAgent) && !/webkit/.test(userAgent) + ? 'firefox' + : /micromessenger/.test(userAgent) + ? 'wechat' + : 'unknown' // 只要在 H5, 即使不认识也要返回一个名称。 // #endif - - // #ifdef APP-PLUS || APP-PLUS-NVUE - systemInfo.environment = 'app' - // #endif - - // #ifdef MP - systemInfo.environment = 'mp' - // 细分成 WEIXIN, ... - // #endif - - return systemInfo + return '' // 如果不在 H5。 }, /*