| @ -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,10 @@ | |||||||
|  | { | ||||||
|  |   "emmet_language_server": { | ||||||
|  |     "init_options": { | ||||||
|  |       "preferences": { | ||||||
|  |         "css.intUnit": "rpx", | ||||||
|  |         "css.floatUnitr": "rpx" | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
| @ -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 @@ | |||||||
|  | ## 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 @@ | |||||||
|  | { | ||||||
|  |   "plugins": [ | ||||||
|  |     [ | ||||||
|  |       "@babel/plugin-transform-react-jsx", | ||||||
|  |       { | ||||||
|  |         "runtime": "automatic", | ||||||
|  |         "importSource": "@antv/f2" | ||||||
|  |       } | ||||||
|  |     ] | ||||||
|  |   ] | ||||||
|  | } | ||||||
| @ -0,0 +1,5 @@ | |||||||
|  | cd ./src/images/ | ||||||
|  | svn add . --no-ignore --force | ||||||
|  | svn ci -m "版本更新" | ||||||
|  | cd .. | ||||||
|  | cd .. | ||||||
| @ -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 @@ | |||||||
|  | #!/bin/bash | ||||||
|  | cd ./src/images/ || exit | ||||||
|  | svn add . --no-ignore --force | ||||||
|  | svn ci -m "版本更新" | ||||||
|  | exit | ||||||
| @ -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 @@ | |||||||
|  | { | ||||||
|  |   "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 @@ | |||||||
|  | { | ||||||
|  |   "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 @@ | |||||||
|  | { | ||||||
|  |   "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 @@ | |||||||
|  | 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 @@ | |||||||
|  | { | ||||||
|  |   "$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 @@ | |||||||
|  | .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 @@ | |||||||
|  | /* 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 @@ | |||||||
|  | { | ||||||
|  |   "component": true, | ||||||
|  |   "usingComponents": { | ||||||
|  |     "van-nav-bar": "@vant/weapp/nav-bar/index" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @ -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 @@ | |||||||
|  | <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 @@ | |||||||
|  | const app = getApp(); | ||||||
|  | 
 | ||||||
|  | Component({ | ||||||
|  |   properties: { | ||||||
|  |     pagination: { | ||||||
|  |       type: Object, | ||||||
|  |       value() { | ||||||
|  |         return {}; | ||||||
|  |       }, | ||||||
|  |     }, | ||||||
|  |   }, | ||||||
|  |   data: { | ||||||
|  |     imageUrl: app.globalData.imageUrl, | ||||||
|  |   }, | ||||||
|  |   methods: { | ||||||
|  |     handleTouchmove() { | ||||||
|  |       return false; | ||||||
|  |     }, | ||||||
|  |   }, | ||||||
|  | }); | ||||||
| @ -0,0 +1,6 @@ | |||||||
|  | { | ||||||
|  |   "component": true, | ||||||
|  |   "usingComponents": { | ||||||
|  |     "van-divider": "@vant/weapp/divider/index" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @ -0,0 +1,6 @@ | |||||||
|  | /* components/pagination/index.wxss */ | ||||||
|  | .none { | ||||||
|  |   display: block; | ||||||
|  |   margin: 30rpx auto; | ||||||
|  |   width: 80%; | ||||||
|  | } | ||||||
| @ -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 @@ | |||||||
|  | { | ||||||
|  |   "component": true, | ||||||
|  |   "usingComponents": { | ||||||
|  |     "van-popup": "@vant/weapp/popup/index" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @ -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 @@ | |||||||
|  | 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 @@ | |||||||
|  | <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 @@ | |||||||
|  | { | ||||||
|  |   "component": true, | ||||||
|  |   "usingComponents": { | ||||||
|  |     "van-tabbar": "@vant/weapp/tabbar/index", | ||||||
|  |     "van-tabbar-item": "@vant/weapp/tabbar-item/index" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @ -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 @@ | |||||||
|  | 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 @@ | |||||||
|  | <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 @@ | |||||||
|  | export {}; | ||||||
| @ -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 @@ | |||||||
|  | { | ||||||
|  |   "component": true, | ||||||
|  |   "usingComponents": { | ||||||
|  |     "van-icon": "../icon/index", | ||||||
|  |     "van-popup": "../popup/index", | ||||||
|  |     "van-loading": "../loading/index" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @ -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 @@ | |||||||
|  | @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 @@ | |||||||
|  | export {}; | ||||||
| @ -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 @@ | |||||||
|  | { | ||||||
|  |   "component": true, | ||||||
|  |   "usingComponents": { | ||||||
|  |     "van-picker": "../picker/index" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @ -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 @@ | |||||||
|  | /* eslint-disable */ | ||||||
|  | function displayColumns(columns, columnsNum) { | ||||||
|  |   return columns.slice(0, +columnsNum); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | module.exports = { | ||||||
|  |   displayColumns: displayColumns, | ||||||
|  | }; | ||||||
| @ -0,0 +1 @@ | |||||||
|  | @import '../common/index.wxss'; | ||||||
| @ -0,0 +1 @@ | |||||||
|  | export {}; | ||||||
| @ -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 @@ | |||||||
|  | { | ||||||
|  |   "component": true, | ||||||
|  |   "usingComponents": { | ||||||
|  |     "van-icon": "../icon/index", | ||||||
|  |     "van-loading": "../loading/index" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @ -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 @@ | |||||||
|  | /* 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 @@ | |||||||
|  | @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 @@ | |||||||
|  | <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 @@ | |||||||
|  | export {}; | ||||||
| @ -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 @@ | |||||||
|  | { | ||||||
|  |   "component": true | ||||||
|  | } | ||||||
| @ -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 @@ | |||||||
|  | @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 @@ | |||||||
|  | export interface Day { | ||||||
|  |     date: Date; | ||||||
|  |     type: string; | ||||||
|  |     text: number; | ||||||
|  |     bottomInfo?: string; | ||||||
|  | } | ||||||
| @ -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 @@ | |||||||
|  | { | ||||||
|  |   "component": true | ||||||
|  | } | ||||||
| @ -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 @@ | |||||||
|  | /* 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 @@ | |||||||
|  | @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 @@ | |||||||
|  | export {}; | ||||||
| @ -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 @@ | |||||||
|  | { | ||||||
|  |   "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 @@ | |||||||
|  | <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 @@ | |||||||
|  | /* 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 @@ | |||||||
|  | @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 @@ | |||||||
|  | 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 @@ | |||||||
|  | "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 @@ | |||||||
|  | /* 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 @@ | |||||||
|  | export {}; | ||||||
| @ -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 @@ | |||||||
|  | { | ||||||
|  |   "component": true, | ||||||
|  |   "usingComponents": { | ||||||
|  |     "van-tag": "../tag/index" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @ -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 @@ | |||||||
|  | @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 @@ | |||||||
|  | export {}; | ||||||
| @ -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 @@ | |||||||
|  | { | ||||||
|  |   "component": true, | ||||||
|  |   "usingComponents": { | ||||||
|  |     "van-icon": "../icon/index", | ||||||
|  |     "van-tab":  "../tab/index", | ||||||
|  |     "van-tabs": "../tabs/index" | ||||||
|  |   } | ||||||
|  | } | ||||||
| @ -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 @@ | |||||||
|  | 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 @@ | |||||||
|  | @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 @@ | |||||||
|  | export {}; | ||||||
| @ -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 @@ | |||||||
|  | { | ||||||
|  |   "component": true | ||||||
|  | } | ||||||
| @ -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 @@ | |||||||
|  | @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 @@ | |||||||
|  | export {}; | ||||||
| @ -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(); | ||||||
|  |         }, | ||||||
|  |     }, | ||||||
|  | }); | ||||||