| @ -0,0 +1,12 @@@@ -0,0 +1,12 @@ | ||||
| # EditorConfig is awesome: https://EditorConfig.org | ||||
| 
 | ||||
| # top-most EditorConfig file | ||||
| root = true | ||||
| 
 | ||||
| [*] | ||||
| indent_style = space | ||||
| indent_size = 2 | ||||
| end_of_line = lf | ||||
| charset = utf-8 | ||||
| trim_trailing_whitespace = true | ||||
| insert_final_newline = true | ||||
| @ -0,0 +1,5 @@@@ -0,0 +1,5 @@ | ||||
| .svn | ||||
| .vscode | ||||
| node_modules | ||||
| .idea | ||||
| .DS_Store | ||||
| @ -0,0 +1,10 @@@@ -0,0 +1,10 @@ | ||||
| { | ||||
|   "emmet_language_server": { | ||||
|     "init_options": { | ||||
|       "preferences": { | ||||
|         "css.intUnit": "rpx", | ||||
|         "css.floatUnitr": "rpx" | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,28 @@@@ -0,0 +1,28 @@ | ||||
| { | ||||
|   "$schema": "http://json.schemastore.org/prettierrc", | ||||
|   "printWidth": 120, | ||||
|   "tabWidth": 2, | ||||
|   "useTabs": false, | ||||
|   "semi": false, | ||||
|   "singleQuote": true, | ||||
|   "bracketSpacing": true, | ||||
|   "trailingComma": "all", | ||||
|   "arrowParens": "always", | ||||
|   "endOfLine": "lf", | ||||
|   "htmlWhitespaceSensitivity": "ignore", | ||||
|   "singleAttributePerLine": false, | ||||
|   "overrides": [ | ||||
|     { | ||||
|       "files": "*.wxml", | ||||
|       "options": { "parser": "html" } | ||||
|     }, | ||||
|     { | ||||
|       "files": "*.wxss", | ||||
|       "options": { "parser": "css" } | ||||
|     }, | ||||
|     { | ||||
|       "files": "*.wxs", | ||||
|       "options": { "parser": "babel" } | ||||
|     } | ||||
|   ] | ||||
| } | ||||
| @ -0,0 +1,81 @@@@ -0,0 +1,81 @@ | ||||
| ## global color | ||||
| 
 | ||||
| <!--图片文件夹svn地址--> | ||||
| 
 | ||||
| svn://39.106.86.127:28386/projects/zd/proj_src/shop/frontend/web/zd | ||||
| 
 | ||||
| 1. 视频根据列表滚动自动播放 | ||||
| 2. 患者来源渠道以及渠道值需要记录 | ||||
| 3. iframe 嵌套第三方网页,小程序 webview 试验 | ||||
| 4. 上传完诊断证明之后才记录额度 | ||||
| 5. 我的故事编辑姓名和手机号直接读出来就行 | ||||
| 
 | ||||
| ```json | ||||
| { | ||||
|   "ignore": [ | ||||
|     { | ||||
|       "value": "images/**/*.png", | ||||
|       "type": "glob" | ||||
|     } | ||||
|   ], | ||||
|   "include": [ | ||||
|     { | ||||
|       "value": "images/tabbar/*.png", | ||||
|       "type": "glob" | ||||
|     } | ||||
|   ] | ||||
| } | ||||
| ``` | ||||
| 
 | ||||
| (/images/)(\S*(?=["|'])) | ||||
| {{imageUrl}}$2?t={{Timestamp}} | ||||
| 
 | ||||
| 首页banner对应变量 | ||||
| MINIDOCTOR 微医弹窗 | ||||
| 
 | ||||
| 1. 互动消息列表 时间展示规则 | ||||
|    1. 当天展示 时分 | ||||
|    2. 超过一天 年月日 | ||||
| 
 | ||||
| ```js | ||||
| wx.showModal({ | ||||
|   title: '', | ||||
|   confirmColor: '#cf5375', | ||||
| }) | ||||
| // 医生端 confirmColor: '#62bed0', | ||||
| ``` | ||||
| 
 | ||||
| 1)提供3中的3个路径链接; | ||||
| a.跳转到患者端小程序的路径; | ||||
| /pages/index/index?es=201501 | ||||
| b.带商保参数的ADL引导页路径; | ||||
| /pages/adl/index?m_d=1&es=201502 | ||||
| c.微医webview页面路径; | ||||
| /pages/webview/index?es=201503 | ||||
| 
 | ||||
| 过滤微医路径的banner标题 | ||||
| BANNER-MINIDOVTOR | ||||
| 
 | ||||
| ### 下载文件到本地 | ||||
| 
 | ||||
| ```js | ||||
| const handleDownload = () => { | ||||
|   const url = | ||||
|     'https://circlehbsaas.oss-cn-beijing.aliyuncs.com/doc/20250506353_%E5%B0%8F%E7%A8%8B%E5%BA%8F%E6%9D%90%E6%96%99.xlsx' | ||||
|   wx.showLoading({ | ||||
|     title: '加载中', | ||||
|   }) | ||||
|   wx.downloadFile({ | ||||
|     url, | ||||
|     success(res) { | ||||
|       wx.shareFileMessage({ | ||||
|         fileName: '测试.xlsx', | ||||
|         filePath: res.tempFilePath, | ||||
|         success() { | ||||
|           wx.hideLoading() | ||||
|         }, | ||||
|       }) | ||||
|     }, | ||||
|   }) | ||||
| } | ||||
| ``` | ||||
| @ -0,0 +1,11 @@@@ -0,0 +1,11 @@ | ||||
| { | ||||
|   "plugins": [ | ||||
|     [ | ||||
|       "@babel/plugin-transform-react-jsx", | ||||
|       { | ||||
|         "runtime": "automatic", | ||||
|         "importSource": "@antv/f2" | ||||
|       } | ||||
|     ] | ||||
|   ] | ||||
| } | ||||
| @ -0,0 +1,5 @@@@ -0,0 +1,5 @@ | ||||
| cd ./src/images/ | ||||
| svn add . --no-ignore --force | ||||
| svn ci -m "版本更新" | ||||
| cd .. | ||||
| cd .. | ||||
| @ -0,0 +1,8 @@@@ -0,0 +1,8 @@ | ||||
| # Change to the src/images directory, or exit if the directory doesn't exist | ||||
| Set-Location -Path ./src/images/ -ErrorAction Stop | ||||
| 
 | ||||
| # Add all files to svn, including ignored files and forced additions | ||||
| svn add . --no-ignore --force | ||||
| 
 | ||||
| # Commit the changes with a message | ||||
| svn ci -m "版本更新" | ||||
| @ -0,0 +1,5 @@@@ -0,0 +1,5 @@ | ||||
| #!/bin/bash | ||||
| cd ./src/images/ || exit | ||||
| svn add . --no-ignore --force | ||||
| svn ci -m "版本更新" | ||||
| exit | ||||
| @ -0,0 +1,29 @@@@ -0,0 +1,29 @@ | ||||
| // eslint.config.mjs
 | ||||
| import antfu from '@antfu/eslint-config' | ||||
| import prettierConfig from 'eslint-config-prettier' | ||||
| 
 | ||||
| export default antfu( | ||||
|   { | ||||
|     env: { | ||||
|       es6: true, | ||||
|     }, | ||||
|     stylistic: false, | ||||
|     parserOptions: { project: ['./tsconfig.json'] }, | ||||
|     globals: { | ||||
|       wx: true, | ||||
|       App: true, | ||||
|       Page: true, | ||||
|       getCurrentPages: true, | ||||
|       getApp: true, | ||||
|       Component: true, | ||||
|       requirePlugin: true, | ||||
|       requireMiniProgram: true, | ||||
|     }, | ||||
|     rules: { | ||||
|       'eslint-comments/no-unlimited-disable': 'off', | ||||
|       'ts/no-require-imports': 'off', | ||||
|       eqeqeq: 'off', | ||||
|     }, | ||||
|   }, | ||||
|   prettierConfig, | ||||
| ) | ||||
| @ -0,0 +1,31 @@@@ -0,0 +1,31 @@ | ||||
| { | ||||
|   "name": "geneb", | ||||
|   "version": "1.0.0", | ||||
|   "description": "", | ||||
|   "author": "", | ||||
|   "license": "", | ||||
|   "keywords": [], | ||||
|   "scripts": { | ||||
|     "beforeCompile": "babel src/pages --out-dir src/pages --only **/*.jsx", | ||||
|     "lint:fix": "eslint . --fix" | ||||
|   }, | ||||
|   "dependencies": { | ||||
|     "@vant/weapp": "^1.11.2", | ||||
|     "dayjs": "^1.11.10", | ||||
|     "echarts": "^5.4.3", | ||||
|     "miniprogram-licia": "^1.39.2", | ||||
|     "mp-html": "^2.4.2", | ||||
|     "number-precision": "^1.6.0", | ||||
|     "typescript": "^5.3.3" | ||||
|   }, | ||||
|   "devDependencies": { | ||||
|     "@antfu/eslint-config": "^3.2.0", | ||||
|     "@babel/cli": "^7.23.4", | ||||
|     "@babel/core": "^7.23.6", | ||||
|     "@babel/plugin-transform-react-jsx": "^7.23.4", | ||||
|     "eslint": "^9.9.1", | ||||
|     "eslint-config-prettier": "^9.1.0", | ||||
|     "miniprogram-api-typings": "^3.12.2", | ||||
|     "prettier": "^3.3.3" | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,67 @@@@ -0,0 +1,67 @@ | ||||
| { | ||||
|   "description": "项目配置文件,详见文档:https://developers.weixin.qq.com/miniprogram/dev/devtools/projectconfig.html", | ||||
|   "miniprogramRoot": "src/", | ||||
|   "compileType": "miniprogram", | ||||
|   "setting": { | ||||
|     "useCompilerPlugins": [ | ||||
|       "typescript", | ||||
|       "sass" | ||||
|     ], | ||||
|     "urlCheck": true, | ||||
|     "coverView": true, | ||||
|     "es6": true, | ||||
|     "postcss": true, | ||||
|     "lazyloadPlaceholderEnable": false, | ||||
|     "preloadBackgroundData": false, | ||||
|     "minified": true, | ||||
|     "autoAudits": false, | ||||
|     "uglifyFileName": false, | ||||
|     "uploadWithSourceMap": true, | ||||
|     "enhance": true, | ||||
|     "useMultiFrameRuntime": true, | ||||
|     "showShadowRootInWxmlPanel": true, | ||||
|     "packNpmManually": true, | ||||
|     "packNpmRelationList": [ | ||||
|       { | ||||
|         "packageJsonPath": "package.json", | ||||
|         "miniprogramNpmDistDir": "./src" | ||||
|       } | ||||
|     ], | ||||
|     "minifyWXSS": true, | ||||
|     "useStaticServer": true, | ||||
|     "showES6CompileOption": false, | ||||
|     "checkInvalidKey": true, | ||||
|     "babelSetting": { | ||||
|       "ignore": [], | ||||
|       "disablePlugins": [], | ||||
|       "outputPath": "" | ||||
|     }, | ||||
|     "disableUseStrict": false, | ||||
|     "minifyWXML": true, | ||||
|     "localPlugins": false, | ||||
|     "condition": false, | ||||
|     "ignoreUploadUnusedFiles": true, | ||||
|     "compileWorklet": false, | ||||
|     "swc": false, | ||||
|     "disableSWC": true | ||||
|   }, | ||||
|   "simulatorType": "wechat", | ||||
|   "simulatorPluginLibVersion": {}, | ||||
|   "condition": {}, | ||||
|   "srcMiniprogramRoot": "src/", | ||||
|   "editorSetting": { | ||||
|     "tabIndent": "insertSpaces", | ||||
|     "tabSize": 2 | ||||
|   }, | ||||
|   "packOptions": { | ||||
|     "ignore": [], | ||||
|     "include": [] | ||||
|   }, | ||||
|   "appid": "wxa4ece062e60e93a5", | ||||
|   "scripts": { | ||||
|     "beforeCompile": "pnpm run beforeCompile", | ||||
|     "beforePreview": "pnpm run beforeCompile", | ||||
|     "beforeUpload": "pnpm run beforeCompile" | ||||
|   }, | ||||
|   "libVersion": "3.5.8" | ||||
| } | ||||
| @ -0,0 +1,24 @@@@ -0,0 +1,24 @@ | ||||
| { | ||||
|   "projectname": "GeneB-miniprogram", | ||||
|   "setting": { | ||||
|     "compileHotReLoad": true, | ||||
|     "urlCheck": false, | ||||
|     "coverView": true, | ||||
|     "lazyloadPlaceholderEnable": false, | ||||
|     "skylineRenderEnable": false, | ||||
|     "preloadBackgroundData": false, | ||||
|     "autoAudits": false, | ||||
|     "useApiHook": true, | ||||
|     "useApiHostProcess": true, | ||||
|     "showShadowRootInWxmlPanel": true, | ||||
|     "useStaticServer": true, | ||||
|     "useLanDebug": false, | ||||
|     "showES6CompileOption": false, | ||||
|     "checkInvalidKey": true, | ||||
|     "ignoreDevUnusedFiles": true, | ||||
|     "bigPackageSizeSupport": false | ||||
|   }, | ||||
|   "description": "项目私有配置文件。此文件中的内容将覆盖 project.config.json 中的相同字段。项目的改动优先同步到此文件中。详见文档:https://developers.weixin.qq.com/miniprogram/dev/devtools/projectconfig.html", | ||||
|   "condition": {}, | ||||
|   "libVersion": "3.5.8" | ||||
| } | ||||
| @ -0,0 +1,72 @@@@ -0,0 +1,72 @@ | ||||
| interface IGlobalParams { | ||||
|   gUrl: string; | ||||
|   version: string; | ||||
| } | ||||
| 
 | ||||
| export const request = function ( | ||||
|   { gUrl, version }: IGlobalParams, | ||||
|   { url, method, data, header, showMsg = true, loading = false, isJSON = false, ...options }: IAgaxParams, | ||||
| ): Promise<any> { | ||||
|   return new Promise((resolve, reject) => { | ||||
|     if (loading) { | ||||
|       wx.showLoading({ | ||||
|         title: "加载中...", | ||||
|         mask: true, | ||||
|       }); | ||||
|     } | ||||
|     wx.request({ | ||||
|       header: { | ||||
|         loginState: getApp().globalData.loginState, | ||||
|         ...header, | ||||
|       }, | ||||
|       url: gUrl + url, | ||||
|       method: method, | ||||
|       data: { | ||||
|         loginState: getApp().globalData.loginState, | ||||
|         ...(data as object), | ||||
|       }, | ||||
|       ...options, | ||||
|       success(res: any) { | ||||
|         const { code, data } = res.data; | ||||
|         if (isJSON) { | ||||
|           resolve(res.data); | ||||
|         } else if (code === 0) { | ||||
|           resolve(data); | ||||
|         } else if (showMsg) { | ||||
|           const msg = errPicker(res.data); | ||||
|           if (loading) { | ||||
|             setTimeout(() => { | ||||
|               wx.showToast({ | ||||
|                 title: msg, | ||||
|                 icon: "none", | ||||
|               }); | ||||
|             }, 30); | ||||
|           } else { | ||||
|             wx.showToast({ | ||||
|               title: msg, | ||||
|               icon: "none", | ||||
|             }); | ||||
|             reject(res); | ||||
|           } | ||||
|         } else { | ||||
|           reject(res); | ||||
|         } | ||||
|       }, | ||||
|       fail(err) { | ||||
|         reject(err); | ||||
|       }, | ||||
|       complete() { | ||||
|         if (loading) { | ||||
|           wx.hideLoading(); | ||||
|         } | ||||
|       }, | ||||
|     }); | ||||
|   }); | ||||
| }; | ||||
| 
 | ||||
| function errPicker(err) { | ||||
|   if (typeof err === "string") { | ||||
|     return err; | ||||
|   } | ||||
|   return err.data || err.msg || err.errMsg || (err.detail && err.detail.errMsg) || "未知错误"; | ||||
| } | ||||
| @ -0,0 +1,36 @@@@ -0,0 +1,36 @@ | ||||
| { | ||||
|   "$schema": "https://dldir1.qq.com/WechatWebDev/editor-extension/wx-json/app.schema.json", | ||||
|   "pages": ["pages/index/index", "pages/my/index"], | ||||
|   "tabBar": { | ||||
|     "custom": true, | ||||
|     "list": [ | ||||
|       { | ||||
|         "pagePath": "pages/index/index", | ||||
|         "text": "首页" | ||||
|       }, | ||||
|       { | ||||
|         "pagePath": "pages/my/index", | ||||
|         "text": "我的" | ||||
|       } | ||||
|     ] | ||||
|   }, | ||||
|   "window": { | ||||
|     "backgroundTextStyle": "light", | ||||
|     "navigationBarBackgroundColor": "#fff", | ||||
|     "navigationBarTitleText": "Weixin", | ||||
|     "navigationBarTextStyle": "black" | ||||
|   }, | ||||
|   "sitemapLocation": "sitemap.json", | ||||
|   "resolveAlias": { | ||||
|     "@/*": "/*" | ||||
|   }, | ||||
|   "usingComponents": { | ||||
|     "pagination": "/components/pagination/index" | ||||
|   }, | ||||
|   "requiredPrivateInfos": ["getFuzzyLocation"], | ||||
|   "permission": { | ||||
|     "scope.userFuzzyLocation": { | ||||
|       "desc": "获取您的当前位置,用于模糊匹配您附近的活动" | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,88 @@@@ -0,0 +1,88 @@ | ||||
| .page-meat { | ||||
|   background-repeat: no-repeat; | ||||
| } | ||||
| .van-tabbar { | ||||
|   background: rgba(255, 255, 255, 0.8); | ||||
|   box-shadow: 0rpx 4rpx 12rpx 0rpx rgba(0, 0, 0, 0.12); | ||||
| } | ||||
| 
 | ||||
| .van-tabbar-item__icon { | ||||
|   margin-bottom: 0 !important; | ||||
| } | ||||
| 
 | ||||
| .clearfix:after { | ||||
|   content: "020"; | ||||
|   display: block; | ||||
|   height: 0; | ||||
|   clear: both; | ||||
|   visibility: hidden; | ||||
| } | ||||
| 
 | ||||
| .clearfix { | ||||
|   /* 触发 hasLayout */ | ||||
|   zoom: 1; | ||||
| } | ||||
| 
 | ||||
| .scroll::-webkit-scrollbar { | ||||
|   width: 0; | ||||
|   height: 0; | ||||
|   color: transparent; | ||||
| } | ||||
| 
 | ||||
| .theme1 { | ||||
|   --name: #fff; | ||||
| } | ||||
| 
 | ||||
| .theme2 { | ||||
|   --name: #000; | ||||
| } | ||||
| 
 | ||||
| .van-hairline--bottom:after { | ||||
|   border-bottom-width: 0px !important; | ||||
| } | ||||
| 
 | ||||
| .extend-via-pseudo-elem { | ||||
|   position: relative; | ||||
|   overflow: visible; | ||||
|   &::before { | ||||
|     content: ""; | ||||
|     position: absolute; | ||||
|     top: -20rpx; | ||||
|     right: -20rpx; | ||||
|     bottom: -20rpx; | ||||
|     left: -20rpx; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| view { | ||||
|   word-break: break-all; | ||||
| } | ||||
| .mp-html { | ||||
|   video { | ||||
|     // width: 100% !important; | ||||
|     // object-fit: contain !important; | ||||
|     // max-height: 350rpx; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .van-tabbar { | ||||
|   display: flex; | ||||
|   justify-content: space-around; | ||||
|   .van-tabbar-item { | ||||
|   } | ||||
|   [is="miniprogram_npm/@vant/weapp/tabbar-item/index"] { | ||||
|     flex: none !important; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| // .tab-item:first-of-type, | ||||
| // .tab-item:last-of-type { | ||||
| //   .van-tabbar-item { | ||||
| //     width: 2em; | ||||
| //   } | ||||
| // } | ||||
| 
 | ||||
| 
 | ||||
| .pre-line{ | ||||
|   white-space: pre-line; | ||||
| } | ||||
| @ -0,0 +1,566 @@@@ -0,0 +1,566 @@ | ||||
| /* eslint-disable */ | ||||
| // app.ts
 | ||||
| import { request } from './api/request' | ||||
| import { parseScene } from './utils/util' | ||||
| const licia = require('miniprogram-licia') | ||||
| 
 | ||||
| const dayjs = require('dayjs') | ||||
| require('/utils/dayjs/day-zh-cn.js') | ||||
| const relativeTime = require('/utils/dayjs/relativeTime.js') | ||||
| dayjs.locale('zh-cn') // 全局使用
 | ||||
| dayjs.extend(relativeTime) | ||||
| 
 | ||||
| // page
 | ||||
| import page from '@/utils/page' | ||||
| 
 | ||||
| App<IAppOption>({ | ||||
|   globalData: { | ||||
|     // dev
 | ||||
|     // appid:wxa4ece062e60e93a5
 | ||||
|     url: 'https://m.zd.hbraas.com', | ||||
|     upFileUrl: 'https://m.zd.hbraas.com/', | ||||
|     imageUrl: 'https://m.zd.hbraas.com/zd/', | ||||
| 
 | ||||
|     // pro
 | ||||
|     // appid:wx96f45ca4f1fa36ec
 | ||||
|     // url: 'https://m.zd.hbsaas.com',
 | ||||
|     // upFileUrl: 'https://m.zd.hbsaas.com/',
 | ||||
|     // imageUrl: 'https://m.zd.hbsaas.com/zd/',
 | ||||
|     //
 | ||||
|     //login
 | ||||
|     registrationSource: 0, | ||||
|     registChannel: 0, | ||||
|     regBusinessId: '', | ||||
|     IsAliQiWei: 0, | ||||
| 
 | ||||
|     scene: {}, | ||||
|     listeners: [], | ||||
| 
 | ||||
|     Timestamp: new Date().getTime(), | ||||
|     loginState: '', | ||||
|     isLogin: 0, // 0 未登录 1 已登录
 | ||||
|     isReg: '0', | ||||
|     WorkerId: '', | ||||
|     loginType: '', // 1:患者  2:医生
 | ||||
| 
 | ||||
|     first: true, | ||||
|     // anyWhere: true,
 | ||||
|     anyWhere: false, | ||||
| 
 | ||||
|     userInfo: {}, | ||||
|   }, | ||||
|   onLaunch() { | ||||
|     // if (options.path) {
 | ||||
|     //   this.globalData.anyWhere = true;
 | ||||
|     // }
 | ||||
|     Page = page as WechatMiniprogram.Page.Constructor | ||||
| 
 | ||||
|     wx.ajax = licia.curry(request)({ gUrl: this.globalData.url }) | ||||
| 
 | ||||
|     this.autoUpdate() | ||||
| 
 | ||||
|     wx.setInnerAudioOption({ | ||||
|       obeyMuteSwitch: false, | ||||
|       mixWithOther: false, | ||||
|     }) | ||||
|   }, | ||||
|   onShow(options) { | ||||
|     if (options.query.scene) { | ||||
|       this.globalData.anyWhere = false | ||||
|       this.globalData.scene = parseScene(options.query.scene) as { workerId: string } | ||||
|     } | ||||
|     // this.startLogin()
 | ||||
|   }, | ||||
|   startLogin() { | ||||
|     const that = this | ||||
|     wx.login({ | ||||
|       success(res) { | ||||
|         wx.ajax({ | ||||
|           method: 'GET', | ||||
|           url: '?r=zd/user/init-login', | ||||
|           data: { | ||||
|             code: res.code, | ||||
|           }, | ||||
|         }).then((res) => { | ||||
|           that.globalData.loginState = res.loginState | ||||
|           that.globalData.isReg = res.isReg | ||||
|           that.globalData.isLogin = res.isLogin | ||||
|           that.globalData.loginType = res.loginType | ||||
|           if (!Object.keys(that.globalData.scene)?.length) { | ||||
|             that.globalData.anyWhere = res.anyWhere | ||||
|           } | ||||
|           if (wx.getLaunchOptionsSync()?.query?.activity === 'NRDL') { | ||||
|             that.clickPush() | ||||
|           } | ||||
|           that.getUserInfo() | ||||
|         }) | ||||
|       }, | ||||
|     }) | ||||
|   }, | ||||
|   waitLogin({ isReg = true, loginPage = false } = { isReg: true, loginPage: false }) { | ||||
|     let time: number | ||||
|     const regFun = (resolve) => { | ||||
|       if (this.verifySys()) { | ||||
|         if (this.globalData.loginType === 1) { | ||||
|           this.registrationVerification(() => resolve(), loginPage) | ||||
|         } else { | ||||
|           resolve() | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|     const unRegFun = (resolve) => { | ||||
|       if (!this.verifySys(isReg)) return | ||||
|       resolve() | ||||
|     } | ||||
|     return new Promise((resolve: (value?) => void) => { | ||||
|       if (isReg) { | ||||
|         if (Object.keys(this.globalData.userInfo).length) { | ||||
|           regFun(resolve) | ||||
|           return | ||||
|         } | ||||
|         time = setInterval(() => { | ||||
|           if (Object.keys(this.globalData.userInfo).length) { | ||||
|             clearInterval(time) | ||||
|             regFun(resolve) | ||||
|           } | ||||
|         }, 500) | ||||
|         return | ||||
|       } | ||||
|       this.globalData.anyWhere = true | ||||
|       if (this.globalData.loginState) { | ||||
|         unRegFun(resolve) | ||||
|         return | ||||
|       } | ||||
|       time = setInterval(() => { | ||||
|         if (this.globalData.loginState) { | ||||
|           clearInterval(time) | ||||
|           unRegFun(resolve) | ||||
|         } | ||||
|       }, 500) | ||||
|     }) | ||||
|   }, | ||||
|   registrationVerification(callback: () => void, loginPage = false) { | ||||
|     // 1-空白用户,2-注册用户,3-疾病患者,4-用药患者
 | ||||
|     const { PatientId, AuditStatus, isFollow, UserType } = this.globalData.userInfo | ||||
|     const { anyWhere, first } = this.globalData | ||||
| 
 | ||||
|     if (loginPage || (anyWhere && first)) { | ||||
|       callback() | ||||
|       return | ||||
|     } | ||||
| 
 | ||||
|     if (UserType == 4) { | ||||
|       this.globalData.first = false | ||||
|       callback() | ||||
|       return | ||||
|     } | ||||
| 
 | ||||
|     if (UserType == 1) { | ||||
|       this.globalData.registChannel = 0 | ||||
|       this.globalData.first = false | ||||
|       wx.reLaunch({ | ||||
|         url: '/pages/login/index', | ||||
|       }) | ||||
|       return | ||||
|     } | ||||
| 
 | ||||
|     let urlKey = '' | ||||
|     if (!PatientId) { | ||||
|       urlKey = 'enterInfo' | ||||
|     } else if (AuditStatus == 0) { | ||||
|       urlKey = 'noCert' | ||||
|     } else if (AuditStatus == 1) { | ||||
|       urlKey = isFollow ? 'nopending' : 'pending' | ||||
|     } else if (AuditStatus == 2) { | ||||
|       urlKey = 'reject' | ||||
|     } | ||||
|     let navUrl = { | ||||
|       enterInfo: '/pages/enterInfo/index', | ||||
|       noCert: '/pages/enterInfo/index', | ||||
|       reject: '/pages/enterInfo/index', | ||||
|       pending: '/pages/enterInfo/index', | ||||
|       nopending: '/pages/enterInfo/index', | ||||
|     }[urlKey] | ||||
| 
 | ||||
|     if (navUrl && first) { | ||||
|       this.globalData.registChannel = 0 | ||||
|       this.globalData.first = false | ||||
|       wx.reLaunch({ | ||||
|         url: navUrl, | ||||
|       }) | ||||
|       this.globalData.first = false | ||||
|       return | ||||
|     } | ||||
| 
 | ||||
|     this.globalData.first = false | ||||
|     callback() | ||||
|   }, | ||||
|   verifySys() { | ||||
|     // 1:患者  2:医生
 | ||||
|     const { loginType, isLogin, anyWhere } = this.globalData | ||||
|     const pages = getCurrentPages() | ||||
|     const currentPage = pages[pages.length - 1] | ||||
|     const url = currentPage.route | ||||
|     const options = currentPage.options | ||||
|     const ignorePath = ['pages/start/index'] | ||||
| 
 | ||||
|     // 未登录用户
 | ||||
|     if (!isLogin) { | ||||
|       // 医生端页面重定向到医生端登录页
 | ||||
|       if (url.includes('doctor/pages')) { | ||||
|         wx.reLaunch({ | ||||
|           url: '/doctor/pages/d_login/index', | ||||
|         }) | ||||
|         return false | ||||
|       } | ||||
|       // 患者端随便看看
 | ||||
|       if (anyWhere) { | ||||
|         return true | ||||
|       } | ||||
|       wx.reLaunch({ | ||||
|         url: '/pages/login/index', | ||||
|       }) | ||||
|       return false | ||||
|     } | ||||
|     if (ignorePath.includes(url)) return true | ||||
| 
 | ||||
|     if (loginType === 1) { | ||||
|       if (url.includes('doctor/pages')) { | ||||
|         wx.reLaunch({ | ||||
|           url: '/pages/index/index', | ||||
|         }) | ||||
|         return false | ||||
|       } else { | ||||
|         return true | ||||
|       } | ||||
|     } | ||||
|     if (loginType === 2) { | ||||
|       if (url.includes('doctor/pages')) { | ||||
|         return true | ||||
|       } else { | ||||
|         const params = Object.entries(options) | ||||
|           .map(([key, value]) => `${key}=${value}`) | ||||
|           .join('&') | ||||
|         wx.reLaunch({ | ||||
|           url: '/doctor/pages/d_trans/index?path=' + encodeURIComponent(`/${url}?${params}`), | ||||
|         }) | ||||
|         return false | ||||
|       } | ||||
|     } | ||||
|     return true | ||||
|   }, | ||||
|   permissionVerification(grade = 1, registChannel = 0, backPage = null, regBusinessId = '') { | ||||
|     // 1-空白用户,2-注册用户,3-疾病患者,4-用药患者
 | ||||
|     const { PatientId, AuditStatus, isFollow, UserType } = this.globalData.userInfo | ||||
|     const that = this | ||||
|     this.globalData.registChannel = registChannel | ||||
|     this.globalData.regBusinessId = regBusinessId | ||||
|     let isReject = false | ||||
|     return new Promise((resolve, reject) => { | ||||
|       if (grade == 2 && Number(UserType) < 2) { | ||||
|         wx.reLaunch({ | ||||
|           url: '/pages/login/index', | ||||
|         }) | ||||
|         isReject = true | ||||
|       } | ||||
|       if (grade == 3 && Number(UserType) < 3) { | ||||
|         if (UserType == 1) { | ||||
|           wx.reLaunch({ | ||||
|             url: '/pages/login/index', | ||||
|           }) | ||||
|           isReject = true | ||||
|         } | ||||
|         if (UserType == 2) { | ||||
|           let urlKey = '' | ||||
|           if (!PatientId) { | ||||
|             urlKey = 'enterInfo' | ||||
|           } else if (AuditStatus == 0) { | ||||
|             urlKey = 'noCert' | ||||
|           } else if (AuditStatus == 1) { | ||||
|             if (backPage && (backPage as string).includes('liveResult')) { | ||||
|               urlKey = 'liveResult' | ||||
|             } else { | ||||
|               urlKey = isFollow ? 'nopending' : 'pending' | ||||
|             } | ||||
|           } else if (AuditStatus == 2) { | ||||
|             urlKey = 'reject' | ||||
|           } | ||||
|           let navUrl = { | ||||
|             enterInfo: '/pages/enterInfo/index', | ||||
|             noCert: '/pages/enterInfo/index', | ||||
|             reject: '/pages/enterInfo/index', | ||||
|             pending: '/pages/enterInfo/index', | ||||
|             nopending: '/pages/enterInfo/index', | ||||
|             liveResult: backPage, | ||||
|           }[urlKey] | ||||
|           if (urlKey == 'liveResult') { | ||||
|             wx.navigateTo({ | ||||
|               url: navUrl as string, | ||||
|             }) | ||||
|           } else { | ||||
|             wx.reLaunch({ | ||||
|               url: navUrl as string, | ||||
|             }) | ||||
|           } | ||||
|           isReject = true | ||||
|         } | ||||
|       } | ||||
|       if (grade == 4 && Number(UserType) < 4) { | ||||
|         wx.reLaunch({ | ||||
|           url: '/pages/vipLogin/index', | ||||
|         }) | ||||
|         isReject = true | ||||
|       } | ||||
|       if (isReject) { | ||||
|         that.globalData.backPage = backPage | ||||
|         reject(null) | ||||
|         return | ||||
|       } | ||||
|       resolve(null) | ||||
|     }) | ||||
|   }, | ||||
|   getUserInfo(self, update = false, callback = (_userInfo) => {}) { | ||||
|     if (this.globalData.userInfo?.UserId && !update) { | ||||
|       self?.setData({ | ||||
|         userInfo: this.globalData.userInfo, | ||||
|       }) | ||||
|       callback(this.globalData.userInfo) | ||||
|       return | ||||
|     } | ||||
|     wx.ajax({ | ||||
|       method: 'GET', | ||||
|       url: '?r=zd/account/info', | ||||
|       showMsg: false, | ||||
|     }).then((res) => { | ||||
|       res.UserType = res.UserType || 1 | ||||
|       if (res.UserType > 2) { | ||||
|         this.globalData.anyWhere = false | ||||
|       } | ||||
|       this.globalData.userInfo = res | ||||
|       this.triggerListeners() | ||||
|       self?.setData({ | ||||
|         userInfo: res, | ||||
|       }) | ||||
|       const { doctorId, inviteChan } = this.globalData.scene | ||||
|       if (doctorId && res.InviteDoctorId != doctorId && this.globalData.isLogin && res.PatientId) { | ||||
|         wx.ajax({ | ||||
|           method: 'POST', | ||||
|           url: '?r=zd/account/update-doctor', | ||||
|           data: { | ||||
|             inviteDoctorId: doctorId, | ||||
|             inviteChannel: inviteChan, | ||||
|           }, | ||||
|         }) | ||||
|       } | ||||
|       callback(res) | ||||
|     }) | ||||
|   }, | ||||
|   mpBehavior(data: { PageName: string; doctor?: boolean }) { | ||||
|     let url = '?r=zd/mp-behavior/add' | ||||
|     if (data.doctor) { | ||||
|       url = '?r=zd/doctor/mp-behavior/add' | ||||
|     } | ||||
|     delete data.doctor | ||||
|     wx.ajax({ | ||||
|       method: 'POST', | ||||
|       url, | ||||
|       data: data, | ||||
|       loading: false, | ||||
|       showMsg: false, | ||||
|     }).then((res) => { | ||||
|       console.log('res: ', res) | ||||
|     }) | ||||
|   }, | ||||
| 
 | ||||
|   // 更新用户信息
 | ||||
|   async updateUserInfo(encryptedData, iv) { | ||||
|     let loginState = this.globalData.loginState | ||||
|     const encodeEncryptedData = encodeURIComponent(encryptedData) | ||||
|     const encodeIv = encodeURIComponent(iv) | ||||
|     const { | ||||
|       data: { code, msg }, | ||||
|     } = await wx.ajax({ | ||||
|       method: 'POST', | ||||
|       url: '?r=eyecare/user/update-wx-user-info', | ||||
|       data: { | ||||
|         loginState, | ||||
|         encryptedData: encodeEncryptedData, | ||||
|         iv: encodeIv, | ||||
|       }, | ||||
|     }) | ||||
|     if (code !== 0) { | ||||
|       wx.showToast({ | ||||
|         duration: 1500, | ||||
|         title: msg, | ||||
|         icon: 'none', | ||||
|       }) | ||||
|     } | ||||
|     return code | ||||
|   }, | ||||
|   getCode() { | ||||
|     return new Promise((resolve) => { | ||||
|       wx.login({ | ||||
|         success: (res) => { | ||||
|           resolve(res.code) | ||||
|         }, | ||||
|         fail: () => { | ||||
|           wx.showToast({ | ||||
|             duration: 10000, | ||||
|             title: '发生错误请重试', | ||||
|             icon: 'none', | ||||
|           }) | ||||
|         }, | ||||
|       }) | ||||
|     }) | ||||
|   }, | ||||
|   // 微信登录
 | ||||
|   doLogin() { | ||||
|     return new Promise((resolve) => { | ||||
|       wx.showLoading({ | ||||
|         title: '加载中...', | ||||
|         mask: true, | ||||
|       }) | ||||
|       this.getCode().then((code) => { | ||||
|         wx.ajax({ | ||||
|           url: '?r=eyecare/user/init-login', | ||||
|           data: { | ||||
|             code, | ||||
|           }, | ||||
|         }).then((res) => { | ||||
|           if (res.data.code === 0) { | ||||
|             resolve(res) | ||||
|           } | ||||
|         }) | ||||
|       }) | ||||
|     }) | ||||
|   }, | ||||
|   clickPush() { | ||||
|     wx.ajax({ | ||||
|       method: 'POST', | ||||
|       url: '?r=zd/nrdl/add-push-click-record', | ||||
|     }) | ||||
|   }, | ||||
|   watch: function (key, method) { | ||||
|     var obj = this.globalData | ||||
|     //加个前缀生成隐藏变量,防止死循环发生
 | ||||
|     let ori = obj[key] //obj[key]这个不能放在Object.defineProperty里
 | ||||
|     if (ori) { | ||||
|       //处理已经声明的变量,绑定处理
 | ||||
|       method(ori) | ||||
|     } | ||||
|     Object.defineProperty(obj, key, { | ||||
|       configurable: true, | ||||
|       enumerable: true, | ||||
|       set: function (value) { | ||||
|         this['_' + key] = value | ||||
|         console.log('是否会被执行2') | ||||
|         method(value) | ||||
|       }, | ||||
|       get: function () { | ||||
|         // 在其它界面调用key值的时候,这里就会执行。
 | ||||
|         if (typeof this['_' + key] == 'undefined') { | ||||
|           if (ori) { | ||||
|             //这里读取数据的时候隐藏变量和 globalData设置不一样,所以要做同步处理
 | ||||
|             this['_' + key] = ori | ||||
|             return ori | ||||
|           } else { | ||||
|             return undefined | ||||
|           } | ||||
|         } else { | ||||
|           return this['_' + key] | ||||
|         } | ||||
|       }, | ||||
|     }) | ||||
|   }, | ||||
|   // 注册监听器函数的方法
 | ||||
|   registerListener: function (listener: () => {}) { | ||||
|     this.globalData.listeners.push(listener) | ||||
|   }, | ||||
|   // 触发监听器函数的方法
 | ||||
|   triggerListeners: function () { | ||||
|     var listeners = this.globalData.listeners | ||||
|     for (var i = 0; i < listeners.length; i++) { | ||||
|       listeners[i]() | ||||
|     } | ||||
|   }, | ||||
|   autoUpdate: function () { | ||||
|     var self = this | ||||
|     // 获取小程序更新机制兼容
 | ||||
|     if (wx.canIUse('getUpdateManager')) { | ||||
|       const updateManager = wx.getUpdateManager() | ||||
|       //1. 检查小程序是否有新版本发布
 | ||||
|       updateManager.onCheckForUpdate(function (res) { | ||||
|         // 请求完新版本信息的回调
 | ||||
|         if (res.hasUpdate) { | ||||
|           //检测到新版本,需要更新,给出提示
 | ||||
|           wx.showModal({ | ||||
|             title: '更新提示', | ||||
|             content: '检测到新版本,是否下载新版本并重启小程序?', | ||||
|             success: function (res) { | ||||
|               if (res.confirm) { | ||||
|                 //2. 用户确定下载更新小程序,小程序下载及更新静默进行
 | ||||
|                 self.downLoadAndUpdate(updateManager) | ||||
|               } else if (res.cancel) { | ||||
|                 //用户点击取消按钮的处理,如果需要强制更新,则给出二次弹窗,如果不需要,则这里的代码都可以删掉了
 | ||||
|                 wx.showModal({ | ||||
|                   title: '温馨提示~', | ||||
|                   content: '本次版本更新涉及到新的功能添加,旧版本无法正常访问的哦~', | ||||
|                   showCancel: false, //隐藏取消按钮
 | ||||
|                   confirmText: '确定更新', //只保留确定更新按钮
 | ||||
|                   success: function (res) { | ||||
|                     if (res.confirm) { | ||||
|                       //下载新版本,并重新应用
 | ||||
|                       self.downLoadAndUpdate(updateManager) | ||||
|                     } | ||||
|                   }, | ||||
|                 }) | ||||
|               } | ||||
|             }, | ||||
|           }) | ||||
|         } | ||||
|       }) | ||||
|     } else { | ||||
|       // 如果希望用户在最新版本的客户端上体验您的小程序,可以这样子提示
 | ||||
|       wx.showModal({ | ||||
|         title: '提示', | ||||
|         content: '当前微信版本过低,无法使用该功能,请升级到最新微信版本后重试。', | ||||
|       }) | ||||
|     } | ||||
|   }, | ||||
|   downLoadAndUpdate: function (updateManager) { | ||||
|     //静默下载更新小程序新版本
 | ||||
|     updateManager.onUpdateReady(function () { | ||||
|       wx.hideLoading() | ||||
|       //新的版本已经下载好,调用 applyUpdate 应用新版本并重启
 | ||||
|       updateManager.applyUpdate() | ||||
|     }) | ||||
|     updateManager.onUpdateFailed(function () { | ||||
|       // 新的版本下载失败
 | ||||
|       wx.showModal({ | ||||
|         title: '新版本更新失败', | ||||
|         content: '您可删除当前小程序,重新打开尝试', | ||||
|       }) | ||||
|     }) | ||||
|   }, | ||||
|   getTheme() { | ||||
|     return new Promise((resolve) => { | ||||
|       const checkUserType = () => { | ||||
|         const userInfo = this.globalData.userInfo | ||||
|         if (userInfo.UserType) { | ||||
|           // resolve(userInfo.UserType >= 4 ? 'DRUG' : 'PATIENT')
 | ||||
|           resolve('PATIENT') | ||||
|           return true | ||||
|         } | ||||
|         return false | ||||
|       } | ||||
| 
 | ||||
|       const tryResolve = () => { | ||||
|         if (!checkUserType()) { | ||||
|           setTimeout(tryResolve, 30) | ||||
|         } | ||||
|       } | ||||
| 
 | ||||
|       tryResolve() | ||||
|     }) | ||||
|   }, | ||||
| }) | ||||
| @ -0,0 +1,6 @@@@ -0,0 +1,6 @@ | ||||
| { | ||||
|   "component": true, | ||||
|   "usingComponents": { | ||||
|     "van-nav-bar": "@vant/weapp/nav-bar/index" | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,31 @@@@ -0,0 +1,31 @@ | ||||
| const _app = getApp<IAppOption>() | ||||
| 
 | ||||
| Component({ | ||||
|   properties: { | ||||
|     title: String, | ||||
|     fixed: Boolean, | ||||
|     placeholder: Boolean, | ||||
|     leftText: String, | ||||
|     rightText: String, | ||||
|     customStyle: String, | ||||
|     leftArrow: Boolean, | ||||
|     border: { | ||||
|       type: Boolean, | ||||
|       value: false, | ||||
|     }, | ||||
|     zIndex: { | ||||
|       type: Number, | ||||
|       value: 1, | ||||
|     }, | ||||
|   }, | ||||
| 
 | ||||
|   /** | ||||
|    * 组件的初始数据 | ||||
|    */ | ||||
|   data: {}, | ||||
| 
 | ||||
|   /** | ||||
|    * 组件的方法列表 | ||||
|    */ | ||||
|   methods: {}, | ||||
| }) | ||||
| @ -0,0 +1,15 @@@@ -0,0 +1,15 @@ | ||||
| <van-nav-bar | ||||
|   title="{{title === 'slot' ? '' : title}}" | ||||
|   fixed="{{fixed}}" | ||||
|   placeholder="{{placeholder}}" | ||||
|   leftText="{{leftText === 'slot' ? '' : leftText}}" | ||||
|   rightText="{{rightText === 'slot' ? '' : rightText}}" | ||||
|   customStyle="{{customStyle}}" | ||||
|   leftArrow="{{leftArrow}}" | ||||
|   border="{{border}}" | ||||
|   zIndex="{{zIndex}}" | ||||
| > | ||||
|   <slot wx:if="{{title==='slot'}}" slot="title"></slot> | ||||
|   <slot wx:if="{{leftText==='slot'}}" slot="left"></slot> | ||||
|   <slot wx:if="{{rightText==='slot'}}" slot="right"></slot> | ||||
| </van-nav-bar> | ||||
| @ -0,0 +1,20 @@@@ -0,0 +1,20 @@ | ||||
| const app = getApp(); | ||||
| 
 | ||||
| Component({ | ||||
|   properties: { | ||||
|     pagination: { | ||||
|       type: Object, | ||||
|       value() { | ||||
|         return {}; | ||||
|       }, | ||||
|     }, | ||||
|   }, | ||||
|   data: { | ||||
|     imageUrl: app.globalData.imageUrl, | ||||
|   }, | ||||
|   methods: { | ||||
|     handleTouchmove() { | ||||
|       return false; | ||||
|     }, | ||||
|   }, | ||||
| }); | ||||
| @ -0,0 +1,6 @@@@ -0,0 +1,6 @@ | ||||
| { | ||||
|   "component": true, | ||||
|   "usingComponents": { | ||||
|     "van-divider": "@vant/weapp/divider/index" | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,6 @@@@ -0,0 +1,6 @@ | ||||
| /* components/pagination/index.wxss */ | ||||
| .none { | ||||
|   display: block; | ||||
|   margin: 30rpx auto; | ||||
|   width: 80%; | ||||
| } | ||||
| @ -0,0 +1,6 @@@@ -0,0 +1,6 @@ | ||||
| <image class="none" src="{{imageUrl}}none.png" wx:if="{{pagination.count==0}}"></image> | ||||
| <van-divider contentPosition="center" wx:elif="{{pagination.page<pagination.pages}}"> | ||||
|   <van-loading /> | ||||
|   加载中... | ||||
| </van-divider> | ||||
| <van-divider contentPosition="center" wx:elif="{{pagination.page>=pagination.pages}}">没有更多了</van-divider> | ||||
| @ -0,0 +1,6 @@@@ -0,0 +1,6 @@ | ||||
| { | ||||
|   "component": true, | ||||
|   "usingComponents": { | ||||
|     "van-popup": "@vant/weapp/popup/index" | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,51 @@@@ -0,0 +1,51 @@ | ||||
| .popup1 { | ||||
|   padding: 84rpx 60rpx; | ||||
|   background: linear-gradient(6deg, #ffffff 0%, #ffe6e4 100%); | ||||
|   .logo { | ||||
|     display: block; | ||||
|     margin: 0 auto; | ||||
|     width: 164rpx; | ||||
|     height: 164rpx; | ||||
|   } | ||||
|   .title { | ||||
|     margin-top: 32rpx; | ||||
|     font-size: 48rpx; | ||||
|     color: #f23a2f; | ||||
|     font-weight: bold; | ||||
|   } | ||||
|   .conent { | ||||
|     margin-top: 30rpx; | ||||
|     font-size: 32rpx; | ||||
|     color: #010105; | ||||
|     line-height: 52rpx; | ||||
|   } | ||||
|   .check { | ||||
|     margin-top: 64rpx; | ||||
|     font-size: 32rpx; | ||||
|     color: rgba(1, 1, 5, 0.3); | ||||
|     .checkbox { | ||||
|       transform: scale(0.8); | ||||
|     } | ||||
|   } | ||||
|   .link { | ||||
|     color: #f23a2f; | ||||
|   } | ||||
|   .btn1 { | ||||
|     margin-top: 40rpx; | ||||
|     height: 84rpx; | ||||
|     border-radius: 84rpx; | ||||
|     font-size: 32rpx; | ||||
|     color: #ffffff; | ||||
|     text-align: center; | ||||
|     line-height: 84rpx; | ||||
|     background: linear-gradient(356deg, #f23a2f 0%, #fc684f 100%); | ||||
|   } | ||||
|   .btn2 { | ||||
|     margin-top: 20rpx; | ||||
|     height: 84rpx; | ||||
|     text-align: center; | ||||
|     line-height: 84rpx; | ||||
|     font-size: 32rpx; | ||||
|     color: rgba(1, 1, 5, 0.4); | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,33 @@@@ -0,0 +1,33 @@ | ||||
| const _app = getApp<IAppOption>() | ||||
| 
 | ||||
| Component({ | ||||
|   properties: { | ||||
|     show: { | ||||
|       type: Boolean, | ||||
|       value: false, | ||||
|     }, | ||||
|     type: String, | ||||
|     params: { | ||||
|       type: Object, | ||||
|       value() { | ||||
|         return {} | ||||
|       }, | ||||
|     }, | ||||
|   }, | ||||
| 
 | ||||
|   data: {}, | ||||
|   methods: { | ||||
|     handleOk() { | ||||
|       this.setData({ | ||||
|         show: false, | ||||
|       }) | ||||
|       this.triggerEvent('ok') | ||||
|     }, | ||||
|     handleCancel() { | ||||
|       this.setData({ | ||||
|         show: false, | ||||
|       }) | ||||
|       this.triggerEvent('cancel') | ||||
|     }, | ||||
|   }, | ||||
| }) | ||||
| @ -0,0 +1,25 @@@@ -0,0 +1,25 @@ | ||||
| <van-popup | ||||
|   bind:click-overlay="handleCancel" | ||||
|   round | ||||
|   z-index="{{100000}}" | ||||
|   show="{{ show }}" | ||||
|   catch:touchstart | ||||
|   position="{{params.position || 'center'}}" | ||||
| > | ||||
|   <view class="popup1" wx:if="{{type==='argument'}}"> | ||||
|     <image class="logo" src="/images/logo1.png"></image> | ||||
|     <view class="title">欢迎加入“向光而行”</view> | ||||
|     <view class="content"> | ||||
|       亲爱的用户,为了更好地向您提供平台服务保护您的权益,我们完善了 | ||||
|       <text class="link">《个人信息及隐私政策》</text> | ||||
|       ,请您仔细阅读。一旦您开始使用,即表示您已充分理解并同意协议内容。 | ||||
|     </view> | ||||
|     <view class="check"> | ||||
|       <checkbox class="checkbox"></checkbox> | ||||
|       我已阅读并同意 | ||||
|       <text class="link">《个人信息及隐私政策》</text> | ||||
|     </view> | ||||
|     <view class="btn1">同意并继续</view> | ||||
|     <view class="btn2">不同意</view> | ||||
|   </view> | ||||
| </van-popup> | ||||
| @ -0,0 +1,7 @@@@ -0,0 +1,7 @@ | ||||
| { | ||||
|   "component": true, | ||||
|   "usingComponents": { | ||||
|     "van-tabbar": "@vant/weapp/tabbar/index", | ||||
|     "van-tabbar-item": "@vant/weapp/tabbar-item/index" | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,19 @@@@ -0,0 +1,19 @@ | ||||
| /* custom-tab-bar/index.wxss */ | ||||
| 
 | ||||
| 
 | ||||
| .tab-item { | ||||
|   .icon { | ||||
|     width: 50rpx; | ||||
|     height: 50rpx; | ||||
|   } | ||||
|   .name { | ||||
|     font-size: 24rpx; | ||||
|     color: #010105; | ||||
|     &.active{ | ||||
|       color: #F23A2F; | ||||
|     } | ||||
|     &.drug-active{ | ||||
|       color: #25D9C8; | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,53 @@@@ -0,0 +1,53 @@ | ||||
| import { getCurrentPageUrl } from '@/utils/util' | ||||
| const app = getApp() | ||||
| 
 | ||||
| Component({ | ||||
|   properties: {}, | ||||
|   data: { | ||||
|     imageUrl: app.globalData.imageUrl, | ||||
|     isChild: 0, | ||||
|     active: 0, | ||||
|     list: [ | ||||
|       { | ||||
|         pagePath: '/pages/index/index', | ||||
|         text: '首页', | ||||
|         icon: 'tabbar1-1', | ||||
|         iconActive: 'tabbar1-1-active', | ||||
|       }, | ||||
|       { | ||||
|         pagePath: '/pages/repository/index', | ||||
|         text: 'MG全知道', | ||||
|         icon: 'tabbar1-2', | ||||
|         iconActive: 'tabbar1-2-active', | ||||
|       }, | ||||
|       { | ||||
|         pagePath: '/pages/my/index', | ||||
|         text: '我的', | ||||
|         icon: 'tabbar1-2', | ||||
|         iconActive: 'tabbar1-3-active', | ||||
|       }, | ||||
|     ], | ||||
|   }, | ||||
|   observers: {}, | ||||
|   lifetimes: { | ||||
|     ready() { | ||||
|       const pagePath = getCurrentPageUrl() | ||||
|       const active = this.data.list.findIndex((item) => item.pagePath === pagePath) | ||||
|       this.setData({ | ||||
|         active, | ||||
|         anyWhere: app.globalData.anyWhere, | ||||
|       }) | ||||
|     }, | ||||
|   }, | ||||
|   methods: { | ||||
|     onChange() {}, | ||||
|     handleNav(e) { | ||||
|       const { index } = e.currentTarget.dataset | ||||
|       const { list } = this.data | ||||
|       const pagePath = list[index].pagePath | ||||
|       wx.switchTab({ | ||||
|         url: pagePath, | ||||
|       }) | ||||
|     }, | ||||
|   }, | ||||
| }) | ||||
| @ -0,0 +1,14 @@@@ -0,0 +1,14 @@ | ||||
| <van-tabbar active="{{ active }}" active-color="#F23A2F" bind:change="onChange" inactive-color="#010105"> | ||||
|   <block wx:for="{{list}}" wx:key="*this"> | ||||
|     <van-tabbar-item | ||||
|       class="tab-item" | ||||
|       wx:if="{{ index != 3 || !anyWhere}}" | ||||
|       bind:tap="handleNav" | ||||
|       data-index="{{index}}" | ||||
|       icon="/images/tabbar/{{active==index ? item.iconActive : item.icon}}.png" | ||||
|     > | ||||
|       <view class="name {{index==active && 'active'}}">{{item.text}}</view> | ||||
|       <view class="hot"></view> | ||||
|     </van-tabbar-item> | ||||
|   </block> | ||||
| </van-tabbar> | ||||
| After Width: | Height: | Size: 93 KiB | 
| After Width: | Height: | Size: 415 KiB | 
| After Width: | Height: | Size: 8.1 KiB | 
| After Width: | Height: | Size: 43 KiB | 
| After Width: | Height: | Size: 2.0 KiB | 
| After Width: | Height: | Size: 1.6 KiB | 
| After Width: | Height: | Size: 1.5 KiB | 
| After Width: | Height: | Size: 1.2 KiB | 
| After Width: | Height: | Size: 1.4 KiB | 
| After Width: | Height: | Size: 1.1 KiB | 
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| export {}; | ||||
| @ -0,0 +1,74 @@@@ -0,0 +1,74 @@ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| var component_1 = require("../common/component"); | ||||
| var button_1 = require("../mixins/button"); | ||||
| (0, component_1.VantComponent)({ | ||||
|     classes: ['list-class'], | ||||
|     mixins: [button_1.button], | ||||
|     props: { | ||||
|         show: Boolean, | ||||
|         title: String, | ||||
|         cancelText: String, | ||||
|         description: String, | ||||
|         round: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|         zIndex: { | ||||
|             type: Number, | ||||
|             value: 100, | ||||
|         }, | ||||
|         actions: { | ||||
|             type: Array, | ||||
|             value: [], | ||||
|         }, | ||||
|         overlay: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|         closeOnClickOverlay: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|         closeOnClickAction: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|         safeAreaInsetBottom: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|     }, | ||||
|     methods: { | ||||
|         onSelect: function (event) { | ||||
|             var _this = this; | ||||
|             var index = event.currentTarget.dataset.index; | ||||
|             var _a = this.data, actions = _a.actions, closeOnClickAction = _a.closeOnClickAction, canIUseGetUserProfile = _a.canIUseGetUserProfile; | ||||
|             var item = actions[index]; | ||||
|             if (item) { | ||||
|                 this.$emit('select', item); | ||||
|                 if (closeOnClickAction) { | ||||
|                     this.onClose(); | ||||
|                 } | ||||
|                 if (item.openType === 'getUserInfo' && canIUseGetUserProfile) { | ||||
|                     wx.getUserProfile({ | ||||
|                         desc: item.getUserProfileDesc || '  ', | ||||
|                         complete: function (userProfile) { | ||||
|                             _this.$emit('getuserinfo', userProfile); | ||||
|                         }, | ||||
|                     }); | ||||
|                 } | ||||
|             } | ||||
|         }, | ||||
|         onCancel: function () { | ||||
|             this.$emit('cancel'); | ||||
|         }, | ||||
|         onClose: function () { | ||||
|             this.$emit('close'); | ||||
|         }, | ||||
|         onClickOverlay: function () { | ||||
|             this.$emit('click-overlay'); | ||||
|             this.onClose(); | ||||
|         }, | ||||
|     }, | ||||
| }); | ||||
| @ -0,0 +1,8 @@@@ -0,0 +1,8 @@ | ||||
| { | ||||
|   "component": true, | ||||
|   "usingComponents": { | ||||
|     "van-icon": "../icon/index", | ||||
|     "van-popup": "../popup/index", | ||||
|     "van-loading": "../loading/index" | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,69 @@@@ -0,0 +1,69 @@ | ||||
| <wxs src="../wxs/utils.wxs" module="utils" /> | ||||
| 
 | ||||
| <van-popup | ||||
|   show="{{ show }}" | ||||
|   position="bottom" | ||||
|   round="{{ round }}" | ||||
|   z-index="{{ zIndex }}" | ||||
|   overlay="{{ overlay }}" | ||||
|   custom-class="van-action-sheet custom-class" | ||||
|   safe-area-inset-bottom="{{ safeAreaInsetBottom }}" | ||||
|   close-on-click-overlay="{{ closeOnClickOverlay }}" | ||||
|   bind:close="onClickOverlay" | ||||
| > | ||||
|   <view wx:if="{{ title }}" class="van-action-sheet__header"> | ||||
|     {{ title }} | ||||
|     <van-icon | ||||
|       name="cross" | ||||
|       custom-class="van-action-sheet__close" | ||||
|       bind:click="onClose" | ||||
|     /> | ||||
|   </view> | ||||
|   <view wx:if="{{ description }}" class="van-action-sheet__description van-hairline--bottom"> | ||||
|     {{ description }} | ||||
|   </view> | ||||
|   <view wx:if="{{ actions && actions.length }}" class="list-class"> | ||||
|     <!-- button外包一层view,防止actions动态变化,导致渲染时button被打散 --> | ||||
|     <button | ||||
|       wx:for="{{ actions }}" | ||||
|       wx:key="index" | ||||
|       open-type="{{ item.disabled || item.loading || (canIUseGetUserProfile && item.openType === 'getUserInfo') ? '' : item.openType }}" | ||||
|       style="{{ item.color ? 'color: ' + item.color : '' }}" | ||||
|       class="{{ utils.bem('action-sheet__item', { disabled: item.disabled || item.loading }) }} {{ item.className || '' }}" | ||||
|       hover-class="van-action-sheet__item--hover" | ||||
|       data-index="{{ index }}" | ||||
|       bindtap="{{ item.disabled || item.loading ? '' : 'onSelect' }}" | ||||
|       bindgetuserinfo="onGetUserInfo" | ||||
|       bindcontact="onContact" | ||||
|       bindgetphonenumber="onGetPhoneNumber" | ||||
|       binderror="onError" | ||||
|       bindlaunchapp="onLaunchApp" | ||||
|       bindopensetting="onOpenSetting" | ||||
|       lang="{{ lang }}" | ||||
|       session-from="{{ sessionFrom }}" | ||||
|       send-message-title="{{ sendMessageTitle }}" | ||||
|       send-message-path="{{ sendMessagePath }}" | ||||
|       send-message-img="{{ sendMessageImg }}" | ||||
|       show-message-card="{{ showMessageCard }}" | ||||
|       app-parameter="{{ appParameter }}" | ||||
|     > | ||||
|       <block wx:if="{{ !item.loading }}"> | ||||
|         {{ item.name }} | ||||
|         <view wx:if="{{ item.subname }}" class="van-action-sheet__subname" >{{ item.subname }}</view> | ||||
|       </block> | ||||
|       <van-loading wx:else custom-class="van-action-sheet__loading" size="22px" /> | ||||
|     </button> | ||||
|   </view> | ||||
|   <slot /> | ||||
|   <block wx:if="{{ cancelText }}"> | ||||
|     <view class="van-action-sheet__gap" /> | ||||
|     <view | ||||
|       class="van-action-sheet__cancel" | ||||
|       hover-class="van-action-sheet__cancel--hover" | ||||
|       hover-stay-time="70" | ||||
|       bind:tap="onCancel" | ||||
|     > | ||||
|       {{ cancelText }} | ||||
|     </view> | ||||
|   </block> | ||||
| </van-popup> | ||||
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| @import '../common/index.wxss';.van-action-sheet{color:var(--action-sheet-item-text-color,#323233);max-height:var(--action-sheet-max-height,90%)!important}.van-action-sheet__cancel,.van-action-sheet__item{background-color:var(--action-sheet-item-background,#fff);font-size:var(--action-sheet-item-font-size,16px);line-height:var(--action-sheet-item-line-height,22px);padding:14px 16px;text-align:center}.van-action-sheet__cancel--hover,.van-action-sheet__item--hover{background-color:#f2f3f5}.van-action-sheet__cancel:after,.van-action-sheet__item:after{border-width:0}.van-action-sheet__cancel{color:var(--action-sheet-cancel-text-color,#646566)}.van-action-sheet__gap{background-color:var(--action-sheet-cancel-padding-color,#f7f8fa);display:block;height:var(--action-sheet-cancel-padding-top,8px)}.van-action-sheet__item--disabled{color:var(--action-sheet-item-disabled-text-color,#c8c9cc)}.van-action-sheet__item--disabled.van-action-sheet__item--hover{background-color:var(--action-sheet-item-background,#fff)}.van-action-sheet__subname{color:var(--action-sheet-subname-color,#969799);font-size:var(--action-sheet-subname-font-size,12px);line-height:var(--action-sheet-subname-line-height,20px);margin-top:var(--padding-xs,8px)}.van-action-sheet__header{font-size:var(--action-sheet-header-font-size,16px);font-weight:var(--font-weight-bold,500);line-height:var(--action-sheet-header-height,48px);text-align:center}.van-action-sheet__description{color:var(--action-sheet-description-color,#969799);font-size:var(--action-sheet-description-font-size,14px);line-height:var(--action-sheet-description-line-height,20px);padding:20px var(--padding-md,16px);text-align:center}.van-action-sheet__close{color:var(--action-sheet-close-icon-color,#c8c9cc);font-size:var(--action-sheet-close-icon-size,22px)!important;line-height:inherit!important;padding:var(--action-sheet-close-icon-padding,0 16px);position:absolute!important;right:0;top:0}.van-action-sheet__loading{display:flex!important} | ||||
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| export {}; | ||||
| @ -0,0 +1,235 @@@@ -0,0 +1,235 @@ | ||||
| "use strict"; | ||||
| var __assign = (this && this.__assign) || function () { | ||||
|     __assign = Object.assign || function(t) { | ||||
|         for (var s, i = 1, n = arguments.length; i < n; i++) { | ||||
|             s = arguments[i]; | ||||
|             for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) | ||||
|                 t[p] = s[p]; | ||||
|         } | ||||
|         return t; | ||||
|     }; | ||||
|     return __assign.apply(this, arguments); | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| var component_1 = require("../common/component"); | ||||
| var shared_1 = require("../picker/shared"); | ||||
| var utils_1 = require("../common/utils"); | ||||
| var EMPTY_CODE = '000000'; | ||||
| (0, component_1.VantComponent)({ | ||||
|     classes: ['active-class', 'toolbar-class', 'column-class'], | ||||
|     props: __assign(__assign({}, shared_1.pickerProps), { showToolbar: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, value: { | ||||
|             type: String, | ||||
|             observer: function (value) { | ||||
|                 this.code = value; | ||||
|                 this.setValues(); | ||||
|             }, | ||||
|         }, areaList: { | ||||
|             type: Object, | ||||
|             value: {}, | ||||
|             observer: 'setValues', | ||||
|         }, columnsNum: { | ||||
|             type: null, | ||||
|             value: 3, | ||||
|         }, columnsPlaceholder: { | ||||
|             type: Array, | ||||
|             observer: function (val) { | ||||
|                 this.setData({ | ||||
|                     typeToColumnsPlaceholder: { | ||||
|                         province: val[0] || '', | ||||
|                         city: val[1] || '', | ||||
|                         county: val[2] || '', | ||||
|                     }, | ||||
|                 }); | ||||
|             }, | ||||
|         } }), | ||||
|     data: { | ||||
|         columns: [{ values: [] }, { values: [] }, { values: [] }], | ||||
|         typeToColumnsPlaceholder: {}, | ||||
|     }, | ||||
|     mounted: function () { | ||||
|         var _this = this; | ||||
|         (0, utils_1.requestAnimationFrame)(function () { | ||||
|             _this.setValues(); | ||||
|         }); | ||||
|     }, | ||||
|     methods: { | ||||
|         getPicker: function () { | ||||
|             if (this.picker == null) { | ||||
|                 this.picker = this.selectComponent('.van-area__picker'); | ||||
|             } | ||||
|             return this.picker; | ||||
|         }, | ||||
|         onCancel: function (event) { | ||||
|             this.emit('cancel', event.detail); | ||||
|         }, | ||||
|         onConfirm: function (event) { | ||||
|             var index = event.detail.index; | ||||
|             var value = event.detail.value; | ||||
|             value = this.parseValues(value); | ||||
|             this.emit('confirm', { value: value, index: index }); | ||||
|         }, | ||||
|         emit: function (type, detail) { | ||||
|             detail.values = detail.value; | ||||
|             delete detail.value; | ||||
|             this.$emit(type, detail); | ||||
|         }, | ||||
|         parseValues: function (values) { | ||||
|             var columnsPlaceholder = this.data.columnsPlaceholder; | ||||
|             return values.map(function (value, index) { | ||||
|                 if (value && | ||||
|                     (!value.code || value.name === columnsPlaceholder[index])) { | ||||
|                     return __assign(__assign({}, value), { code: '', name: '' }); | ||||
|                 } | ||||
|                 return value; | ||||
|             }); | ||||
|         }, | ||||
|         onChange: function (event) { | ||||
|             var _this = this; | ||||
|             var _a; | ||||
|             var _b = event.detail, index = _b.index, picker = _b.picker, value = _b.value; | ||||
|             this.code = value[index].code; | ||||
|             (_a = this.setValues()) === null || _a === void 0 ? void 0 : _a.then(function () { | ||||
|                 _this.$emit('change', { | ||||
|                     picker: picker, | ||||
|                     values: _this.parseValues(picker.getValues()), | ||||
|                     index: index, | ||||
|                 }); | ||||
|             }); | ||||
|         }, | ||||
|         getConfig: function (type) { | ||||
|             var areaList = this.data.areaList; | ||||
|             return (areaList && areaList["".concat(type, "_list")]) || {}; | ||||
|         }, | ||||
|         getList: function (type, code) { | ||||
|             if (type !== 'province' && !code) { | ||||
|                 return []; | ||||
|             } | ||||
|             var typeToColumnsPlaceholder = this.data.typeToColumnsPlaceholder; | ||||
|             var list = this.getConfig(type); | ||||
|             var result = Object.keys(list).map(function (code) { return ({ | ||||
|                 code: code, | ||||
|                 name: list[code], | ||||
|             }); }); | ||||
|             if (code != null) { | ||||
|                 // oversea code
 | ||||
|                 if (code[0] === '9' && type === 'city') { | ||||
|                     code = '9'; | ||||
|                 } | ||||
|                 result = result.filter(function (item) { return item.code.indexOf(code) === 0; }); | ||||
|             } | ||||
|             if (typeToColumnsPlaceholder[type] && result.length) { | ||||
|                 // set columns placeholder
 | ||||
|                 var codeFill = type === 'province' | ||||
|                     ? '' | ||||
|                     : type === 'city' | ||||
|                         ? EMPTY_CODE.slice(2, 4) | ||||
|                         : EMPTY_CODE.slice(4, 6); | ||||
|                 result.unshift({ | ||||
|                     code: "".concat(code).concat(codeFill), | ||||
|                     name: typeToColumnsPlaceholder[type], | ||||
|                 }); | ||||
|             } | ||||
|             return result; | ||||
|         }, | ||||
|         getIndex: function (type, code) { | ||||
|             var compareNum = type === 'province' ? 2 : type === 'city' ? 4 : 6; | ||||
|             var list = this.getList(type, code.slice(0, compareNum - 2)); | ||||
|             // oversea code
 | ||||
|             if (code[0] === '9' && type === 'province') { | ||||
|                 compareNum = 1; | ||||
|             } | ||||
|             code = code.slice(0, compareNum); | ||||
|             for (var i = 0; i < list.length; i++) { | ||||
|                 if (list[i].code.slice(0, compareNum) === code) { | ||||
|                     return i; | ||||
|                 } | ||||
|             } | ||||
|             return 0; | ||||
|         }, | ||||
|         setValues: function () { | ||||
|             var picker = this.getPicker(); | ||||
|             if (!picker) { | ||||
|                 return; | ||||
|             } | ||||
|             var code = this.code || this.getDefaultCode(); | ||||
|             var provinceList = this.getList('province'); | ||||
|             var cityList = this.getList('city', code.slice(0, 2)); | ||||
|             var stack = []; | ||||
|             var indexes = []; | ||||
|             var columnsNum = this.data.columnsNum; | ||||
|             if (columnsNum >= 1) { | ||||
|                 stack.push(picker.setColumnValues(0, provinceList, false)); | ||||
|                 indexes.push(this.getIndex('province', code)); | ||||
|             } | ||||
|             if (columnsNum >= 2) { | ||||
|                 stack.push(picker.setColumnValues(1, cityList, false)); | ||||
|                 indexes.push(this.getIndex('city', code)); | ||||
|                 if (cityList.length && code.slice(2, 4) === '00') { | ||||
|                     code = cityList[0].code; | ||||
|                 } | ||||
|             } | ||||
|             if (columnsNum === 3) { | ||||
|                 stack.push(picker.setColumnValues(2, this.getList('county', code.slice(0, 4)), false)); | ||||
|                 indexes.push(this.getIndex('county', code)); | ||||
|             } | ||||
|             return Promise.all(stack) | ||||
|                 .catch(function () { }) | ||||
|                 .then(function () { return picker.setIndexes(indexes); }) | ||||
|                 .catch(function () { }); | ||||
|         }, | ||||
|         getDefaultCode: function () { | ||||
|             var columnsPlaceholder = this.data.columnsPlaceholder; | ||||
|             if (columnsPlaceholder.length) { | ||||
|                 return EMPTY_CODE; | ||||
|             } | ||||
|             var countyCodes = Object.keys(this.getConfig('county')); | ||||
|             if (countyCodes[0]) { | ||||
|                 return countyCodes[0]; | ||||
|             } | ||||
|             var cityCodes = Object.keys(this.getConfig('city')); | ||||
|             if (cityCodes[0]) { | ||||
|                 return cityCodes[0]; | ||||
|             } | ||||
|             return ''; | ||||
|         }, | ||||
|         getValues: function () { | ||||
|             var picker = this.getPicker(); | ||||
|             if (!picker) { | ||||
|                 return []; | ||||
|             } | ||||
|             return this.parseValues(picker.getValues().filter(function (value) { return !!value; })); | ||||
|         }, | ||||
|         getDetail: function () { | ||||
|             var values = this.getValues(); | ||||
|             var area = { | ||||
|                 code: '', | ||||
|                 country: '', | ||||
|                 province: '', | ||||
|                 city: '', | ||||
|                 county: '', | ||||
|             }; | ||||
|             if (!values.length) { | ||||
|                 return area; | ||||
|             } | ||||
|             var names = values.map(function (item) { return item.name; }); | ||||
|             area.code = values[values.length - 1].code; | ||||
|             if (area.code[0] === '9') { | ||||
|                 area.country = names[1] || ''; | ||||
|                 area.province = names[2] || ''; | ||||
|             } | ||||
|             else { | ||||
|                 area.province = names[0] || ''; | ||||
|                 area.city = names[1] || ''; | ||||
|                 area.county = names[2] || ''; | ||||
|             } | ||||
|             return area; | ||||
|         }, | ||||
|         reset: function (code) { | ||||
|             this.code = code || ''; | ||||
|             return this.setValues(); | ||||
|         }, | ||||
|     }, | ||||
| }); | ||||
| @ -0,0 +1,6 @@@@ -0,0 +1,6 @@ | ||||
| { | ||||
|   "component": true, | ||||
|   "usingComponents": { | ||||
|     "van-picker": "../picker/index" | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,20 @@@@ -0,0 +1,20 @@ | ||||
| <wxs src="./index.wxs" module="computed" /> | ||||
| 
 | ||||
| <van-picker | ||||
|   class="van-area__picker" | ||||
|   active-class="active-class" | ||||
|   toolbar-class="toolbar-class" | ||||
|   column-class="column-class" | ||||
|   show-toolbar="{{ showToolbar }}" | ||||
|   value-key="name" | ||||
|   title="{{ title }}" | ||||
|   loading="{{ loading }}" | ||||
|   columns="{{ computed.displayColumns(columns, columnsNum) }}" | ||||
|   item-height="{{ itemHeight }}" | ||||
|   visible-item-count="{{ visibleItemCount }}" | ||||
|   cancel-button-text="{{ cancelButtonText }}" | ||||
|   confirm-button-text="{{ confirmButtonText }}" | ||||
|   bind:change="onChange" | ||||
|   bind:confirm="onConfirm" | ||||
|   bind:cancel="onCancel" | ||||
| /> | ||||
| @ -0,0 +1,8 @@@@ -0,0 +1,8 @@ | ||||
| /* eslint-disable */ | ||||
| function displayColumns(columns, columnsNum) { | ||||
|   return columns.slice(0, +columnsNum); | ||||
| } | ||||
| 
 | ||||
| module.exports = { | ||||
|   displayColumns: displayColumns, | ||||
| }; | ||||
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| @import '../common/index.wxss'; | ||||
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| export {}; | ||||
| @ -0,0 +1,67 @@@@ -0,0 +1,67 @@ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| var component_1 = require("../common/component"); | ||||
| var button_1 = require("../mixins/button"); | ||||
| var version_1 = require("../common/version"); | ||||
| var mixins = [button_1.button]; | ||||
| if ((0, version_1.canIUseFormFieldButton)()) { | ||||
|     mixins.push('wx://form-field-button'); | ||||
| } | ||||
| (0, component_1.VantComponent)({ | ||||
|     mixins: mixins, | ||||
|     classes: ['hover-class', 'loading-class'], | ||||
|     data: { | ||||
|         baseStyle: '', | ||||
|     }, | ||||
|     props: { | ||||
|         formType: String, | ||||
|         icon: String, | ||||
|         classPrefix: { | ||||
|             type: String, | ||||
|             value: 'van-icon', | ||||
|         }, | ||||
|         plain: Boolean, | ||||
|         block: Boolean, | ||||
|         round: Boolean, | ||||
|         square: Boolean, | ||||
|         loading: Boolean, | ||||
|         hairline: Boolean, | ||||
|         disabled: Boolean, | ||||
|         loadingText: String, | ||||
|         customStyle: String, | ||||
|         loadingType: { | ||||
|             type: String, | ||||
|             value: 'circular', | ||||
|         }, | ||||
|         type: { | ||||
|             type: String, | ||||
|             value: 'default', | ||||
|         }, | ||||
|         dataset: null, | ||||
|         size: { | ||||
|             type: String, | ||||
|             value: 'normal', | ||||
|         }, | ||||
|         loadingSize: { | ||||
|             type: String, | ||||
|             value: '20px', | ||||
|         }, | ||||
|         color: String, | ||||
|     }, | ||||
|     methods: { | ||||
|         onClick: function (event) { | ||||
|             var _this = this; | ||||
|             this.$emit('click', event); | ||||
|             var _a = this.data, canIUseGetUserProfile = _a.canIUseGetUserProfile, openType = _a.openType, getUserProfileDesc = _a.getUserProfileDesc, lang = _a.lang; | ||||
|             if (openType === 'getUserInfo' && canIUseGetUserProfile) { | ||||
|                 wx.getUserProfile({ | ||||
|                     desc: getUserProfileDesc || '  ', | ||||
|                     lang: lang || 'en', | ||||
|                     complete: function (userProfile) { | ||||
|                         _this.$emit('getuserinfo', userProfile); | ||||
|                     }, | ||||
|                 }); | ||||
|             } | ||||
|         }, | ||||
|     }, | ||||
| }); | ||||
| @ -0,0 +1,7 @@@@ -0,0 +1,7 @@ | ||||
| { | ||||
|   "component": true, | ||||
|   "usingComponents": { | ||||
|     "van-icon": "../icon/index", | ||||
|     "van-loading": "../loading/index" | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,56 @@@@ -0,0 +1,56 @@ | ||||
| <wxs src="../wxs/utils.wxs" module="utils" /> | ||||
| <wxs src="./index.wxs" module="computed" /> | ||||
| 
 | ||||
| <button | ||||
|   id="{{ id || buttonId }}" | ||||
|   data-detail="{{ dataset }}" | ||||
|   class="custom-class {{ utils.bem('button', [type, size, { block, round, plain, square, loading, disabled, hairline, unclickable: disabled || loading }]) }} {{ hairline ? 'van-hairline--surround' : '' }}" | ||||
|   hover-class="{{ disabled || loading ? '' : 'van-button--active hover-class'}}" | ||||
|   lang="{{ lang }}" | ||||
|   form-type="{{ formType }}" | ||||
|   style="{{ computed.rootStyle({ plain, color, customStyle }) }}" | ||||
|   open-type="{{ disabled || loading || (canIUseGetUserProfile && openType === 'getUserInfo') ? '' : openType }}" | ||||
|   business-id="{{ businessId }}" | ||||
|   session-from="{{ sessionFrom }}" | ||||
|   send-message-title="{{ sendMessageTitle }}" | ||||
|   send-message-path="{{ sendMessagePath }}" | ||||
|   send-message-img="{{ sendMessageImg }}" | ||||
|   show-message-card="{{ showMessageCard }}" | ||||
|   app-parameter="{{ appParameter }}" | ||||
|   aria-label="{{ ariaLabel }}" | ||||
|   bindtap="{{ disabled || loading ? '' : 'onClick' }}" | ||||
|   bindgetuserinfo="onGetUserInfo" | ||||
|   bindcontact="onContact" | ||||
|   bindgetphonenumber="onGetPhoneNumber" | ||||
|   bindgetrealtimephonenumber="onGetRealTimePhoneNumber" | ||||
|   bindagreeprivacyauthorization="onAgreePrivacyAuthorization" | ||||
|   binderror="onError" | ||||
|   bindlaunchapp="onLaunchApp" | ||||
|   bindopensetting="onOpenSetting" | ||||
|   bindchooseavatar="onChooseAvatar" | ||||
| > | ||||
|   <block wx:if="{{ loading }}"> | ||||
|     <van-loading | ||||
|       custom-class="loading-class" | ||||
|       size="{{ loadingSize }}" | ||||
|       type="{{ loadingType }}" | ||||
|       color="{{ computed.loadingColor({ type, color, plain }) }}" | ||||
|     /> | ||||
|     <view wx:if="{{ loadingText }}" class="van-button__loading-text"> | ||||
|       {{ loadingText }} | ||||
|     </view> | ||||
|   </block> | ||||
|   <block wx:else> | ||||
|     <van-icon | ||||
|       wx:if="{{ icon }}" | ||||
|       size="1.2em" | ||||
|       name="{{ icon }}" | ||||
|       class-prefix="{{ classPrefix }}" | ||||
|       class="van-button__icon" | ||||
|       custom-style="line-height: inherit;" | ||||
|     /> | ||||
|     <view class="van-button__text"> | ||||
|       <slot /> | ||||
|     </view> | ||||
|   </block> | ||||
| </button> | ||||
| @ -0,0 +1,39 @@@@ -0,0 +1,39 @@ | ||||
| /* eslint-disable */ | ||||
| var style = require('../wxs/style.wxs'); | ||||
| 
 | ||||
| function rootStyle(data) { | ||||
|   if (!data.color) { | ||||
|     return data.customStyle; | ||||
|   } | ||||
| 
 | ||||
|   var properties = { | ||||
|     color: data.plain ? data.color : '#fff', | ||||
|     background: data.plain ? null : data.color, | ||||
|   }; | ||||
| 
 | ||||
|   // hide border when color is linear-gradient | ||||
|   if (data.color.indexOf('gradient') !== -1) { | ||||
|     properties.border = 0; | ||||
|   } else { | ||||
|     properties['border-color'] = data.color; | ||||
|   } | ||||
| 
 | ||||
|   return style([properties, data.customStyle]); | ||||
| } | ||||
| 
 | ||||
| function loadingColor(data) { | ||||
|   if (data.plain) { | ||||
|     return data.color ? data.color : '#c9c9c9'; | ||||
|   } | ||||
| 
 | ||||
|   if (data.type === 'default') { | ||||
|     return '#c9c9c9'; | ||||
|   } | ||||
| 
 | ||||
|   return '#fff'; | ||||
| } | ||||
| 
 | ||||
| module.exports = { | ||||
|   rootStyle: rootStyle, | ||||
|   loadingColor: loadingColor, | ||||
| }; | ||||
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| @import '../common/index.wxss';.van-button{-webkit-text-size-adjust:100%;align-items:center;-webkit-appearance:none;border-radius:var(--button-border-radius,2px);box-sizing:border-box;display:inline-flex;font-size:var(--button-default-font-size,16px);height:var(--button-default-height,44px);justify-content:center;line-height:var(--button-line-height,20px);padding:0;position:relative;text-align:center;transition:opacity .2s;vertical-align:middle}.van-button:before{background-color:#000;border:inherit;border-color:#000;border-radius:inherit;content:" ";height:100%;left:50%;opacity:0;position:absolute;top:50%;transform:translate(-50%,-50%);width:100%}.van-button:after{border-width:0}.van-button--active:before{opacity:.15}.van-button--unclickable:after{display:none}.van-button--default{background:var(--button-default-background-color,#fff);border:var(--button-border-width,1px) solid var(--button-default-border-color,#ebedf0);color:var(--button-default-color,#323233)}.van-button--primary{background:var(--button-primary-background-color,#07c160);border:var(--button-border-width,1px) solid var(--button-primary-border-color,#07c160);color:var(--button-primary-color,#fff)}.van-button--info{background:var(--button-info-background-color,#1989fa);border:var(--button-border-width,1px) solid var(--button-info-border-color,#1989fa);color:var(--button-info-color,#fff)}.van-button--danger{background:var(--button-danger-background-color,#ee0a24);border:var(--button-border-width,1px) solid var(--button-danger-border-color,#ee0a24);color:var(--button-danger-color,#fff)}.van-button--warning{background:var(--button-warning-background-color,#ff976a);border:var(--button-border-width,1px) solid var(--button-warning-border-color,#ff976a);color:var(--button-warning-color,#fff)}.van-button--plain{background:var(--button-plain-background-color,#fff)}.van-button--plain.van-button--primary{color:var(--button-primary-background-color,#07c160)}.van-button--plain.van-button--info{color:var(--button-info-background-color,#1989fa)}.van-button--plain.van-button--danger{color:var(--button-danger-background-color,#ee0a24)}.van-button--plain.van-button--warning{color:var(--button-warning-background-color,#ff976a)}.van-button--large{height:var(--button-large-height,50px);width:100%}.van-button--normal{font-size:var(--button-normal-font-size,14px);padding:0 15px}.van-button--small{font-size:var(--button-small-font-size,12px);height:var(--button-small-height,30px);min-width:var(--button-small-min-width,60px);padding:0 var(--padding-xs,8px)}.van-button--mini{display:inline-block;font-size:var(--button-mini-font-size,10px);height:var(--button-mini-height,22px);min-width:var(--button-mini-min-width,50px)}.van-button--mini+.van-button--mini{margin-left:5px}.van-button--block{display:flex;width:100%}.van-button--round{border-radius:var(--button-round-border-radius,999px)}.van-button--square{border-radius:0}.van-button--disabled{opacity:var(--button-disabled-opacity,.5)}.van-button__text{display:inline}.van-button__icon+.van-button__text:not(:empty),.van-button__loading-text{margin-left:4px}.van-button__icon{line-height:inherit!important;min-width:1em;vertical-align:top}.van-button--hairline{border-width:0;padding-top:1px}.van-button--hairline:after{border-color:inherit;border-radius:calc(var(--button-border-radius, 2px)*2);border-width:1px}.van-button--hairline.van-button--round:after{border-radius:var(--button-round-border-radius,999px)}.van-button--hairline.van-button--square:after{border-radius:0} | ||||
| @ -0,0 +1,70 @@@@ -0,0 +1,70 @@ | ||||
| <wxs src="./index.wxs" module="computed" /> | ||||
| <wxs src="../wxs/utils.wxs" module="utils" /> | ||||
| <view class="van-calendar"> | ||||
|   <header | ||||
|     title="{{ title }}" | ||||
|     showTitle="{{ showTitle }}" | ||||
|     subtitle="{{ subtitle }}" | ||||
|     showSubtitle="{{ showSubtitle }}" | ||||
|     firstDayOfWeek="{{ firstDayOfWeek }}" | ||||
|     bind:click-subtitle="onClickSubtitle" | ||||
|   > | ||||
|     <slot name="title" slot="title"></slot> | ||||
|   </header> | ||||
| 
 | ||||
|   <scroll-view | ||||
|     class="van-calendar__body" | ||||
|     scroll-y | ||||
|     scroll-into-view="{{ scrollIntoView }}" | ||||
|   > | ||||
|     <month | ||||
|       wx:for="{{ computed.getMonths(minDate, maxDate) }}" | ||||
|       wx:key="index" | ||||
|       id="month{{ index }}" | ||||
|       class="month" | ||||
|       data-date="{{ item }}" | ||||
|       date="{{ item }}" | ||||
|       type="{{ type }}" | ||||
|       color="{{ color }}" | ||||
|       minDate="{{ minDate }}" | ||||
|       maxDate="{{ maxDate }}" | ||||
|       showMark="{{ showMark }}" | ||||
|       formatter="{{ formatter }}" | ||||
|       rowHeight="{{ rowHeight }}" | ||||
|       currentDate="{{ currentDate }}" | ||||
|       showSubtitle="{{ showSubtitle }}" | ||||
|       allowSameDay="{{ allowSameDay }}" | ||||
|       showMonthTitle="{{ index !== 0 || !showSubtitle }}" | ||||
|       firstDayOfWeek="{{ firstDayOfWeek }}" | ||||
|       bind:click="onClickDay" | ||||
|     /> | ||||
|   </scroll-view> | ||||
| 
 | ||||
|   <view | ||||
|     class="{{ utils.bem('calendar__footer', { safeAreaInsetBottom }) }}" | ||||
|   > | ||||
|     <slot name="footer"></slot> | ||||
|   </view> | ||||
| 
 | ||||
|   <view | ||||
|     class="{{ utils.bem('calendar__footer', { safeAreaInsetBottom }) }}" | ||||
|   > | ||||
|     <van-button | ||||
|       wx:if="{{ showConfirm }}" | ||||
|       round | ||||
|       block | ||||
|       type="danger" | ||||
|       color="{{ color }}" | ||||
|       custom-class="van-calendar__confirm" | ||||
|       disabled="{{ computed.getButtonDisabled(type, currentDate, minRange) }}" | ||||
|       nativeType="text" | ||||
|       bind:click="onConfirm" | ||||
|     > | ||||
|       {{ | ||||
|         computed.getButtonDisabled(type, currentDate, minRange) | ||||
|           ? confirmDisabledText | ||||
|           : confirmText | ||||
|       }} | ||||
|     </van-button> | ||||
|   </view> | ||||
| </view> | ||||
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| export {}; | ||||
| @ -0,0 +1,45 @@@@ -0,0 +1,45 @@ | ||||
| "use strict"; | ||||
| var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { | ||||
|     if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { | ||||
|         if (ar || !(i in from)) { | ||||
|             if (!ar) ar = Array.prototype.slice.call(from, 0, i); | ||||
|             ar[i] = from[i]; | ||||
|         } | ||||
|     } | ||||
|     return to.concat(ar || Array.prototype.slice.call(from)); | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| var component_1 = require("../../../common/component"); | ||||
| (0, component_1.VantComponent)({ | ||||
|     props: { | ||||
|         title: { | ||||
|             type: String, | ||||
|             value: '日期选择', | ||||
|         }, | ||||
|         subtitle: String, | ||||
|         showTitle: Boolean, | ||||
|         showSubtitle: Boolean, | ||||
|         firstDayOfWeek: { | ||||
|             type: Number, | ||||
|             observer: 'initWeekDay', | ||||
|         }, | ||||
|     }, | ||||
|     data: { | ||||
|         weekdays: [], | ||||
|     }, | ||||
|     created: function () { | ||||
|         this.initWeekDay(); | ||||
|     }, | ||||
|     methods: { | ||||
|         initWeekDay: function () { | ||||
|             var defaultWeeks = ['日', '一', '二', '三', '四', '五', '六']; | ||||
|             var firstDayOfWeek = this.data.firstDayOfWeek || 0; | ||||
|             this.setData({ | ||||
|                 weekdays: __spreadArray(__spreadArray([], defaultWeeks.slice(firstDayOfWeek, 7), true), defaultWeeks.slice(0, firstDayOfWeek), true), | ||||
|             }); | ||||
|         }, | ||||
|         onClickSubtitle: function (event) { | ||||
|             this.$emit('click-subtitle', event); | ||||
|         }, | ||||
|     }, | ||||
| }); | ||||
| @ -0,0 +1,3 @@@@ -0,0 +1,3 @@ | ||||
| { | ||||
|   "component": true | ||||
| } | ||||
| @ -0,0 +1,16 @@@@ -0,0 +1,16 @@ | ||||
| <view class="van-calendar__header"> | ||||
|   <block wx:if="{{ showTitle }}"> | ||||
|     <view class="van-calendar__header-title"><slot name="title"></slot></view> | ||||
|     <view class="van-calendar__header-title">{{ title }}</view> | ||||
|   </block> | ||||
| 
 | ||||
|   <view wx:if="{{ showSubtitle }}" class="van-calendar__header-subtitle" bind:tap="onClickSubtitle"> | ||||
|     {{ subtitle }} | ||||
|   </view> | ||||
| 
 | ||||
|   <view class="van-calendar__weekdays"> | ||||
|     <view wx:for="{{ weekdays }}" wx:key="index" class="van-calendar__weekday"> | ||||
|       {{ item }} | ||||
|     </view> | ||||
|   </view> | ||||
| </view> | ||||
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| @import '../../../common/index.wxss';.van-calendar__header{box-shadow:var(--calendar-header-box-shadow,0 2px 10px hsla(220,1%,50%,.16));flex-shrink:0}.van-calendar__header-subtitle,.van-calendar__header-title{font-weight:var(--font-weight-bold,500);height:var(--calendar-header-title-height,44px);line-height:var(--calendar-header-title-height,44px);text-align:center}.van-calendar__header-title+.van-calendar__header-title,.van-calendar__header-title:empty{display:none}.van-calendar__header-title:empty+.van-calendar__header-title{display:block!important}.van-calendar__weekdays{display:flex}.van-calendar__weekday{flex:1;font-size:var(--calendar-weekdays-font-size,12px);line-height:var(--calendar-weekdays-height,30px);text-align:center} | ||||
| @ -0,0 +1,6 @@@@ -0,0 +1,6 @@ | ||||
| export interface Day { | ||||
|     date: Date; | ||||
|     type: string; | ||||
|     text: number; | ||||
|     bottomInfo?: string; | ||||
| } | ||||
| @ -0,0 +1,158 @@@@ -0,0 +1,158 @@ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| var component_1 = require("../../../common/component"); | ||||
| var utils_1 = require("../../utils"); | ||||
| (0, component_1.VantComponent)({ | ||||
|     props: { | ||||
|         date: { | ||||
|             type: null, | ||||
|             observer: 'setDays', | ||||
|         }, | ||||
|         type: { | ||||
|             type: String, | ||||
|             observer: 'setDays', | ||||
|         }, | ||||
|         color: String, | ||||
|         minDate: { | ||||
|             type: null, | ||||
|             observer: 'setDays', | ||||
|         }, | ||||
|         maxDate: { | ||||
|             type: null, | ||||
|             observer: 'setDays', | ||||
|         }, | ||||
|         showMark: Boolean, | ||||
|         rowHeight: null, | ||||
|         formatter: { | ||||
|             type: null, | ||||
|             observer: 'setDays', | ||||
|         }, | ||||
|         currentDate: { | ||||
|             type: null, | ||||
|             observer: 'setDays', | ||||
|         }, | ||||
|         firstDayOfWeek: { | ||||
|             type: Number, | ||||
|             observer: 'setDays', | ||||
|         }, | ||||
|         allowSameDay: Boolean, | ||||
|         showSubtitle: Boolean, | ||||
|         showMonthTitle: Boolean, | ||||
|     }, | ||||
|     data: { | ||||
|         visible: true, | ||||
|         days: [], | ||||
|     }, | ||||
|     methods: { | ||||
|         onClick: function (event) { | ||||
|             var index = event.currentTarget.dataset.index; | ||||
|             var item = this.data.days[index]; | ||||
|             if (item.type !== 'disabled') { | ||||
|                 this.$emit('click', item); | ||||
|             } | ||||
|         }, | ||||
|         setDays: function () { | ||||
|             var days = []; | ||||
|             var startDate = new Date(this.data.date); | ||||
|             var year = startDate.getFullYear(); | ||||
|             var month = startDate.getMonth(); | ||||
|             var totalDay = (0, utils_1.getMonthEndDay)(startDate.getFullYear(), startDate.getMonth() + 1); | ||||
|             for (var day = 1; day <= totalDay; day++) { | ||||
|                 var date = new Date(year, month, day); | ||||
|                 var type = this.getDayType(date); | ||||
|                 var config = { | ||||
|                     date: date, | ||||
|                     type: type, | ||||
|                     text: day, | ||||
|                     bottomInfo: this.getBottomInfo(type), | ||||
|                 }; | ||||
|                 if (this.data.formatter) { | ||||
|                     config = this.data.formatter(config); | ||||
|                 } | ||||
|                 days.push(config); | ||||
|             } | ||||
|             this.setData({ days: days }); | ||||
|         }, | ||||
|         getMultipleDayType: function (day) { | ||||
|             var currentDate = this.data.currentDate; | ||||
|             if (!Array.isArray(currentDate)) { | ||||
|                 return ''; | ||||
|             } | ||||
|             var isSelected = function (date) { | ||||
|                 return currentDate.some(function (item) { return (0, utils_1.compareDay)(item, date) === 0; }); | ||||
|             }; | ||||
|             if (isSelected(day)) { | ||||
|                 var prevDay = (0, utils_1.getPrevDay)(day); | ||||
|                 var nextDay = (0, utils_1.getNextDay)(day); | ||||
|                 var prevSelected = isSelected(prevDay); | ||||
|                 var nextSelected = isSelected(nextDay); | ||||
|                 if (prevSelected && nextSelected) { | ||||
|                     return 'multiple-middle'; | ||||
|                 } | ||||
|                 if (prevSelected) { | ||||
|                     return 'end'; | ||||
|                 } | ||||
|                 return nextSelected ? 'start' : 'multiple-selected'; | ||||
|             } | ||||
|             return ''; | ||||
|         }, | ||||
|         getRangeDayType: function (day) { | ||||
|             var _a = this.data, currentDate = _a.currentDate, allowSameDay = _a.allowSameDay; | ||||
|             if (!Array.isArray(currentDate)) { | ||||
|                 return ''; | ||||
|             } | ||||
|             var startDay = currentDate[0], endDay = currentDate[1]; | ||||
|             if (!startDay) { | ||||
|                 return ''; | ||||
|             } | ||||
|             var compareToStart = (0, utils_1.compareDay)(day, startDay); | ||||
|             if (!endDay) { | ||||
|                 return compareToStart === 0 ? 'start' : ''; | ||||
|             } | ||||
|             var compareToEnd = (0, utils_1.compareDay)(day, endDay); | ||||
|             if (compareToStart === 0 && compareToEnd === 0 && allowSameDay) { | ||||
|                 return 'start-end'; | ||||
|             } | ||||
|             if (compareToStart === 0) { | ||||
|                 return 'start'; | ||||
|             } | ||||
|             if (compareToEnd === 0) { | ||||
|                 return 'end'; | ||||
|             } | ||||
|             if (compareToStart > 0 && compareToEnd < 0) { | ||||
|                 return 'middle'; | ||||
|             } | ||||
|             return ''; | ||||
|         }, | ||||
|         getDayType: function (day) { | ||||
|             var _a = this.data, type = _a.type, minDate = _a.minDate, maxDate = _a.maxDate, currentDate = _a.currentDate; | ||||
|             if ((0, utils_1.compareDay)(day, minDate) < 0 || (0, utils_1.compareDay)(day, maxDate) > 0) { | ||||
|                 return 'disabled'; | ||||
|             } | ||||
|             if (type === 'single') { | ||||
|                 return (0, utils_1.compareDay)(day, currentDate) === 0 ? 'selected' : ''; | ||||
|             } | ||||
|             if (type === 'multiple') { | ||||
|                 return this.getMultipleDayType(day); | ||||
|             } | ||||
|             /* istanbul ignore else */ | ||||
|             if (type === 'range') { | ||||
|                 return this.getRangeDayType(day); | ||||
|             } | ||||
|             return ''; | ||||
|         }, | ||||
|         getBottomInfo: function (type) { | ||||
|             if (this.data.type === 'range') { | ||||
|                 if (type === 'start') { | ||||
|                     return '开始'; | ||||
|                 } | ||||
|                 if (type === 'end') { | ||||
|                     return '结束'; | ||||
|                 } | ||||
|                 if (type === 'start-end') { | ||||
|                     return '开始/结束'; | ||||
|                 } | ||||
|             } | ||||
|         }, | ||||
|     }, | ||||
| }); | ||||
| @ -0,0 +1,3 @@@@ -0,0 +1,3 @@ | ||||
| { | ||||
|   "component": true | ||||
| } | ||||
| @ -0,0 +1,39 @@@@ -0,0 +1,39 @@ | ||||
| <wxs src="./index.wxs" module="computed"></wxs> | ||||
| <wxs src="../../../wxs/utils.wxs" module="utils" /> | ||||
| 
 | ||||
| <view class="van-calendar__month" style="{{ computed.getMonthStyle(visible, date, rowHeight) }}"> | ||||
|   <view wx:if="{{ showMonthTitle }}" class="van-calendar__month-title"> | ||||
|     {{ computed.formatMonthTitle(date) }} | ||||
|   </view> | ||||
| 
 | ||||
|   <view wx:if="{{ visible }}" class="van-calendar__days"> | ||||
|     <view wx:if="{{ showMark }}" class="van-calendar__month-mark"> | ||||
|       {{ computed.getMark(date) }} | ||||
|     </view> | ||||
| 
 | ||||
|     <view | ||||
|       wx:for="{{ days }}" | ||||
|       wx:key="index" | ||||
|       style="{{ computed.getDayStyle(item.type, index, date, rowHeight, color, firstDayOfWeek) }}" | ||||
|       class="{{ utils.bem('calendar__day', [item.type]) }} {{ item.className }}" | ||||
|       data-index="{{ index }}" | ||||
|       bindtap="onClick" | ||||
|     > | ||||
|       <view wx:if="{{ item.type === 'selected' }}" class="van-calendar__selected-day" style="width: {{ rowHeight }}px; height: {{ rowHeight }}px; background: {{ color }}"> | ||||
|         <view wx:if="{{ item.topInfo }}" class="van-calendar__top-info">{{ item.topInfo }}</view> | ||||
|         {{ item.text }} | ||||
|         <view wx:if="{{ item.bottomInfo }}" class="van-calendar__bottom-info"> | ||||
|           {{ item.bottomInfo }} | ||||
|         </view> | ||||
|       </view> | ||||
| 
 | ||||
|       <view wx:else> | ||||
|         <view wx:if="{{ item.topInfo }}" class="van-calendar__top-info">{{ item.topInfo }}</view> | ||||
|         {{ item.text }} | ||||
|         <view wx:if="{{ item.bottomInfo }}" class="van-calendar__bottom-info"> | ||||
|           {{ item.bottomInfo }} | ||||
|         </view> | ||||
|       </view> | ||||
|     </view> | ||||
|   </view> | ||||
| </view> | ||||
| @ -0,0 +1,71 @@@@ -0,0 +1,71 @@ | ||||
| /* eslint-disable */ | ||||
| var utils = require('../../utils.wxs'); | ||||
| 
 | ||||
| function getMark(date) { | ||||
|   return getDate(date).getMonth() + 1; | ||||
| } | ||||
| 
 | ||||
| var ROW_HEIGHT = 64; | ||||
| 
 | ||||
| function getDayStyle(type, index, date, rowHeight, color, firstDayOfWeek) { | ||||
|   var style = []; | ||||
|   var current = getDate(date).getDay() || 7; | ||||
|   var offset = current < firstDayOfWeek ? (7 - firstDayOfWeek + current) : | ||||
|                current === 7 && firstDayOfWeek === 0 ? 0 : | ||||
|                (current - firstDayOfWeek); | ||||
| 
 | ||||
|   if (index === 0) { | ||||
|     style.push(['margin-left', (100 * offset) / 7 + '%']); | ||||
|   } | ||||
| 
 | ||||
|   if (rowHeight !== ROW_HEIGHT) { | ||||
|     style.push(['height', rowHeight + 'px']); | ||||
|   } | ||||
| 
 | ||||
|   if (color) { | ||||
|     if ( | ||||
|       type === 'start' || | ||||
|       type === 'end' || | ||||
|       type === 'start-end' || | ||||
|       type === 'multiple-selected' || | ||||
|       type === 'multiple-middle' | ||||
|     ) { | ||||
|       style.push(['background', color]); | ||||
|     } else if (type === 'middle') { | ||||
|       style.push(['color', color]); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   return style | ||||
|     .map(function(item) { | ||||
|       return item.join(':'); | ||||
|     }) | ||||
|     .join(';'); | ||||
| } | ||||
| 
 | ||||
| function formatMonthTitle(date) { | ||||
|   date = getDate(date); | ||||
|   return date.getFullYear() + '年' + (date.getMonth() + 1) + '月'; | ||||
| } | ||||
| 
 | ||||
| function getMonthStyle(visible, date, rowHeight) { | ||||
|   if (!visible) { | ||||
|     date = getDate(date); | ||||
| 
 | ||||
|     var totalDay = utils.getMonthEndDay( | ||||
|       date.getFullYear(), | ||||
|       date.getMonth() + 1 | ||||
|     ); | ||||
|     var offset = getDate(date).getDay(); | ||||
|     var padding = Math.ceil((totalDay + offset) / 7) * rowHeight; | ||||
| 
 | ||||
|     return 'padding-bottom:' + padding + 'px'; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| module.exports = { | ||||
|   getMark: getMark, | ||||
|   getDayStyle: getDayStyle, | ||||
|   formatMonthTitle: formatMonthTitle, | ||||
|   getMonthStyle: getMonthStyle | ||||
| }; | ||||
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| @import '../../../common/index.wxss';.van-calendar{background-color:var(--calendar-background-color,#fff);display:flex;flex-direction:column;height:100%}.van-calendar__month-title{font-size:var(--calendar-month-title-font-size,14px);font-weight:var(--font-weight-bold,500);height:var(--calendar-header-title-height,44px);line-height:var(--calendar-header-title-height,44px);text-align:center}.van-calendar__days{display:flex;flex-wrap:wrap;position:relative;-webkit-user-select:none;user-select:none}.van-calendar__month-mark{color:var(--calendar-month-mark-color,rgba(242,243,245,.8));font-size:var(--calendar-month-mark-font-size,160px);left:50%;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);z-index:0}.van-calendar__day,.van-calendar__selected-day{align-items:center;display:flex;justify-content:center;text-align:center}.van-calendar__day{font-size:var(--calendar-day-font-size,16px);height:var(--calendar-day-height,64px);position:relative;width:14.285%}.van-calendar__day--end,.van-calendar__day--multiple-middle,.van-calendar__day--multiple-selected,.van-calendar__day--start,.van-calendar__day--start-end{background-color:var(--calendar-range-edge-background-color,#ee0a24);color:var(--calendar-range-edge-color,#fff)}.van-calendar__day--start{border-radius:4px 0 0 4px}.van-calendar__day--end{border-radius:0 4px 4px 0}.van-calendar__day--multiple-selected,.van-calendar__day--start-end{border-radius:4px}.van-calendar__day--middle{color:var(--calendar-range-middle-color,#ee0a24)}.van-calendar__day--middle:after{background-color:currentColor;bottom:0;content:"";left:0;opacity:var(--calendar-range-middle-background-opacity,.1);position:absolute;right:0;top:0}.van-calendar__day--disabled{color:var(--calendar-day-disabled-color,#c8c9cc);cursor:default}.van-calendar__bottom-info,.van-calendar__top-info{font-size:var(--calendar-info-font-size,10px);left:0;line-height:var(--calendar-info-line-height,14px);position:absolute;right:0}@media (max-width:350px){.van-calendar__bottom-info,.van-calendar__top-info{font-size:9px}}.van-calendar__top-info{top:6px}.van-calendar__bottom-info{bottom:6px}.van-calendar__selected-day{background-color:var(--calendar-selected-day-background-color,#ee0a24);border-radius:4px;color:var(--calendar-selected-day-color,#fff);height:var(--calendar-selected-day-size,54px);width:var(--calendar-selected-day-size,54px)} | ||||
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| export {}; | ||||
| @ -0,0 +1,379 @@@@ -0,0 +1,379 @@ | ||||
| "use strict"; | ||||
| var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { | ||||
|     if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { | ||||
|         if (ar || !(i in from)) { | ||||
|             if (!ar) ar = Array.prototype.slice.call(from, 0, i); | ||||
|             ar[i] = from[i]; | ||||
|         } | ||||
|     } | ||||
|     return to.concat(ar || Array.prototype.slice.call(from)); | ||||
| }; | ||||
| var __importDefault = (this && this.__importDefault) || function (mod) { | ||||
|     return (mod && mod.__esModule) ? mod : { "default": mod }; | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| var component_1 = require("../common/component"); | ||||
| var utils_1 = require("./utils"); | ||||
| var toast_1 = __importDefault(require("../toast/toast")); | ||||
| var utils_2 = require("../common/utils"); | ||||
| var initialMinDate = (0, utils_1.getToday)().getTime(); | ||||
| var initialMaxDate = (function () { | ||||
|     var now = (0, utils_1.getToday)(); | ||||
|     return new Date(now.getFullYear(), now.getMonth() + 6, now.getDate()).getTime(); | ||||
| })(); | ||||
| var getTime = function (date) { | ||||
|     return date instanceof Date ? date.getTime() : date; | ||||
| }; | ||||
| (0, component_1.VantComponent)({ | ||||
|     props: { | ||||
|         title: { | ||||
|             type: String, | ||||
|             value: '日期选择', | ||||
|         }, | ||||
|         color: String, | ||||
|         show: { | ||||
|             type: Boolean, | ||||
|             observer: function (val) { | ||||
|                 if (val) { | ||||
|                     this.initRect(); | ||||
|                     this.scrollIntoView(); | ||||
|                 } | ||||
|             }, | ||||
|         }, | ||||
|         formatter: null, | ||||
|         confirmText: { | ||||
|             type: String, | ||||
|             value: '确定', | ||||
|         }, | ||||
|         confirmDisabledText: { | ||||
|             type: String, | ||||
|             value: '确定', | ||||
|         }, | ||||
|         rangePrompt: String, | ||||
|         showRangePrompt: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|         defaultDate: { | ||||
|             type: null, | ||||
|             value: (0, utils_1.getToday)().getTime(), | ||||
|             observer: function (val) { | ||||
|                 this.setData({ currentDate: val }); | ||||
|                 this.scrollIntoView(); | ||||
|             }, | ||||
|         }, | ||||
|         allowSameDay: Boolean, | ||||
|         type: { | ||||
|             type: String, | ||||
|             value: 'single', | ||||
|             observer: 'reset', | ||||
|         }, | ||||
|         minDate: { | ||||
|             type: Number, | ||||
|             value: initialMinDate, | ||||
|         }, | ||||
|         maxDate: { | ||||
|             type: Number, | ||||
|             value: initialMaxDate, | ||||
|         }, | ||||
|         position: { | ||||
|             type: String, | ||||
|             value: 'bottom', | ||||
|         }, | ||||
|         rowHeight: { | ||||
|             type: null, | ||||
|             value: utils_1.ROW_HEIGHT, | ||||
|         }, | ||||
|         round: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|         poppable: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|         showMark: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|         showTitle: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|         showConfirm: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|         showSubtitle: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|         safeAreaInsetBottom: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|         closeOnClickOverlay: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|         maxRange: { | ||||
|             type: null, | ||||
|             value: null, | ||||
|         }, | ||||
|         minRange: { | ||||
|             type: Number, | ||||
|             value: 1, | ||||
|         }, | ||||
|         firstDayOfWeek: { | ||||
|             type: Number, | ||||
|             value: 0, | ||||
|         }, | ||||
|         readonly: Boolean, | ||||
|     }, | ||||
|     data: { | ||||
|         subtitle: '', | ||||
|         currentDate: null, | ||||
|         scrollIntoView: '', | ||||
|     }, | ||||
|     watch: { | ||||
|         minDate: function () { | ||||
|             this.initRect(); | ||||
|         }, | ||||
|         maxDate: function () { | ||||
|             this.initRect(); | ||||
|         }, | ||||
|     }, | ||||
|     created: function () { | ||||
|         this.setData({ | ||||
|             currentDate: this.getInitialDate(this.data.defaultDate), | ||||
|         }); | ||||
|     }, | ||||
|     mounted: function () { | ||||
|         if (this.data.show || !this.data.poppable) { | ||||
|             this.initRect(); | ||||
|             this.scrollIntoView(); | ||||
|         } | ||||
|     }, | ||||
|     methods: { | ||||
|         reset: function () { | ||||
|             this.setData({ currentDate: this.getInitialDate(this.data.defaultDate) }); | ||||
|             this.scrollIntoView(); | ||||
|         }, | ||||
|         initRect: function () { | ||||
|             var _this = this; | ||||
|             if (this.contentObserver != null) { | ||||
|                 this.contentObserver.disconnect(); | ||||
|             } | ||||
|             var contentObserver = this.createIntersectionObserver({ | ||||
|                 thresholds: [0, 0.1, 0.9, 1], | ||||
|                 observeAll: true, | ||||
|             }); | ||||
|             this.contentObserver = contentObserver; | ||||
|             contentObserver.relativeTo('.van-calendar__body'); | ||||
|             contentObserver.observe('.month', function (res) { | ||||
|                 if (res.boundingClientRect.top <= res.relativeRect.top) { | ||||
|                     // @ts-ignore
 | ||||
|                     _this.setData({ subtitle: (0, utils_1.formatMonthTitle)(res.dataset.date) }); | ||||
|                 } | ||||
|             }); | ||||
|         }, | ||||
|         limitDateRange: function (date, minDate, maxDate) { | ||||
|             if (minDate === void 0) { minDate = null; } | ||||
|             if (maxDate === void 0) { maxDate = null; } | ||||
|             minDate = minDate || this.data.minDate; | ||||
|             maxDate = maxDate || this.data.maxDate; | ||||
|             if ((0, utils_1.compareDay)(date, minDate) === -1) { | ||||
|                 return minDate; | ||||
|             } | ||||
|             if ((0, utils_1.compareDay)(date, maxDate) === 1) { | ||||
|                 return maxDate; | ||||
|             } | ||||
|             return date; | ||||
|         }, | ||||
|         getInitialDate: function (defaultDate) { | ||||
|             var _this = this; | ||||
|             if (defaultDate === void 0) { defaultDate = null; } | ||||
|             var _a = this.data, type = _a.type, minDate = _a.minDate, maxDate = _a.maxDate, allowSameDay = _a.allowSameDay; | ||||
|             if (!defaultDate) | ||||
|                 return []; | ||||
|             var now = (0, utils_1.getToday)().getTime(); | ||||
|             if (type === 'range') { | ||||
|                 if (!Array.isArray(defaultDate)) { | ||||
|                     defaultDate = []; | ||||
|                 } | ||||
|                 var _b = defaultDate || [], startDay = _b[0], endDay = _b[1]; | ||||
|                 var startDate = getTime(startDay || now); | ||||
|                 var start = this.limitDateRange(startDate, minDate, allowSameDay ? startDate : (0, utils_1.getPrevDay)(new Date(maxDate)).getTime()); | ||||
|                 var date = getTime(endDay || now); | ||||
|                 var end = this.limitDateRange(date, allowSameDay ? date : (0, utils_1.getNextDay)(new Date(minDate)).getTime()); | ||||
|                 return [start, end]; | ||||
|             } | ||||
|             if (type === 'multiple') { | ||||
|                 if (Array.isArray(defaultDate)) { | ||||
|                     return defaultDate.map(function (date) { return _this.limitDateRange(date); }); | ||||
|                 } | ||||
|                 return [this.limitDateRange(now)]; | ||||
|             } | ||||
|             if (!defaultDate || Array.isArray(defaultDate)) { | ||||
|                 defaultDate = now; | ||||
|             } | ||||
|             return this.limitDateRange(defaultDate); | ||||
|         }, | ||||
|         scrollIntoView: function () { | ||||
|             var _this = this; | ||||
|             (0, utils_2.requestAnimationFrame)(function () { | ||||
|                 var _a = _this.data, currentDate = _a.currentDate, type = _a.type, show = _a.show, poppable = _a.poppable, minDate = _a.minDate, maxDate = _a.maxDate; | ||||
|                 if (!currentDate) | ||||
|                     return; | ||||
|                 // @ts-ignore
 | ||||
|                 var targetDate = type === 'single' ? currentDate : currentDate[0]; | ||||
|                 var displayed = show || !poppable; | ||||
|                 if (!targetDate || !displayed) { | ||||
|                     return; | ||||
|                 } | ||||
|                 var months = (0, utils_1.getMonths)(minDate, maxDate); | ||||
|                 months.some(function (month, index) { | ||||
|                     if ((0, utils_1.compareMonth)(month, targetDate) === 0) { | ||||
|                         _this.setData({ scrollIntoView: "month".concat(index) }); | ||||
|                         return true; | ||||
|                     } | ||||
|                     return false; | ||||
|                 }); | ||||
|             }); | ||||
|         }, | ||||
|         onOpen: function () { | ||||
|             this.$emit('open'); | ||||
|         }, | ||||
|         onOpened: function () { | ||||
|             this.$emit('opened'); | ||||
|         }, | ||||
|         onClose: function () { | ||||
|             this.$emit('close'); | ||||
|         }, | ||||
|         onClosed: function () { | ||||
|             this.$emit('closed'); | ||||
|         }, | ||||
|         onClickDay: function (event) { | ||||
|             if (this.data.readonly) { | ||||
|                 return; | ||||
|             } | ||||
|             var date = event.detail.date; | ||||
|             var _a = this.data, type = _a.type, currentDate = _a.currentDate, allowSameDay = _a.allowSameDay; | ||||
|             if (type === 'range') { | ||||
|                 // @ts-ignore
 | ||||
|                 var startDay_1 = currentDate[0], endDay = currentDate[1]; | ||||
|                 if (startDay_1 && !endDay) { | ||||
|                     var compareToStart = (0, utils_1.compareDay)(date, startDay_1); | ||||
|                     if (compareToStart === 1) { | ||||
|                         var days_1 = this.selectComponent('.month').data.days; | ||||
|                         days_1.some(function (day, index) { | ||||
|                             var isDisabled = day.type === 'disabled' && | ||||
|                                 getTime(startDay_1) < getTime(day.date) && | ||||
|                                 getTime(day.date) < getTime(date); | ||||
|                             if (isDisabled) { | ||||
|                                 (date = days_1[index - 1].date); | ||||
|                             } | ||||
|                             return isDisabled; | ||||
|                         }); | ||||
|                         this.select([startDay_1, date], true); | ||||
|                     } | ||||
|                     else if (compareToStart === -1) { | ||||
|                         this.select([date, null]); | ||||
|                     } | ||||
|                     else if (allowSameDay) { | ||||
|                         this.select([date, date], true); | ||||
|                     } | ||||
|                 } | ||||
|                 else { | ||||
|                     this.select([date, null]); | ||||
|                 } | ||||
|             } | ||||
|             else if (type === 'multiple') { | ||||
|                 var selectedIndex_1; | ||||
|                 // @ts-ignore
 | ||||
|                 var selected = currentDate.some(function (dateItem, index) { | ||||
|                     var equal = (0, utils_1.compareDay)(dateItem, date) === 0; | ||||
|                     if (equal) { | ||||
|                         selectedIndex_1 = index; | ||||
|                     } | ||||
|                     return equal; | ||||
|                 }); | ||||
|                 if (selected) { | ||||
|                     // @ts-ignore
 | ||||
|                     var cancelDate = currentDate.splice(selectedIndex_1, 1); | ||||
|                     this.setData({ currentDate: currentDate }); | ||||
|                     this.unselect(cancelDate); | ||||
|                 } | ||||
|                 else { | ||||
|                     // @ts-ignore
 | ||||
|                     this.select(__spreadArray(__spreadArray([], currentDate, true), [date], false)); | ||||
|                 } | ||||
|             } | ||||
|             else { | ||||
|                 this.select(date, true); | ||||
|             } | ||||
|         }, | ||||
|         unselect: function (dateArray) { | ||||
|             var date = dateArray[0]; | ||||
|             if (date) { | ||||
|                 this.$emit('unselect', (0, utils_1.copyDates)(date)); | ||||
|             } | ||||
|         }, | ||||
|         select: function (date, complete) { | ||||
|             if (complete && this.data.type === 'range') { | ||||
|                 var valid = this.checkRange(date); | ||||
|                 if (!valid) { | ||||
|                     // auto selected to max range if showConfirm
 | ||||
|                     if (this.data.showConfirm) { | ||||
|                         this.emit([ | ||||
|                             date[0], | ||||
|                             (0, utils_1.getDayByOffset)(date[0], this.data.maxRange - 1), | ||||
|                         ]); | ||||
|                     } | ||||
|                     else { | ||||
|                         this.emit(date); | ||||
|                     } | ||||
|                     return; | ||||
|                 } | ||||
|             } | ||||
|             this.emit(date); | ||||
|             if (complete && !this.data.showConfirm) { | ||||
|                 this.onConfirm(); | ||||
|             } | ||||
|         }, | ||||
|         emit: function (date) { | ||||
|             this.setData({ | ||||
|                 currentDate: Array.isArray(date) ? date.map(getTime) : getTime(date), | ||||
|             }); | ||||
|             this.$emit('select', (0, utils_1.copyDates)(date)); | ||||
|         }, | ||||
|         checkRange: function (date) { | ||||
|             var _a = this.data, maxRange = _a.maxRange, rangePrompt = _a.rangePrompt, showRangePrompt = _a.showRangePrompt; | ||||
|             if (maxRange && (0, utils_1.calcDateNum)(date) > maxRange) { | ||||
|                 if (showRangePrompt) { | ||||
|                     (0, toast_1.default)({ | ||||
|                         context: this, | ||||
|                         message: rangePrompt || "\u9009\u62E9\u5929\u6570\u4E0D\u80FD\u8D85\u8FC7 ".concat(maxRange, " \u5929"), | ||||
|                     }); | ||||
|                 } | ||||
|                 this.$emit('over-range'); | ||||
|                 return false; | ||||
|             } | ||||
|             return true; | ||||
|         }, | ||||
|         onConfirm: function () { | ||||
|             var _this = this; | ||||
|             if (this.data.type === 'range' && | ||||
|                 !this.checkRange(this.data.currentDate)) { | ||||
|                 return; | ||||
|             } | ||||
|             wx.nextTick(function () { | ||||
|                 // @ts-ignore
 | ||||
|                 _this.$emit('confirm', (0, utils_1.copyDates)(_this.data.currentDate)); | ||||
|             }); | ||||
|         }, | ||||
|         onClickSubtitle: function (event) { | ||||
|             this.$emit('click-subtitle', event); | ||||
|         }, | ||||
|     }, | ||||
| }); | ||||
| @ -0,0 +1,10 @@@@ -0,0 +1,10 @@ | ||||
| { | ||||
|   "component": true, | ||||
|   "usingComponents": { | ||||
|     "header": "./components/header/index", | ||||
|     "month": "./components/month/index", | ||||
|     "van-button": "../button/index", | ||||
|     "van-popup": "../popup/index", | ||||
|     "van-toast": "../toast/index" | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,26 @@@@ -0,0 +1,26 @@ | ||||
| <wxs src="./index.wxs" module="computed" /> | ||||
| <wxs src="../wxs/utils.wxs" module="utils" /> | ||||
| 
 | ||||
| <import src="./calendar.wxml" /> | ||||
| 
 | ||||
| <van-popup | ||||
|   wx:if="{{ poppable }}" | ||||
|   custom-class="van-calendar__popup--{{ position }}" | ||||
|   close-icon-class="van-calendar__close-icon" | ||||
|   show="{{ show }}" | ||||
|   round="{{ round }}" | ||||
|   position="{{ position }}" | ||||
|   closeable="{{ showTitle || showSubtitle }}" | ||||
|   close-on-click-overlay="{{ closeOnClickOverlay }}" | ||||
|   safe-area-inset-bottom="{{ safeAreaInsetBottom }}" | ||||
|   bind:enter="onOpen" | ||||
|   bind:close="onClose" | ||||
|   bind:after-enter="onOpened" | ||||
|   bind:after-leave="onClosed" | ||||
| > | ||||
|   <include src="./calendar.wxml" /> | ||||
| </van-popup> | ||||
| 
 | ||||
| <include wx:else src="./calendar.wxml" /> | ||||
| 
 | ||||
| <van-toast id="van-toast" /> | ||||
| @ -0,0 +1,37 @@@@ -0,0 +1,37 @@ | ||||
| /* eslint-disable */ | ||||
| var utils = require('./utils.wxs'); | ||||
| 
 | ||||
| function getMonths(minDate, maxDate) { | ||||
|   var months = []; | ||||
|   var cursor = getDate(minDate); | ||||
| 
 | ||||
|   cursor.setDate(1); | ||||
| 
 | ||||
|   do { | ||||
|     months.push(cursor.getTime()); | ||||
|     cursor.setMonth(cursor.getMonth() + 1); | ||||
|   } while (utils.compareMonth(cursor, getDate(maxDate)) !== 1); | ||||
| 
 | ||||
|   return months; | ||||
| } | ||||
| 
 | ||||
| function getButtonDisabled(type, currentDate, minRange) { | ||||
|   if (currentDate == null) { | ||||
|     return true; | ||||
|   } | ||||
| 
 | ||||
|   if (type === 'range') { | ||||
|     return !currentDate[0] || !currentDate[1]; | ||||
|   } | ||||
| 
 | ||||
|   if (type === 'multiple') { | ||||
|     return currentDate.length < minRange; | ||||
|   } | ||||
| 
 | ||||
|   return !currentDate; | ||||
| } | ||||
| 
 | ||||
| module.exports = { | ||||
|   getMonths: getMonths, | ||||
|   getButtonDisabled: getButtonDisabled | ||||
| }; | ||||
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| @import '../common/index.wxss';.van-calendar{background-color:var(--calendar-background-color,#fff);display:flex;flex-direction:column;height:var(--calendar-height,100%)}.van-calendar__close-icon{top:11px}.van-calendar__popup--bottom,.van-calendar__popup--top{height:var(--calendar-popup-height,90%)}.van-calendar__popup--left,.van-calendar__popup--right{height:100%}.van-calendar__body{-webkit-overflow-scrolling:touch;flex:1;overflow:auto}.van-calendar__footer{flex-shrink:0;padding:0 var(--padding-md,16px)}.van-calendar__footer--safe-area-inset-bottom{padding-bottom:env(safe-area-inset-bottom)}.van-calendar__footer+.van-calendar__footer,.van-calendar__footer:empty{display:none}.van-calendar__footer:empty+.van-calendar__footer{display:block!important}.van-calendar__confirm{height:var(--calendar-confirm-button-height,36px)!important;line-height:var(--calendar-confirm-button-line-height,34px)!important;margin:var(--calendar-confirm-button-margin,7px 0)!important} | ||||
| @ -0,0 +1,12 @@@@ -0,0 +1,12 @@ | ||||
| export declare const ROW_HEIGHT = 64; | ||||
| export declare function formatMonthTitle(date: Date): string; | ||||
| export declare function compareMonth(date1: Date | number, date2: Date | number): 0 | 1 | -1; | ||||
| export declare function compareDay(day1: Date | number, day2: Date | number): 0 | 1 | -1; | ||||
| export declare function getDayByOffset(date: Date, offset: number): Date; | ||||
| export declare function getPrevDay(date: Date): Date; | ||||
| export declare function getNextDay(date: Date): Date; | ||||
| export declare function getToday(): Date; | ||||
| export declare function calcDateNum(date: [Date, Date]): number; | ||||
| export declare function copyDates(dates: Date | Date[]): Date | Date[]; | ||||
| export declare function getMonthEndDay(year: number, month: number): number; | ||||
| export declare function getMonths(minDate: number, maxDate: number): number[]; | ||||
| @ -0,0 +1,97 @@@@ -0,0 +1,97 @@ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| exports.getMonths = exports.getMonthEndDay = exports.copyDates = exports.calcDateNum = exports.getToday = exports.getNextDay = exports.getPrevDay = exports.getDayByOffset = exports.compareDay = exports.compareMonth = exports.formatMonthTitle = exports.ROW_HEIGHT = void 0; | ||||
| exports.ROW_HEIGHT = 64; | ||||
| function formatMonthTitle(date) { | ||||
|     if (!(date instanceof Date)) { | ||||
|         date = new Date(date); | ||||
|     } | ||||
|     return "".concat(date.getFullYear(), "\u5E74").concat(date.getMonth() + 1, "\u6708"); | ||||
| } | ||||
| exports.formatMonthTitle = formatMonthTitle; | ||||
| function compareMonth(date1, date2) { | ||||
|     if (!(date1 instanceof Date)) { | ||||
|         date1 = new Date(date1); | ||||
|     } | ||||
|     if (!(date2 instanceof Date)) { | ||||
|         date2 = new Date(date2); | ||||
|     } | ||||
|     var year1 = date1.getFullYear(); | ||||
|     var year2 = date2.getFullYear(); | ||||
|     var month1 = date1.getMonth(); | ||||
|     var month2 = date2.getMonth(); | ||||
|     if (year1 === year2) { | ||||
|         return month1 === month2 ? 0 : month1 > month2 ? 1 : -1; | ||||
|     } | ||||
|     return year1 > year2 ? 1 : -1; | ||||
| } | ||||
| exports.compareMonth = compareMonth; | ||||
| function compareDay(day1, day2) { | ||||
|     if (!(day1 instanceof Date)) { | ||||
|         day1 = new Date(day1); | ||||
|     } | ||||
|     if (!(day2 instanceof Date)) { | ||||
|         day2 = new Date(day2); | ||||
|     } | ||||
|     var compareMonthResult = compareMonth(day1, day2); | ||||
|     if (compareMonthResult === 0) { | ||||
|         var date1 = day1.getDate(); | ||||
|         var date2 = day2.getDate(); | ||||
|         return date1 === date2 ? 0 : date1 > date2 ? 1 : -1; | ||||
|     } | ||||
|     return compareMonthResult; | ||||
| } | ||||
| exports.compareDay = compareDay; | ||||
| function getDayByOffset(date, offset) { | ||||
|     date = new Date(date); | ||||
|     date.setDate(date.getDate() + offset); | ||||
|     return date; | ||||
| } | ||||
| exports.getDayByOffset = getDayByOffset; | ||||
| function getPrevDay(date) { | ||||
|     return getDayByOffset(date, -1); | ||||
| } | ||||
| exports.getPrevDay = getPrevDay; | ||||
| function getNextDay(date) { | ||||
|     return getDayByOffset(date, 1); | ||||
| } | ||||
| exports.getNextDay = getNextDay; | ||||
| function getToday() { | ||||
|     var today = new Date(); | ||||
|     today.setHours(0, 0, 0, 0); | ||||
|     return today; | ||||
| } | ||||
| exports.getToday = getToday; | ||||
| function calcDateNum(date) { | ||||
|     var day1 = new Date(date[0]).getTime(); | ||||
|     var day2 = new Date(date[1]).getTime(); | ||||
|     return (day2 - day1) / (1000 * 60 * 60 * 24) + 1; | ||||
| } | ||||
| exports.calcDateNum = calcDateNum; | ||||
| function copyDates(dates) { | ||||
|     if (Array.isArray(dates)) { | ||||
|         return dates.map(function (date) { | ||||
|             if (date === null) { | ||||
|                 return date; | ||||
|             } | ||||
|             return new Date(date); | ||||
|         }); | ||||
|     } | ||||
|     return new Date(dates); | ||||
| } | ||||
| exports.copyDates = copyDates; | ||||
| function getMonthEndDay(year, month) { | ||||
|     return 32 - new Date(year, month - 1, 32).getDate(); | ||||
| } | ||||
| exports.getMonthEndDay = getMonthEndDay; | ||||
| function getMonths(minDate, maxDate) { | ||||
|     var months = []; | ||||
|     var cursor = new Date(minDate); | ||||
|     cursor.setDate(1); | ||||
|     do { | ||||
|         months.push(cursor.getTime()); | ||||
|         cursor.setMonth(cursor.getMonth() + 1); | ||||
|     } while (compareMonth(cursor, maxDate) !== 1); | ||||
|     return months; | ||||
| } | ||||
| exports.getMonths = getMonths; | ||||
| @ -0,0 +1,25 @@@@ -0,0 +1,25 @@ | ||||
| /* eslint-disable */ | ||||
| function getMonthEndDay(year, month) { | ||||
|   return 32 -  getDate(year, month - 1, 32).getDate(); | ||||
| } | ||||
| 
 | ||||
| function compareMonth(date1, date2) { | ||||
|   date1 = getDate(date1); | ||||
|   date2 = getDate(date2); | ||||
| 
 | ||||
|   var year1 = date1.getFullYear(); | ||||
|   var year2 = date2.getFullYear(); | ||||
|   var month1 = date1.getMonth(); | ||||
|   var month2 = date2.getMonth(); | ||||
| 
 | ||||
|   if (year1 === year2) { | ||||
|     return month1 === month2 ? 0 : month1 > month2 ? 1 : -1; | ||||
|   } | ||||
| 
 | ||||
|   return year1 > year2 ? 1 : -1; | ||||
| } | ||||
| 
 | ||||
| module.exports = { | ||||
|   getMonthEndDay: getMonthEndDay, | ||||
|   compareMonth: compareMonth | ||||
| }; | ||||
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| export {}; | ||||
| @ -0,0 +1,51 @@@@ -0,0 +1,51 @@ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| var link_1 = require("../mixins/link"); | ||||
| var component_1 = require("../common/component"); | ||||
| (0, component_1.VantComponent)({ | ||||
|     classes: [ | ||||
|         'num-class', | ||||
|         'desc-class', | ||||
|         'thumb-class', | ||||
|         'title-class', | ||||
|         'price-class', | ||||
|         'origin-price-class', | ||||
|     ], | ||||
|     mixins: [link_1.link], | ||||
|     props: { | ||||
|         tag: String, | ||||
|         num: String, | ||||
|         desc: String, | ||||
|         thumb: String, | ||||
|         title: String, | ||||
|         price: { | ||||
|             type: String, | ||||
|             observer: 'updatePrice', | ||||
|         }, | ||||
|         centered: Boolean, | ||||
|         lazyLoad: Boolean, | ||||
|         thumbLink: String, | ||||
|         originPrice: String, | ||||
|         thumbMode: { | ||||
|             type: String, | ||||
|             value: 'aspectFit', | ||||
|         }, | ||||
|         currency: { | ||||
|             type: String, | ||||
|             value: '¥', | ||||
|         }, | ||||
|     }, | ||||
|     methods: { | ||||
|         updatePrice: function () { | ||||
|             var price = this.data.price; | ||||
|             var priceArr = price.toString().split('.'); | ||||
|             this.setData({ | ||||
|                 integerStr: priceArr[0], | ||||
|                 decimalStr: priceArr[1] ? ".".concat(priceArr[1]) : '', | ||||
|             }); | ||||
|         }, | ||||
|         onClickThumb: function () { | ||||
|             this.jumpLink('thumbLink'); | ||||
|         }, | ||||
|     }, | ||||
| }); | ||||
| @ -0,0 +1,6 @@@@ -0,0 +1,6 @@ | ||||
| { | ||||
|   "component": true, | ||||
|   "usingComponents": { | ||||
|     "van-tag": "../tag/index" | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,56 @@@@ -0,0 +1,56 @@ | ||||
| <wxs src="../wxs/utils.wxs" module="utils" /> | ||||
| 
 | ||||
| <view class="custom-class van-card"> | ||||
|   <view class="{{ utils.bem('card__header', { center: centered }) }}"> | ||||
|     <view class="van-card__thumb" bind:tap="onClickThumb"> | ||||
|       <image | ||||
|         wx:if="{{ thumb }}" | ||||
|         src="{{ thumb }}" | ||||
|         mode="{{ thumbMode }}" | ||||
|         lazy-load="{{ lazyLoad }}" | ||||
|         class="van-card__img thumb-class" | ||||
|       /> | ||||
|       <slot wx:else name="thumb" /> | ||||
|       <van-tag | ||||
|         wx:if="{{ tag }}" | ||||
|         mark | ||||
|         type="danger" | ||||
|         custom-class="van-card__tag" | ||||
|       > | ||||
|         {{ tag }} | ||||
|       </van-tag> | ||||
|       <slot wx:else name="tag" /> | ||||
|     </view> | ||||
| 
 | ||||
|     <view class="van-card__content {{ utils.bem('card__content', { center: centered }) }}"> | ||||
|       <view> | ||||
|         <view wx:if="{{ title }}" class="van-card__title title-class">{{ title }}</view> | ||||
|         <slot wx:else name="title" /> | ||||
| 
 | ||||
|         <view wx:if="{{ desc }}" class="van-card__desc desc-class">{{ desc }}</view> | ||||
|         <slot wx:else name="desc" /> | ||||
| 
 | ||||
|         <slot name="tags" /> | ||||
|       </view> | ||||
| 
 | ||||
|       <view class="van-card__bottom"> | ||||
|         <slot name="price-top" /> | ||||
|         <view wx:if="{{ price || price === 0 }}" class="van-card__price price-class"> | ||||
|           <text>{{ currency }}</text> | ||||
|           <text class="van-card__price-integer">{{ integerStr }}</text> | ||||
|           <text class="van-card__price-decimal">{{ decimalStr }}</text> | ||||
|         </view> | ||||
|         <slot wx:else name="price" /> | ||||
|         <view wx:if="{{ originPrice || originPrice === 0 }}" class="van-card__origin-price origin-price-class">{{ currency }} {{ originPrice }}</view> | ||||
|         <slot wx:else name="origin-price" /> | ||||
|         <view wx:if="{{ num }}" class="van-card__num num-class">x {{ num }}</view> | ||||
|         <slot wx:else  name="num" /> | ||||
|         <slot name="bottom" /> | ||||
|       </view> | ||||
|     </view> | ||||
|   </view> | ||||
| 
 | ||||
|   <view class="van-card__footer"> | ||||
|     <slot name="footer" /> | ||||
|   </view> | ||||
| </view> | ||||
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| @import '../common/index.wxss';.van-card{background-color:var(--card-background-color,#fafafa);box-sizing:border-box;color:var(--card-text-color,#323233);font-size:var(--card-font-size,12px);padding:var(--card-padding,8px 16px);position:relative}.van-card__header{display:flex}.van-card__header--center{align-items:center;justify-content:center}.van-card__thumb{flex:none;height:var(--card-thumb-size,88px);margin-right:var(--padding-xs,8px);position:relative;width:var(--card-thumb-size,88px)}.van-card__thumb:empty{display:none}.van-card__img{border-radius:8px;height:100%;width:100%}.van-card__content{display:flex;flex:1;flex-direction:column;justify-content:space-between;min-height:var(--card-thumb-size,88px);min-width:0;position:relative}.van-card__content--center{justify-content:center}.van-card__desc,.van-card__title{word-wrap:break-word}.van-card__title{font-weight:700;line-height:var(--card-title-line-height,16px)}.van-card__desc{color:var(--card-desc-color,#646566);line-height:var(--card-desc-line-height,20px)}.van-card__bottom{line-height:20px}.van-card__price{color:var(--card-price-color,#ee0a24);display:inline-block;font-size:var(--card-price-font-size,12px);font-weight:700}.van-card__price-integer{font-size:var(--card-price-integer-font-size,16px)}.van-card__price-decimal,.van-card__price-integer{font-family:var(--card-price-font-family,Avenir-Heavy,PingFang SC,Helvetica Neue,Arial,sans-serif)}.van-card__origin-price{color:var(--card-origin-price-color,#646566);display:inline-block;font-size:var(--card-origin-price-font-size,10px);margin-left:5px;text-decoration:line-through}.van-card__num{float:right}.van-card__tag{left:0;position:absolute!important;top:2px}.van-card__footer{flex:none;text-align:right;width:100%} | ||||
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| export {}; | ||||
| @ -0,0 +1,222 @@@@ -0,0 +1,222 @@ | ||||
| "use strict"; | ||||
| var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) { | ||||
|     if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) { | ||||
|         if (ar || !(i in from)) { | ||||
|             if (!ar) ar = Array.prototype.slice.call(from, 0, i); | ||||
|             ar[i] = from[i]; | ||||
|         } | ||||
|     } | ||||
|     return to.concat(ar || Array.prototype.slice.call(from)); | ||||
| }; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| var component_1 = require("../common/component"); | ||||
| var FieldName; | ||||
| (function (FieldName) { | ||||
|     FieldName["TEXT"] = "text"; | ||||
|     FieldName["VALUE"] = "value"; | ||||
|     FieldName["CHILDREN"] = "children"; | ||||
| })(FieldName || (FieldName = {})); | ||||
| var defaultFieldNames = { | ||||
|     text: FieldName.TEXT, | ||||
|     value: FieldName.VALUE, | ||||
|     children: FieldName.CHILDREN, | ||||
| }; | ||||
| (0, component_1.VantComponent)({ | ||||
|     props: { | ||||
|         title: String, | ||||
|         value: { | ||||
|             type: String, | ||||
|         }, | ||||
|         placeholder: { | ||||
|             type: String, | ||||
|             value: '请选择', | ||||
|         }, | ||||
|         activeColor: { | ||||
|             type: String, | ||||
|             value: '#1989fa', | ||||
|         }, | ||||
|         options: { | ||||
|             type: Array, | ||||
|             value: [], | ||||
|         }, | ||||
|         swipeable: { | ||||
|             type: Boolean, | ||||
|             value: false, | ||||
|         }, | ||||
|         closeable: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|         showHeader: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|         closeIcon: { | ||||
|             type: String, | ||||
|             value: 'cross', | ||||
|         }, | ||||
|         fieldNames: { | ||||
|             type: Object, | ||||
|             value: defaultFieldNames, | ||||
|             observer: 'updateFieldNames', | ||||
|         }, | ||||
|     }, | ||||
|     data: { | ||||
|         tabs: [], | ||||
|         activeTab: 0, | ||||
|         textKey: FieldName.TEXT, | ||||
|         valueKey: FieldName.VALUE, | ||||
|         childrenKey: FieldName.CHILDREN, | ||||
|         innerValue: '', | ||||
|     }, | ||||
|     watch: { | ||||
|         options: function () { | ||||
|             this.updateTabs(); | ||||
|         }, | ||||
|         value: function (newVal) { | ||||
|             this.updateValue(newVal); | ||||
|         }, | ||||
|     }, | ||||
|     created: function () { | ||||
|         this.updateTabs(); | ||||
|     }, | ||||
|     methods: { | ||||
|         updateValue: function (val) { | ||||
|             var _this = this; | ||||
|             if (val !== undefined) { | ||||
|                 var values = this.data.tabs.map(function (tab) { return tab.selected && tab.selected[_this.data.valueKey]; }); | ||||
|                 if (values.indexOf(val) > -1) { | ||||
|                     return; | ||||
|                 } | ||||
|             } | ||||
|             this.innerValue = val; | ||||
|             this.updateTabs(); | ||||
|         }, | ||||
|         updateFieldNames: function () { | ||||
|             var _a = this.data.fieldNames || defaultFieldNames, _b = _a.text, text = _b === void 0 ? 'text' : _b, _c = _a.value, value = _c === void 0 ? 'value' : _c, _d = _a.children, children = _d === void 0 ? 'children' : _d; | ||||
|             this.setData({ | ||||
|                 textKey: text, | ||||
|                 valueKey: value, | ||||
|                 childrenKey: children, | ||||
|             }); | ||||
|         }, | ||||
|         getSelectedOptionsByValue: function (options, value) { | ||||
|             for (var i = 0; i < options.length; i++) { | ||||
|                 var option = options[i]; | ||||
|                 if (option[this.data.valueKey] === value) { | ||||
|                     return [option]; | ||||
|                 } | ||||
|                 if (option[this.data.childrenKey]) { | ||||
|                     var selectedOptions = this.getSelectedOptionsByValue(option[this.data.childrenKey], value); | ||||
|                     if (selectedOptions) { | ||||
|                         return __spreadArray([option], selectedOptions, true); | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         }, | ||||
|         updateTabs: function () { | ||||
|             var _this = this; | ||||
|             var options = this.data.options; | ||||
|             var innerValue = this.innerValue; | ||||
|             if (!options.length) { | ||||
|                 return; | ||||
|             } | ||||
|             if (innerValue !== undefined) { | ||||
|                 var selectedOptions = this.getSelectedOptionsByValue(options, innerValue); | ||||
|                 if (selectedOptions) { | ||||
|                     var optionsCursor_1 = options; | ||||
|                     var tabs_1 = selectedOptions.map(function (option) { | ||||
|                         var tab = { | ||||
|                             options: optionsCursor_1, | ||||
|                             selected: option, | ||||
|                         }; | ||||
|                         var next = optionsCursor_1.find(function (item) { return item[_this.data.valueKey] === option[_this.data.valueKey]; }); | ||||
|                         if (next) { | ||||
|                             optionsCursor_1 = next[_this.data.childrenKey]; | ||||
|                         } | ||||
|                         return tab; | ||||
|                     }); | ||||
|                     if (optionsCursor_1) { | ||||
|                         tabs_1.push({ | ||||
|                             options: optionsCursor_1, | ||||
|                             selected: null, | ||||
|                         }); | ||||
|                     } | ||||
|                     this.setData({ | ||||
|                         tabs: tabs_1, | ||||
|                     }); | ||||
|                     wx.nextTick(function () { | ||||
|                         _this.setData({ | ||||
|                             activeTab: tabs_1.length - 1, | ||||
|                         }); | ||||
|                     }); | ||||
|                     return; | ||||
|                 } | ||||
|             } | ||||
|             this.setData({ | ||||
|                 tabs: [ | ||||
|                     { | ||||
|                         options: options, | ||||
|                         selected: null, | ||||
|                     }, | ||||
|                 ], | ||||
|             }); | ||||
|         }, | ||||
|         onClose: function () { | ||||
|             this.$emit('close'); | ||||
|         }, | ||||
|         onClickTab: function (e) { | ||||
|             var _a = e.detail, tabIndex = _a.index, title = _a.title; | ||||
|             this.$emit('click-tab', { title: title, tabIndex: tabIndex }); | ||||
|             this.setData({ | ||||
|                 activeTab: tabIndex, | ||||
|             }); | ||||
|         }, | ||||
|         // 选中
 | ||||
|         onSelect: function (e) { | ||||
|             var _this = this; | ||||
|             var _a = e.currentTarget.dataset, option = _a.option, tabIndex = _a.tabIndex; | ||||
|             if (option && option.disabled) { | ||||
|                 return; | ||||
|             } | ||||
|             var _b = this.data, valueKey = _b.valueKey, childrenKey = _b.childrenKey; | ||||
|             var tabs = this.data.tabs; | ||||
|             tabs[tabIndex].selected = option; | ||||
|             if (tabs.length > tabIndex + 1) { | ||||
|                 tabs = tabs.slice(0, tabIndex + 1); | ||||
|             } | ||||
|             if (option[childrenKey]) { | ||||
|                 var nextTab = { | ||||
|                     options: option[childrenKey], | ||||
|                     selected: null, | ||||
|                 }; | ||||
|                 if (tabs[tabIndex + 1]) { | ||||
|                     tabs[tabIndex + 1] = nextTab; | ||||
|                 } | ||||
|                 else { | ||||
|                     tabs.push(nextTab); | ||||
|                 } | ||||
|                 wx.nextTick(function () { | ||||
|                     _this.setData({ | ||||
|                         activeTab: tabIndex + 1, | ||||
|                     }); | ||||
|                 }); | ||||
|             } | ||||
|             this.setData({ | ||||
|                 tabs: tabs, | ||||
|             }); | ||||
|             var selectedOptions = tabs.map(function (tab) { return tab.selected; }).filter(Boolean); | ||||
|             var value = option[valueKey]; | ||||
|             var params = { | ||||
|                 value: value, | ||||
|                 tabIndex: tabIndex, | ||||
|                 selectedOptions: selectedOptions, | ||||
|             }; | ||||
|             this.innerValue = value; | ||||
|             this.$emit('change', params); | ||||
|             if (!option[childrenKey]) { | ||||
|                 this.$emit('finish', params); | ||||
|             } | ||||
|         }, | ||||
|     }, | ||||
| }); | ||||
| @ -0,0 +1,8 @@@@ -0,0 +1,8 @@ | ||||
| { | ||||
|   "component": true, | ||||
|   "usingComponents": { | ||||
|     "van-icon": "../icon/index", | ||||
|     "van-tab":  "../tab/index", | ||||
|     "van-tabs": "../tabs/index" | ||||
|   } | ||||
| } | ||||
| @ -0,0 +1,53 @@@@ -0,0 +1,53 @@ | ||||
| <wxs src="./index.wxs" module="utils" /> | ||||
| 
 | ||||
| <view wx:if="{{ showHeader }}" class="van-cascader__header"> | ||||
|   <text class="van-cascader__title"><slot name="title"></slot>{{ title }}</text> | ||||
|   <van-icon | ||||
|     wx:if="{{ closeable }}" | ||||
|     name="{{ closeIcon }}" | ||||
|     class="van-cascader__close-icon" | ||||
|     bind:tap="onClose" | ||||
|   /> | ||||
| </view> | ||||
| 
 | ||||
| <van-tabs | ||||
|   active="{{ activeTab }}" | ||||
|   custom-class="van-cascader__tabs" | ||||
|   wrap-class="van-cascader__tabs-wrap" | ||||
|   tab-class="van-cascader__tab" | ||||
|   color="{{ activeColor }}" | ||||
|   border="{{ false }}" | ||||
|   swipeable="{{ swipeable }}" | ||||
|   bind:click="onClickTab" | ||||
| > | ||||
|   <van-tab | ||||
|     wx:for="{{ tabs }}" | ||||
|     wx:for-item="tab" | ||||
|     wx:for-index="tabIndex" | ||||
|     wx:key="tabIndex" | ||||
|     title="{{ tab.selected ? tab.selected[textKey] : placeholder }}" | ||||
|     style="width: 100%;" | ||||
|     title-style="{{ !tab.selected ? 'color: #969799;font-weight:normal;' : '' }}" | ||||
|   > | ||||
|     <!-- 暂不支持 --> | ||||
|     <!-- <slot name="options-top"></slot> --> | ||||
| 
 | ||||
|     <view class="van-cascader__options"> | ||||
|       <view | ||||
|         wx:for="{{ tab.options }}" | ||||
|         wx:for-item="option" | ||||
|         wx:key="index" | ||||
|         class="{{ option.className }} {{ utils.optionClass(tab, valueKey, option) }}" | ||||
|         style="{{ utils.optionStyle({ tab, valueKey, option, activeColor }) }}" | ||||
|         data-option="{{ option }}" | ||||
|         data-tab-index="{{ tabIndex }}" | ||||
|         bind:tap="onSelect" | ||||
|       > | ||||
|         <text>{{ option[textKey] }}</text> | ||||
|         <van-icon wx:if="{{ utils.isSelected(tab, valueKey, option) }}" name="success" size="18" /> | ||||
|       </view> | ||||
|     </view> | ||||
|     <!-- 暂不支持 --> | ||||
|     <!-- <slot name="options-bottom"></slot> --> | ||||
|   </van-tab> | ||||
| </van-tabs> | ||||
| @ -0,0 +1,24 @@@@ -0,0 +1,24 @@ | ||||
| var utils = require('../wxs/utils.wxs'); | ||||
| var style = require('../wxs/style.wxs'); | ||||
| 
 | ||||
| function isSelected(tab, valueKey, option) { | ||||
|   return tab.selected && tab.selected[valueKey] === option[valueKey] | ||||
| } | ||||
| 
 | ||||
| function optionClass(tab, valueKey, option) { | ||||
|   return utils.bem('cascader__option', { selected: isSelected(tab, valueKey, option), disabled: option.disabled }) | ||||
| } | ||||
| 
 | ||||
| function optionStyle(data) { | ||||
|   var color = data.option.color || (isSelected(data.tab, data.valueKey, data.option) ? data.activeColor : undefined); | ||||
|   return style({ | ||||
|     color | ||||
|   }); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| module.exports = { | ||||
|   isSelected: isSelected, | ||||
|   optionClass: optionClass, | ||||
|   optionStyle: optionStyle, | ||||
| }; | ||||
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| @import '../common/index.wxss';.van-cascader__header{align-items:center;display:flex;height:48px;justify-content:space-between;padding:0 16px}.van-cascader__title{font-size:16px;font-weight:600;line-height:20px}.van-cascader__close-icon{color:#c8c9cc;font-size:22px;height:22px}.van-cascader__tabs-wrap{height:48px!important;padding:0 8px}.van-cascader__tab{color:#323233!important;flex:none!important;font-weight:600!important;padding:0 8px!important}.van-cascader__tab--unselected{color:#969799!important;font-weight:400!important}.van-cascader__option{align-items:center;cursor:pointer;display:flex;font-size:14px;justify-content:space-between;line-height:20px;padding:10px 16px}.van-cascader__option:active{background-color:#f2f3f5}.van-cascader__option--selected{color:#1989fa;font-weight:600}.van-cascader__option--disabled{color:#c8c9cc;cursor:not-allowed}.van-cascader__option--disabled:active{background-color:initial}.van-cascader__options{-webkit-overflow-scrolling:touch;box-sizing:border-box;height:384px;overflow-y:auto;padding-top:6px} | ||||
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| export {}; | ||||
| @ -0,0 +1,13 @@@@ -0,0 +1,13 @@ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| var component_1 = require("../common/component"); | ||||
| (0, component_1.VantComponent)({ | ||||
|     props: { | ||||
|         title: String, | ||||
|         border: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|         inset: Boolean, | ||||
|     }, | ||||
| }); | ||||
| @ -0,0 +1,3 @@@@ -0,0 +1,3 @@ | ||||
| { | ||||
|   "component": true | ||||
| } | ||||
| @ -0,0 +1,11 @@@@ -0,0 +1,11 @@ | ||||
| <wxs src="../wxs/utils.wxs" module="utils" /> | ||||
| 
 | ||||
| <view | ||||
|   wx:if="{{ title }}" | ||||
|   class="{{ utils.bem('cell-group__title', { inset }) }}" | ||||
| > | ||||
|   {{ title }} | ||||
| </view> | ||||
| <view class="custom-class {{ utils.bem('cell-group', { inset }) }} {{ border ? 'van-hairline--top-bottom' : '' }}"> | ||||
|   <slot /> | ||||
| </view> | ||||
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| @import '../common/index.wxss';.van-cell-group--inset{border-radius:var(--cell-group-inset-border-radius,8px);margin:var(--cell-group-inset-padding,0 16px);overflow:hidden}.van-cell-group__title{color:var(--cell-group-title-color,#969799);font-size:var(--cell-group-title-font-size,14px);line-height:var(--cell-group-title-line-height,16px);padding:var(--cell-group-title-padding,16px 16px 8px)}.van-cell-group__title--inset{padding:var(--cell-group-inset-title-padding,16px 16px 8px 32px)} | ||||
| @ -0,0 +1 @@@@ -0,0 +1 @@ | ||||
| export {}; | ||||
| @ -0,0 +1,40 @@@@ -0,0 +1,40 @@ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| var link_1 = require("../mixins/link"); | ||||
| var component_1 = require("../common/component"); | ||||
| (0, component_1.VantComponent)({ | ||||
|     classes: [ | ||||
|         'title-class', | ||||
|         'label-class', | ||||
|         'value-class', | ||||
|         'right-icon-class', | ||||
|         'hover-class', | ||||
|     ], | ||||
|     mixins: [link_1.link], | ||||
|     props: { | ||||
|         title: null, | ||||
|         value: null, | ||||
|         icon: String, | ||||
|         size: String, | ||||
|         label: String, | ||||
|         center: Boolean, | ||||
|         isLink: Boolean, | ||||
|         required: Boolean, | ||||
|         clickable: Boolean, | ||||
|         titleWidth: String, | ||||
|         customStyle: String, | ||||
|         arrowDirection: String, | ||||
|         useLabelSlot: Boolean, | ||||
|         border: { | ||||
|             type: Boolean, | ||||
|             value: true, | ||||
|         }, | ||||
|         titleStyle: String, | ||||
|     }, | ||||
|     methods: { | ||||
|         onClick: function (event) { | ||||
|             this.$emit('click', event.detail); | ||||
|             this.jumpLink(); | ||||
|         }, | ||||
|     }, | ||||
| }); | ||||