@smt-ui/component
Advanced tools
Comparing version 0.0.38-alpha.0 to 0.0.39-alpha.0
{ | ||
"name": "@smt-ui/component", | ||
"version": "0.0.38-alpha.0", | ||
"version": "0.0.39-alpha.0", | ||
"description": "extension base", | ||
@@ -40,3 +40,6 @@ "author": "jialipeng <jialipeng@baidu.com>", | ||
}, | ||
"gitHead": "0b4c348b29307af2e979154939ad7b454e85e2fa" | ||
"gitHead": "2d91807caacf4f387a97c0233bb1ae4346d40fab", | ||
"dependencies": { | ||
"@babel/runtime": "^7.7.7" | ||
} | ||
} |
@@ -1,1 +0,1 @@ | ||
{"npmPackageName":"@smt-ui/component","npmPackageVersion":"0.0.37-alpha.0","componentsList":[{"name":"layout","label":"布局组件","icon":"","components":[{"name":"smt-feed-item","label":"信息流子项","description":"信息流子项:包括左文右图、纯文本、上文下图、多图及视频模式。","codeSnap":"<smt-feed-item theme='default' content='title: '宠物自己在家时, 如何帮助它度过孤独时光',infoSource: '萌宠在家',commentsNum: 2' status='0'></smt-feed-item>","groups":"layout","fragement":"swanide://fragment/afebdafc13cda2201207a3d6721577481577175550244","properties":{"attributes":[{"name":"theme","type":"string","description":"信息流子项的主题","required":"是","default":"default"},{"name":"content","type":"Object","description":"信息流子项目的内容","required":"是","default":"{title: '标题',infoSource: '网易新闻',commentsNum: 2,images: []}"},{"name":"video","type":"Object","description":"是否为视频和视频信息","required":"否","default":"{isVideo: true, time: '05:00'}"},{"name":"status","type":"String","description":"阅读状态:0未读,1已读","required":"否","default":"0"}],"events":[{"name":"bindfeeditemtap","type":"Event","description":"点击feed-item之后的回调","required":"否","default":"-"}]},"type":"component","doc":"https://smartprogram.baidu.com/docs/develop/component/smt-feed-item","qrCode":"https://b.bdstatic.com/miniapp/assets/images/doc_demo/smt-feed-item.png","usingComponents":{"smt-feed-item":"@smt-ui/component/src/feed-item"}},{"name":"smt-feed","label":"信息流","description":"信息流组件,可配置下拉刷新、列表加载、上滑加载功能,适用于列表信息展示,并可放置在页面的任何部分;组件包含手势下拉以及api调用两种使用方式\n* 注意:\n1. 和scroll-view一样,信息流组件作为局部滚动组件,必须在它的父级或本身指定高度\n2. 当同时启用下拉刷新和上滑加载且请求不稳定时,可使用CancelToken取消先前的请求","codeSnap":"<smt-feed pull-to-refresh><view>list</view></smt-feed>","groups":"layout","fragement":"swanide://fragment/7b9bf19d0c974d45d9b68fd9fc4429b31577200628346","properties":{"attributes":[{"name":"theme","type":"String","description":"主题配置,默认浅色;深色主题请指定dark","required":"否","default":"-"},{"name":"loadingHeight","type":"Number","description":"加载、话术区域高度,单位为设备px,转换方法: import {upx2dpx} from '@smt-ui/component/src/common/utils/px';","required":"否","default":"192px(设计稿宽度为1242)"},{"name":"pullToRefresh","type":"Boolean","description":"是否开启手势下拉刷新; 默认只能通过组件api调起","required":"否","default":"false"},{"name":"lowerThreshold","type":"Number","description":"触发scrolltolower事件的阈值","required":"否","default":"150px(设备上的px)"},{"name":"text","type":"String","description":"加载成功时的展示话术","required":"否","default":"建议最多显示18个汉字,超出内容截断"},{"name":"refresh","type":"EventHandle","description":"手势滑动触发加载时,响应该onRefresh事件; 通过调用api加载,不会触发该事件","required":"否","default":""},{"name":"startRefresh","type":"EventHandle","description":"手动调用该api,触发加载","required":"否","default":""},{"name":"stopRefresh","type":"EventHandle","description":"手动调用该api,停止加载,并弹出加载提示(对应属性text);可使用await等待关闭动画结束","required":"否","default":""},{"name":"closeLoading","type":"EventHandle","description":"手动调用该api,立即关闭加载,不弹出加载提示;例如接口异常,建义直接关闭加载(小球交替一次大约为500ms,调用前可加延时避免关闭太快)","required":"否","default":""},{"name":"smt-feed-container","type":"externalClass","description":"组件整体class名","required":"否","default":"-"},{"name":"smt-feed-loading","type":"externalClass","description":"加载区域class名","required":"否","default":"-"},{"name":"smt-feed-content","type":"externalClass","description":"滚动区域class名,用于设置ios回弹背景","required":"false","default":""},{"name":"smt-refresh-circle-left","type":"externalClass","description":"加载中左侧小球class名","required":"否","default":"-"},{"name":"smt-refresh-circle-right","type":"externalClass","description":"加载中右侧小球class名","required":"否","default":"-"},{"name":"ext-cls-content","type":"externalClass","description":"滚动区域class名","required":"否","default":"-"},{"name":"smt-refresh-result-container","type":"externalClass","description":"加载话术外框class名","required":"否","default":"-"},{"name":"ext-cls-result-text","type":"externalClass","description":"加载话术文字class名","required":"否","default":"-"}],"events":[{"name":"bindscroll","type":"Event","description":"滚动时触发,返回当前组件的值","required":"否","default":"-"}]},"type":"component","doc":"https://smartprogram.baidu.com/docs/develop/component/smt-feed","qrCode":"https://b.bdstatic.com/miniapp/assets/images/doc_demo/smt-feed.png","usingComponents":{"smt-feed":"@smt-ui/component/src/feed"}},{"name":"smt-icon","label":"图标","description":"包括天气、系统设置、互动社交、生活服务、书籍影音、政务服务、交通出行7个行业类别的图标。请扫描示例二维码查看图标全集。","codeSnap":"<smt-icon name='add'></smt-icon>","groups":"layout","fragement":"swanide://fragment/1151cb408d98313c4e79bb6a62755bfa1577193673206","properties":{"attributes":[{"name":"name","type":"String","description":"icon的英文名称","required":"是"},{"name":"color","type":"String, Array.<String>","description":"icon的颜色,多色图标支持传入色值的数组"},{"name":"size","type":"Number","description":"icon的尺寸,单位px","default":25}],"events":[]},"type":"component","doc":"https://smartprogram.baidu.com/docs/develop/component/smt-icon","qrCode":"https://b.bdstatic.com/miniapp/assets/images/doc_demo/smt-icon.png","usingComponents":{"smt-icon":"@smt-ui/component/src/icon"}},{"name":"navigation","label":"顶部导航bar","description":"顶部导航bar可以自定义","codeSnap":"<smt-navigation></smt-navigation>","groups":"layout","properties":{"properties":[],"events":[]},"type":"component","doc":"https://smartprogram.baidu.com/docs/develop/component/navigation","qrCode":"https://b.bdstatic.com/miniapp/assets/images/doc_demo/navigation.png","usingComponents":{"navigation":"@smt-ui/component/src/navigation"}},{"name":"smt-page-status","label":"页面状态组件","description":"页面状态组件,可用于全屏和半屏。用于展示页面加载,页面异常-有操作、页面异常-无操作三种页面状态。","codeSnap":"<smt-page-status></smt-page-status>","groups":"layout","fragment":"swanide://fragment/4cc92982287ac8a30b5fe19f220dc8f71577190736077","properties":{"attributes":[{"name":"theme","type":"String","description":"主题配置,默认浅色;沉浸式主题请指定dark","required":"否","default":""},{"name":"loading","type":"Boolean","description":"页面状态配置,默认不展示加载状态页面","required":"否","default":"false"},{"name":"icon","type":"String","description":"空态/缺省页面下的图标名称","required":"否","default":"content"},{"name":"loadingTitle","type":"String","description":"加载页面下的标题文案","required":"否","default":"正在加载..."},{"name":"title","type":"String","description":"空态/缺省页面下的标题文案","required":"否","default":"单行标题"},{"name":"desc","type":"String","description":"空态/缺省页面下的描述文案","required":"否","default":""},{"name":"showBtn","type":"Boolean","description":"是否展示空态/缺省页面下的操作按钮,默认展示","required":"否","default":"true"},{"name":"btnText","type":"String","description":"空态/缺省页面下,操作按钮的描述文案,建议最多显示4个汉字,超出内容截断","required":"否","default":"重新加载"}],"events":[{"name":"reloading","type":"Event","description":"空态/缺省页面下,点击操作按钮时触发","required":"否","default":"-"}]},"type":"component","doc":"https://smartprogram.baidu.com/docs/develop/component/smt-page-status","qrCode":"https://b.bdstatic.com/miniapp/assets/images/doc_demo/smt-page-status.png","usingComponents":{"smt-page-status":"@smt-ui/component/src/page-status"}},{"name":"publish","label":"发布器","description":"发布器组件可以用于用户直接发布文章使用,可以包含文字与图片,在支持发布器的客户端上,会直接调用API来展示发布器,在不支持发布器的客户端上,则会展示降级版的发布器","codeSnap":"<smt-publish></smt-publish>","groups":"layout","properties":{"attributes":[{"name":"theme","type":"String","description":"主题配置,默认浅色;深色主题请指定dark","required":"false","default":"-"},{"name":"loadingHgt","type":"Number","description":"加载区域高度","required":"false","default":"192px(需转换为设备尺寸)"},{"name":"offsetY","type":"Number","description":"垂直移动距离,*建议后续在sjs中使用","required":"false","default":"0"},{"name":"status","type":"Number","description":"加载状态 0: 未开始 1: 加载中 2: 展示话术","required":"false","default":"0"},{"name":"text","type":"String","description":"加载成功时的展示话术","required":"false","default":"建议最多显示18个汉字,超出内容截断"}],"events":[]},"type":"component","doc":"https://smartprogram.baidu.com/docs/develop/component/publish","qrCode":"https://b.bdstatic.com/miniapp/assets/images/doc_demo/publish.png","usingComponents":{"publish":"@smt-ui/component/src/publish"}},{"name":"smt-refresh","label":"刷新","description":"可用于页面任意区域;使用时需自行添加下拉逻辑改变offset-y参数;smt-feed组件对smt-refresh进行了封装,支持手势交互和api调起刷新。","codeSnap":"<smt-refresh offset-y=\"{{0}}\" status=\"{{1}}\" text=\"为你推荐15条更新\"></smt-refresh>","fragement":"swanide://fragment/598510a21b650b89e2e5d13c814dc46c1577192328823","groups":"layout","properties":{"attributes":[{"name":"theme","type":"String","description":"主题配置,默认浅色;深色主题请指定dark","required":"否","default":"-"},{"name":"loadingHgt","type":"Number","description":"加载区域高度","required":"否","default":"192px(需转换为设备尺寸)"},{"name":"offsetY","type":"Number","description":"垂直移动距离,*建议后续在sjs中使用","required":"否","default":"0"},{"name":"status","type":"Number","description":"加载状态 0: 未开始 1: 加载中 2: 展示话术","required":"否","default":"0"},{"name":"text","type":"String","description":"加载成功时的展示话术","required":"否","default":"建议最多显示18个汉字,超出内容截断"}],"events":[]},"type":"component","doc":"https://smartprogram.baidu.com/docs/develop/component/smt-refresh","qrCode":"https://b.bdstatic.com/miniapp/assets/images/doc_demo/smt-refresh.png","usingComponents":{"smt-refresh":"@smt-ui/component/src/refresh"}},{"name":"smt-spin","label":"加载","description":"加载组件,可用于全屏和半屏。用于展示加载状态,点击加载、正在加载、加载完成、重新加载四种状态。","codeSnap":"<spin status='1'></spin>","groups":"layout","fragement":"swanide://fragment/25af44248f8aad73b64e274ead38d6151577191316430","properties":{"attributes":[{"name":"status","type":"Number","description":"加载状态配置","required":"是"},{"name":"theme","type":"String","description":"主题配置,默认浅色;深色主题请指定dark","required":"否","default":""},{"name":"textConfig","type":"Array","description":"加载状态对应的文案","required":"否","default":"['点击加载更多', '正在加载...', '已经到底啦', '加载失败 点击重新加载']"},{"name":"secureBottom","type":"Boolean","description":"默认兼容iPhoneX 及以上型号底部安全区,非全屏可关闭","required":"否","default":"true"}],"events":[]},"type":"component","doc":"https://smartprogram.baidu.com/docs/develop/component/smt-spin","qrCode":"https://b.bdstatic.com/miniapp/assets/images/doc_demo/smt-spin.png","usingComponents":{"smt-spin":"@smt-ui/component/src/spin"}}]}]} | ||
{"npmPackageName":"@smt-ui/component","npmPackageVersion":"0.0.38-alpha.0","componentsList":[{"name":"layout","label":"布局组件","icon":"","components":[{"name":"smt-feed-item","label":"信息流子项","description":"信息流子项:包括左文右图、纯文本、上文下图、多图及视频模式。","codeSnap":"<smt-feed-item theme='default' content='title: '宠物自己在家时, 如何帮助它度过孤独时光',infoSource: '萌宠在家',commentsNum: 2' status='0'></smt-feed-item>","groups":"layout","fragement":"swanide://fragment/afebdafc13cda2201207a3d6721577481577175550244","properties":{"attributes":[{"name":"theme","type":"string","description":"信息流子项的主题","required":"是","default":"default"},{"name":"content","type":"Object","description":"信息流子项目的内容","required":"是","default":"{title: '标题',infoSource: '网易新闻',commentsNum: 2,images: []}"},{"name":"video","type":"Object","description":"是否为视频和视频信息","required":"否","default":"{isVideo: true, time: '05:00'}"},{"name":"status","type":"String","description":"阅读状态:0未读,1已读","required":"否","default":"0"}],"events":[{"name":"bindfeeditemtap","type":"Event","description":"点击feed-item之后的回调","required":"否","default":"-"}]},"type":"component","doc":"https://smartprogram.baidu.com/docs/develop/component/smt-feed-item","qrCode":"https://b.bdstatic.com/miniapp/assets/images/doc_demo/smt-feed-item.png","usingComponents":{"smt-feed-item":"@smt-ui/component/src/feed-item"}},{"name":"smt-feed","label":"信息流","description":"信息流组件,可配置下拉刷新、列表加载、上滑加载功能,适用于列表信息展示,并可放置在页面的任何部分;组件包含手势下拉以及api调用两种使用方式\n* 注意:\n1. 和scroll-view一样,信息流组件作为局部滚动组件,必须在它的父级或本身指定高度\n2. 当同时启用下拉刷新和上滑加载且请求不稳定时,可使用CancelToken取消先前的请求","codeSnap":"<smt-feed pull-to-refresh><view>list</view></smt-feed>","groups":"layout","fragement":"swanide://fragment/7b9bf19d0c974d45d9b68fd9fc4429b31577200628346","properties":{"attributes":[{"name":"theme","type":"String","description":"主题配置,默认浅色;深色主题请指定dark","required":"否","default":"-"},{"name":"loadingHeight","type":"Number","description":"加载、话术区域高度,单位为设备px,转换方法: import {upx2dpx} from '@smt-ui/component/src/common/utils/px';","required":"否","default":"192px(设计稿宽度为1242)"},{"name":"pullToRefresh","type":"Boolean","description":"是否开启手势下拉刷新; 默认只能通过组件api调起","required":"否","default":"false"},{"name":"lowerThreshold","type":"Number","description":"触发scrolltolower事件的阈值","required":"否","default":"150px(设备上的px)"},{"name":"text","type":"String","description":"加载成功时的展示话术","required":"否","default":"建议最多显示18个汉字,超出内容截断"},{"name":"refresh","type":"EventHandle","description":"手势滑动触发加载时,响应该onRefresh事件; 通过调用api加载,不会触发该事件","required":"否","default":""},{"name":"startRefresh","type":"EventHandle","description":"手动调用该api,触发加载","required":"否","default":""},{"name":"stopRefresh","type":"EventHandle","description":"手动调用该api,停止加载,并弹出加载提示(对应属性text);可使用await等待关闭动画结束","required":"否","default":""},{"name":"closeLoading","type":"EventHandle","description":"手动调用该api,立即关闭加载,不弹出加载提示;例如接口异常,建义直接关闭加载(小球交替一次大约为500ms,调用前可加延时避免关闭太快)","required":"否","default":""},{"name":"smt-feed-container","type":"externalClass","description":"组件整体class名","required":"否","default":"-"},{"name":"smt-feed-loading","type":"externalClass","description":"加载区域class名","required":"否","default":"-"},{"name":"smt-feed-content","type":"externalClass","description":"滚动区域class名,用于设置ios回弹背景","required":"false","default":""},{"name":"smt-refresh-circle-left","type":"externalClass","description":"加载中左侧小球class名","required":"否","default":"-"},{"name":"smt-refresh-circle-right","type":"externalClass","description":"加载中右侧小球class名","required":"否","default":"-"},{"name":"ext-cls-content","type":"externalClass","description":"滚动区域class名","required":"否","default":"-"},{"name":"smt-refresh-result-container","type":"externalClass","description":"加载话术外框class名","required":"否","default":"-"},{"name":"ext-cls-result-text","type":"externalClass","description":"加载话术文字class名","required":"否","default":"-"}],"events":[{"name":"bindscroll","type":"Event","description":"滚动时触发,返回当前组件的值","required":"否","default":"-"}]},"type":"component","doc":"https://smartprogram.baidu.com/docs/develop/component/smt-feed","qrCode":"https://b.bdstatic.com/miniapp/assets/images/doc_demo/smt-feed.png","usingComponents":{"smt-feed":"@smt-ui/component/src/feed"}},{"name":"smt-icon","label":"图标","description":"包括天气、系统设置、互动社交、生活服务、书籍影音、政务服务、交通出行7个行业类别的图标。请扫描示例二维码查看图标全集。","codeSnap":"<smt-icon name='add'></smt-icon>","groups":"layout","fragement":"swanide://fragment/1151cb408d98313c4e79bb6a62755bfa1577193673206","properties":{"attributes":[{"name":"name","type":"String","description":"icon的英文名称","required":"是"},{"name":"color","type":"String, Array.<String>","description":"icon的颜色,多色图标支持传入色值的数组"},{"name":"size","type":"Number","description":"icon的尺寸,单位px","default":25}],"events":[]},"type":"component","doc":"https://smartprogram.baidu.com/docs/develop/component/smt-icon","qrCode":"https://b.bdstatic.com/miniapp/assets/images/doc_demo/smt-icon.png","usingComponents":{"smt-icon":"@smt-ui/component/src/icon"}},{"name":"navigation","label":"顶部导航bar","description":"顶部导航bar可以自定义","codeSnap":"<smt-navigation></smt-navigation>","groups":"layout","properties":{"properties":[],"events":[]},"type":"component","doc":"https://smartprogram.baidu.com/docs/develop/component/navigation","qrCode":"https://b.bdstatic.com/miniapp/assets/images/doc_demo/navigation.png","usingComponents":{"navigation":"@smt-ui/component/src/navigation"}},{"name":"smt-page-status","label":"页面状态组件","description":"页面状态组件,可用于全屏和半屏。用于展示页面加载,页面异常-有操作、页面异常-无操作三种页面状态。","codeSnap":"<smt-page-status></smt-page-status>","groups":"layout","fragment":"swanide://fragment/4cc92982287ac8a30b5fe19f220dc8f71577190736077","properties":{"attributes":[{"name":"theme","type":"String","description":"主题配置,默认浅色;沉浸式主题请指定dark","required":"否","default":""},{"name":"loading","type":"Boolean","description":"页面状态配置,默认不展示加载状态页面","required":"否","default":"false"},{"name":"icon","type":"String","description":"空态/缺省页面下的图标名称","required":"否","default":"content"},{"name":"loadingTitle","type":"String","description":"加载页面下的标题文案","required":"否","default":"正在加载..."},{"name":"title","type":"String","description":"空态/缺省页面下的标题文案","required":"否","default":"单行标题"},{"name":"desc","type":"String","description":"空态/缺省页面下的描述文案","required":"否","default":""},{"name":"showBtn","type":"Boolean","description":"是否展示空态/缺省页面下的操作按钮,默认展示","required":"否","default":"true"},{"name":"btnText","type":"String","description":"空态/缺省页面下,操作按钮的描述文案,建议最多显示4个汉字,超出内容截断","required":"否","default":"重新加载"}],"events":[{"name":"reloading","type":"Event","description":"空态/缺省页面下,点击操作按钮时触发","required":"否","default":"-"}]},"type":"component","doc":"https://smartprogram.baidu.com/docs/develop/component/smt-page-status","qrCode":"https://b.bdstatic.com/miniapp/assets/images/doc_demo/smt-page-status.png","usingComponents":{"smt-page-status":"@smt-ui/component/src/page-status"}},{"name":"publish","label":"发布器","description":"发布器组件可以用于用户直接发布文章使用,可以包含文字与图片,在支持发布器的客户端上,会直接调用API来展示发布器,在不支持发布器的客户端上,则会展示降级版的发布器","codeSnap":"<smt-publish></smt-publish>","groups":"layout","properties":{"attributes":[{"name":"theme","type":"String","description":"主题配置,默认浅色;深色主题请指定dark","required":"false","default":"-"},{"name":"loadingHgt","type":"Number","description":"加载区域高度","required":"false","default":"192px(需转换为设备尺寸)"},{"name":"offsetY","type":"Number","description":"垂直移动距离,*建议后续在sjs中使用","required":"false","default":"0"},{"name":"status","type":"Number","description":"加载状态 0: 未开始 1: 加载中 2: 展示话术","required":"false","default":"0"},{"name":"text","type":"String","description":"加载成功时的展示话术","required":"false","default":"建议最多显示18个汉字,超出内容截断"}],"events":[]},"type":"component","doc":"https://smartprogram.baidu.com/docs/develop/component/publish","qrCode":"https://b.bdstatic.com/miniapp/assets/images/doc_demo/publish.png","usingComponents":{"publish":"@smt-ui/component/src/publish"}},{"name":"smt-refresh","label":"刷新","description":"可用于页面任意区域;使用时需自行添加下拉逻辑改变offset-y参数;smt-feed组件对smt-refresh进行了封装,支持手势交互和api调起刷新。","codeSnap":"<smt-refresh offset-y=\"{{0}}\" status=\"{{1}}\" text=\"为你推荐15条更新\"></smt-refresh>","fragement":"swanide://fragment/598510a21b650b89e2e5d13c814dc46c1577192328823","groups":"layout","properties":{"attributes":[{"name":"theme","type":"String","description":"主题配置,默认浅色;深色主题请指定dark","required":"否","default":"-"},{"name":"loadingHgt","type":"Number","description":"加载区域高度","required":"否","default":"192px(需转换为设备尺寸)"},{"name":"offsetY","type":"Number","description":"垂直移动距离,*建议后续在sjs中使用","required":"否","default":"0"},{"name":"status","type":"Number","description":"加载状态 0: 未开始 1: 加载中 2: 展示话术","required":"否","default":"0"},{"name":"text","type":"String","description":"加载成功时的展示话术","required":"否","default":"建议最多显示18个汉字,超出内容截断"}],"events":[]},"type":"component","doc":"https://smartprogram.baidu.com/docs/develop/component/smt-refresh","qrCode":"https://b.bdstatic.com/miniapp/assets/images/doc_demo/smt-refresh.png","usingComponents":{"smt-refresh":"@smt-ui/component/src/refresh"}},{"name":"smt-spin","label":"加载","description":"加载组件,可用于全屏和半屏。用于展示加载状态,点击加载、正在加载、加载完成、重新加载四种状态。","codeSnap":"<spin status='1'></spin>","groups":"layout","fragement":"swanide://fragment/25af44248f8aad73b64e274ead38d6151577191316430","properties":{"attributes":[{"name":"status","type":"Number","description":"加载状态配置","required":"是"},{"name":"theme","type":"String","description":"主题配置,默认浅色;深色主题请指定dark","required":"否","default":""},{"name":"textConfig","type":"Array","description":"加载状态对应的文案","required":"否","default":"['点击加载更多', '正在加载...', '已经到底啦', '加载失败 点击重新加载']"},{"name":"secureBottom","type":"Boolean","description":"默认兼容iPhoneX 及以上型号底部安全区,非全屏可关闭","required":"否","default":"true"}],"events":[]},"type":"component","doc":"https://smartprogram.baidu.com/docs/develop/component/smt-spin","qrCode":"https://b.bdstatic.com/miniapp/assets/images/doc_demo/smt-spin.png","usingComponents":{"smt-spin":"@smt-ui/component/src/spin"}}]}]} |
@@ -209,3 +209,3 @@ /** | ||
*/ | ||
export const syncSetData = async (context, obj = {}) => new Promise(r => context.setData(obj, r)); | ||
export const syncSetData = (context, obj = {}) => new Promise(r => context.setData(obj, r)); | ||
@@ -212,0 +212,0 @@ /** |
@@ -1,13 +0,1 @@ | ||
"use strict"; | ||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); | ||
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator")); | ||
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator")); | ||
var _px = require("../../common/utils/px"); | ||
var _index = require("../../common/utils/index"); | ||
/** | ||
@@ -18,719 +6,423 @@ * @file 下拉刷新 | ||
*/ | ||
var STATUS = { | ||
IDLE: 0, | ||
LOADING: 1, | ||
SHOWTEXT: 2 | ||
import {upx2dpx} from '../../common/utils/px'; | ||
import {calcCircle, linearAccu, promiseDebounce, syncSetData} from '../../common/utils/index'; | ||
const STATUS = { | ||
IDLE: 0, | ||
LOADING: 1, | ||
SHOWTEXT: 2 | ||
}; | ||
Component({ | ||
externalClasses: ['smt-feed-container', 'smt-feed-loading', 'smt-feed-content', 'smt-refresh-circle-left', 'smt-refresh-circle-right', 'smt-refresh-result-container', 'smt-refresh-result-text'], | ||
properties: { | ||
// 是否开启下拉刷新 | ||
pullToRefresh: { | ||
type: Boolean, | ||
value: false | ||
}, | ||
// loading加载区域高度 * 必须是device px | ||
loadingHeight: { | ||
type: Number, | ||
value: (0, _px.upx2dpx)(192), | ||
observer: function observer(n) { | ||
if (typeof n !== 'number') { | ||
throw 'loadingHeight 必须是数字类型!否则下拉可造成卡顿闪屏'; | ||
} | ||
} | ||
}, | ||
// 距底部距离 触发 scrolltolower 事件 | ||
lowerThreshold: { | ||
type: Number, | ||
value: 150 | ||
}, | ||
// 加载成功话术 * 不要默认值,prop抖动 | ||
text: { | ||
type: String, | ||
value: '', | ||
observer: function observer(n) { | ||
this.clipText(n); | ||
} | ||
}, | ||
theme: { | ||
type: String, | ||
value: '' | ||
}, | ||
// 禁止下拉 * 场景:处于滚动页面且api加载(demo示例平台) | ||
disableTouch: { | ||
type: Boolean, | ||
value: false | ||
} | ||
}, | ||
data: { | ||
// 左右小球信息 | ||
circle: { | ||
// 小球尺寸 * device px防止变形 | ||
size: (0, _px.upx2dpx)(21), | ||
// 小球移动距离 | ||
offsetX: (0, _px.upx2dpx)(33), | ||
// 左右渐隐(有先后) | ||
opacityL: 0, | ||
opacityR: 0, | ||
// 左右距离(有先后) | ||
xL: 0, | ||
xR: 0 | ||
}, | ||
// 是否禁用scrollView | ||
enableScroll: true, | ||
// 滑动距离 | ||
offsetY: 0, | ||
// 滑动区域高度,用于计算阻尼值 | ||
clientHeight: 0, | ||
// 最长18个汉字 | ||
clipedText: '', | ||
// 0: 未开始 1: 加载中 2: 展示话术 | ||
status: STATUS.IDLE, | ||
// 滚动高度 | ||
scrollTop: 0 | ||
}, | ||
methods: { | ||
/** | ||
* 截取18位文字 | ||
* @param {string} str 传入的文字 | ||
*/ | ||
clipText: function clipText(str) { | ||
this.setData({ | ||
clipedText: str.slice(0, 18) | ||
}); | ||
}, | ||
externalClasses: [ | ||
'smt-feed-container', | ||
'smt-feed-loading', | ||
'smt-feed-content', | ||
/** | ||
* scrollView 滚动参数 | ||
* @param {Object} param Event | ||
*/ | ||
scrollHdl: function scrollHdl(_ref) { | ||
var _this = this; | ||
'smt-refresh-circle-left', | ||
'smt-refresh-circle-right', | ||
'smt-refresh-result-container', | ||
'smt-refresh-result-text' | ||
], | ||
var detail = _ref.detail; | ||
this.scrollTop = detail.scrollTop; // 如果是ios惯性,就禁掉回弹 | ||
properties: { | ||
// 是否开启下拉刷新 | ||
pullToRefresh: { | ||
type: Boolean, | ||
value: false | ||
}, | ||
if (this.data.pullToRefresh && this.scrollTop < 0 && this.data.enableScroll && this.offsetY === 0) { | ||
this.setData({ | ||
enableScroll: false | ||
}, function () { | ||
_this.setData({ | ||
enableScroll: true | ||
}); | ||
}); | ||
} | ||
// loading加载区域高度 * 必须是device px | ||
loadingHeight: { | ||
type: Number, | ||
value: upx2dpx(192), | ||
observer(n) { | ||
if (typeof n !== 'number') { | ||
throw 'loadingHeight 必须是数字类型!否则下拉可造成卡顿闪屏'; | ||
} | ||
} | ||
}, | ||
this.triggerEvent('scroll', detail); | ||
}, | ||
// 距底部距离 触发 scrolltolower 事件 | ||
lowerThreshold: { | ||
type: Number, | ||
value: 150 | ||
}, | ||
/** | ||
* 阻尼值转换 * 四参方程有常数,便于转换屏幕比 | ||
* 两种情况: 滚动区域 > 400 ? 用系数 = .7 : .65 | ||
* x: 0, 50, 100, 150, 200, 250, 300, 350, 400, 800, 40000, 120000 | ||
* y: 0,32,62,90,115,136,153,164,170,270, 420, 440 | ||
* | ||
* @param {number} pullDistance 下拉的总距离 | ||
* @param {number=} base 基础值,calc(iphone 8p - 40px) | ||
* @return {number} 返回值 | ||
*/ | ||
dumping: function dumping(offsetY) { | ||
var base = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 464; | ||
var y = offsetY > 0 ? offsetY : 0; | ||
var ratio = this.data.clientHeight / base; | ||
var result = 0; | ||
// 加载成功话术 * 不要默认值,prop抖动 | ||
text: { | ||
type: String, | ||
value: '', | ||
observer(n) { | ||
this.clipText(n); | ||
} | ||
}, | ||
if (this.data.clientHeight > 400) { | ||
// 系数 .65 | ||
result = (440.5 + .5) * ratio / (1 + Math.pow(y / 551.5665, -1.009)) - .5; | ||
} else { | ||
// 系数 .7 | ||
result = (440.0483 + .0510) * ratio / (1 + Math.pow(y / 444.0544, -1.2801)) - .0510; | ||
} | ||
theme: { | ||
type: String, | ||
value: '' | ||
}, | ||
return Math.round(result); | ||
// 禁止下拉 * 场景:处于滚动页面且api加载(demo示例平台) | ||
disableTouch: { | ||
type: Boolean, | ||
value: false | ||
} | ||
}, | ||
touchHdl: function () { | ||
var _touchHdl = (0, _asyncToGenerator2["default"])( | ||
/*#__PURE__*/ | ||
_regenerator["default"].mark(function _callee(_ref2) { | ||
var _this2 = this; | ||
var type, _ref2$touches, touches, _ref2$changedTouches, changedTouches, _ref2$manual, manual, disabled, _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, touch, id, pageY, distance, _iteratorNormalCompletion2, _didIteratorError2, _iteratorError2, _iterator2, _step2, _touch, _id, _pageY, offsetY, pullDown, circleInfo, setOffsetY, _iteratorNormalCompletion3, _didIteratorError3, _iteratorError3, _iterator3, _step3, _touch2, _id2, _pageY2, shouldLoad, result; | ||
data: { | ||
// 左右小球信息 | ||
circle: { | ||
// 小球尺寸 * device px防止变形 | ||
size: upx2dpx(21), | ||
// 小球移动距离 | ||
offsetX: upx2dpx(33), | ||
// 左右渐隐(有先后) | ||
opacityL: 0, | ||
opacityR: 0, | ||
// 左右距离(有先后) | ||
xL: 0, | ||
xR: 0 | ||
}, | ||
return _regenerator["default"].wrap(function _callee$(_context) { | ||
while (1) { | ||
switch (_context.prev = _context.next) { | ||
case 0: | ||
type = _ref2.type, _ref2$touches = _ref2.touches, touches = _ref2$touches === void 0 ? [] : _ref2$touches, _ref2$changedTouches = _ref2.changedTouches, changedTouches = _ref2$changedTouches === void 0 ? [] : _ref2$changedTouches, _ref2$manual = _ref2.manual, manual = _ref2$manual === void 0 ? false : _ref2$manual; | ||
// 是否禁用scrollView | ||
enableScroll: true, | ||
if (!(this.closing || this.data.disableTouch && !manual)) { | ||
_context.next = 3; | ||
break; | ||
} | ||
// 滑动距离 | ||
offsetY: 0, | ||
return _context.abrupt("return"); | ||
// 滑动区域高度,用于计算阻尼值 | ||
clientHeight: 0, | ||
case 3: | ||
// ue规定: 如果api调用下拉刷新,则不启用手势刷新 | ||
disabled = !this.data.pullToRefresh && !manual && this.status === STATUS.IDLE; // 禁用多点触控 | ||
// 最长18个汉字 | ||
clipedText: '', | ||
_context.t0 = type; | ||
_context.next = _context.t0 === 'touchstart' ? 7 : _context.t0 === 'touchmove' ? 37 : _context.t0 === 'touchend' ? 70 : 99; | ||
break; | ||
// 0: 未开始 1: 加载中 2: 展示话术 | ||
status: STATUS.IDLE, | ||
case 7: | ||
this.touching = true; | ||
_iteratorNormalCompletion = true; | ||
_didIteratorError = false; | ||
_iteratorError = undefined; | ||
_context.prev = 11; | ||
_iterator = touches[Symbol.iterator](); | ||
// 滚动高度 | ||
scrollTop: 0 | ||
}, | ||
case 13: | ||
if (_iteratorNormalCompletion = (_step = _iterator.next()).done) { | ||
_context.next = 22; | ||
break; | ||
} | ||
methods: { | ||
/** | ||
* 截取18位文字 | ||
* @param {string} str 传入的文字 | ||
*/ | ||
clipText(str) { | ||
this.setData({ | ||
clipedText: str.slice(0, 18) | ||
}); | ||
}, | ||
touch = _step.value; | ||
id = touch.identifier, pageY = touch.pageY; | ||
if (!(this.pos[id] == null)) { | ||
_context.next = 19; | ||
break; | ||
} | ||
this.pos[id] = pageY + this.scrollTop; | ||
return _context.abrupt("break", 22); | ||
case 19: | ||
_iteratorNormalCompletion = true; | ||
_context.next = 13; | ||
break; | ||
case 22: | ||
_context.next = 28; | ||
break; | ||
case 24: | ||
_context.prev = 24; | ||
_context.t1 = _context["catch"](11); | ||
_didIteratorError = true; | ||
_iteratorError = _context.t1; | ||
case 28: | ||
_context.prev = 28; | ||
_context.prev = 29; | ||
if (!_iteratorNormalCompletion && _iterator["return"] != null) { | ||
_iterator["return"](); | ||
} | ||
case 31: | ||
_context.prev = 31; | ||
if (!_didIteratorError) { | ||
_context.next = 34; | ||
break; | ||
} | ||
throw _iteratorError; | ||
case 34: | ||
return _context.finish(31); | ||
case 35: | ||
return _context.finish(28); | ||
case 36: | ||
return _context.abrupt("break", 99); | ||
case 37: | ||
distance = 0; | ||
_iteratorNormalCompletion2 = true; | ||
_didIteratorError2 = false; | ||
_iteratorError2 = undefined; | ||
_context.prev = 41; | ||
for (_iterator2 = touches[Symbol.iterator](); !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) { | ||
_touch = _step2.value; | ||
_id = _touch.identifier, _pageY = _touch.pageY; | ||
if (this.pos[_id]) { | ||
distance += Math.round(_pageY - this.pos[_id]); | ||
} | ||
} | ||
_context.next = 49; | ||
break; | ||
case 45: | ||
_context.prev = 45; | ||
_context.t2 = _context["catch"](41); | ||
_didIteratorError2 = true; | ||
_iteratorError2 = _context.t2; | ||
case 49: | ||
_context.prev = 49; | ||
_context.prev = 50; | ||
if (!_iteratorNormalCompletion2 && _iterator2["return"] != null) { | ||
_iterator2["return"](); | ||
} | ||
case 52: | ||
_context.prev = 52; | ||
if (!_didIteratorError2) { | ||
_context.next = 55; | ||
break; | ||
} | ||
throw _iteratorError2; | ||
case 55: | ||
return _context.finish(52); | ||
case 56: | ||
return _context.finish(49); | ||
case 57: | ||
offsetY = this.offsetY = this.dumping(distance + this.lastOffsetY); | ||
pullDown = distance > 0; // 没loading动画时下拉计算动画 | ||
if (this.status === STATUS.IDLE) { | ||
circleInfo = (0, _index.calcCircle)(offsetY, this.data.loadingHeight); | ||
circleInfo && this.setData(circleInfo); | ||
} // 还未加载时,向上划要收起loading | ||
if (!(!pullDown && this.status !== STATUS.IDLE && Math.abs(offsetY) > 20)) { | ||
_context.next = 66; | ||
break; | ||
} | ||
this.fadeCircle(); | ||
/** | ||
* scrollView 滚动参数 | ||
* @param {Object} param Event | ||
*/ | ||
scrollHdl({detail}) { | ||
this.scrollTop = detail.scrollTop; | ||
// 如果是ios惯性,就禁掉回弹 | ||
if (this.data.pullToRefresh && this.scrollTop < 0 && this.data.enableScroll && this.offsetY === 0) { | ||
this.setData({ | ||
status: STATUS.IDLE, | ||
offsetY: 0 | ||
enableScroll: false | ||
}, () => { | ||
this.setData({ | ||
enableScroll: true | ||
}); | ||
}); | ||
this.status = STATUS.IDLE; | ||
this.lastOffsetY = this.offsetY = 0; | ||
return _context.abrupt("return"); | ||
} | ||
this.triggerEvent('scroll', detail); | ||
}, | ||
case 66: | ||
if (!disabled) { | ||
_context.next = 68; | ||
break; | ||
} | ||
/** | ||
* 阻尼值转换 * 四参方程有常数,便于转换屏幕比 | ||
* 两种情况: 滚动区域 > 400 ? 用系数 = .7 : .65 | ||
* x: 0, 50, 100, 150, 200, 250, 300, 350, 400, 800, 40000, 120000 | ||
* y: 0,32,62,90,115,136,153,164,170,270, 420, 440 | ||
* | ||
* @param {number} pullDistance 下拉的总距离 | ||
* @param {number=} base 基础值,calc(iphone 8p - 40px) | ||
* @return {number} 返回值 | ||
*/ | ||
dumping(offsetY, base = 464) { | ||
const y = offsetY > 0 ? offsetY : 0; | ||
const ratio = this.data.clientHeight / base; | ||
let result = 0; | ||
if (this.data.clientHeight > 400) { | ||
// 系数 .65 | ||
result = (440.5 + .5) * ratio / (1 + (y / 551.5665) ** -1.009) - .5; | ||
} | ||
else { | ||
// 系数 .7 | ||
result = (440.0483 + .0510) * ratio / (1 + (y / 444.0544) ** -1.2801) - .0510; | ||
} | ||
return Math.round(result); | ||
}, | ||
return _context.abrupt("return"); | ||
async touchHdl({type, touches = [], changedTouches = [], manual = false}) { // eslint-disable-line fecs-max-statements | ||
// 如果上一次没完全关闭,禁止下拉 | ||
if (this.closing || (this.data.disableTouch && !manual)) { | ||
return; | ||
} | ||
// ue规定: 如果api调用下拉刷新,则不启用手势刷新 | ||
const disabled = !this.data.pullToRefresh && !manual && this.status === STATUS.IDLE; | ||
case 68: | ||
// offsetY快,setData慢,可能造成向上划没到顶。 | ||
// 要注意 初始就向下划,过滤掉 | ||
if (offsetY > 0 || this.data.offsetY > 0) { | ||
setOffsetY = function setOffsetY() { | ||
return _this2.setData({ | ||
offsetY: offsetY | ||
}); | ||
}; // 如果已经禁止滚动&&还往下拉,直接赋值 | ||
if (!this.data.enableScroll) { | ||
setOffsetY(); | ||
} else { | ||
this.setData({ | ||
// 该setData 不会多次执行 | ||
enableScroll: false | ||
}, setOffsetY); | ||
} | ||
// 禁用多点触控 | ||
switch (type) { | ||
case 'touchstart': { | ||
this.touching = true; | ||
for (const touch of touches) { | ||
const {identifier: id, pageY} = touch; | ||
if (this.pos[id] == null) { | ||
this.pos[id] = pageY + this.scrollTop; | ||
break; | ||
} | ||
} | ||
break; | ||
} | ||
case 'touchmove': { | ||
let distance = 0; | ||
for (const touch of touches) { | ||
const {identifier: id, pageY} = touch; | ||
if (this.pos[id]) { | ||
distance += Math.round(pageY - this.pos[id]); | ||
} | ||
} | ||
let offsetY = this.offsetY = this.dumping(distance + this.lastOffsetY); | ||
return _context.abrupt("break", 99); | ||
const pullDown = distance > 0; | ||
// 没loading动画时下拉计算动画 | ||
if (this.status === STATUS.IDLE) { | ||
const circleInfo = calcCircle(offsetY, this.data.loadingHeight); | ||
circleInfo && this.setData(circleInfo); | ||
} | ||
case 70: | ||
_iteratorNormalCompletion3 = true; | ||
_didIteratorError3 = false; | ||
_iteratorError3 = undefined; | ||
_context.prev = 73; | ||
// 还未加载时,向上划要收起loading | ||
if (!pullDown && this.status !== STATUS.IDLE && Math.abs(offsetY) > 20) { | ||
this.fadeCircle(); | ||
this.setData({ | ||
status: STATUS.IDLE, | ||
offsetY: 0 | ||
}); | ||
this.status = STATUS.IDLE; | ||
this.lastOffsetY = this.offsetY = 0; | ||
return; | ||
} | ||
for (_iterator3 = changedTouches[Symbol.iterator](); !(_iteratorNormalCompletion3 = (_step3 = _iterator3.next()).done); _iteratorNormalCompletion3 = true) { | ||
_touch2 = _step3.value; | ||
_id2 = _touch2.identifier, _pageY2 = _touch2.pageY; | ||
if (this.pos[_id2]) { | ||
this.lastOffsetY += _pageY2 - this.pos[_id2]; | ||
} | ||
if (disabled) { | ||
return; | ||
} | ||
// offsetY快,setData慢,可能造成向上划没到顶。 | ||
// 要注意 初始就向下划,过滤掉 | ||
if (offsetY > 0 || this.data.offsetY > 0) { | ||
const setOffsetY = () => this.setData({offsetY}); | ||
// 如果已经禁止滚动&&还往下拉,直接赋值 | ||
if (!this.data.enableScroll) { | ||
setOffsetY(); | ||
} | ||
else { | ||
this.setData({ // 该setData 不会多次执行 | ||
enableScroll: false | ||
}, setOffsetY); | ||
} | ||
} | ||
break; | ||
} | ||
case 'touchend': { | ||
for (const touch of changedTouches) { | ||
const {identifier: id, pageY} = touch; | ||
if (this.pos[id]) { | ||
this.lastOffsetY += pageY - this.pos[id]; | ||
} | ||
} | ||
_context.next = 81; | ||
break; | ||
if (touches.length || disabled) { | ||
return; | ||
} | ||
case 77: | ||
_context.prev = 77; | ||
_context.t3 = _context["catch"](73); | ||
_didIteratorError3 = true; | ||
_iteratorError3 = _context.t3; | ||
this.touching = false; | ||
this.pos = {}; | ||
case 81: | ||
_context.prev = 81; | ||
_context.prev = 82; | ||
if (!_iteratorNormalCompletion3 && _iterator3["return"] != null) { | ||
_iterator3["return"](); | ||
// 判断是否加载 | ||
const shouldLoad = this.scrollTop <= 0 && this.offsetY >= this.data.loadingHeight; | ||
let result = 0; | ||
if (shouldLoad) { | ||
// 只有status === 0时,触发加载 | ||
if (this.status === STATUS.IDLE) { | ||
this.triggerEvent('refresh'); | ||
this.setData({status: STATUS.LOADING}); | ||
this.status = STATUS.LOADING; | ||
} | ||
this.startRefreshTime = Date.now(); | ||
result = this.data.loadingHeight; | ||
} | ||
else { | ||
this.fadeCircle(); | ||
} | ||
this.setData({ | ||
enableScroll: true | ||
}, | ||
() => { | ||
this.setData({ | ||
offsetY: result | ||
}); | ||
}); | ||
this.lastOffsetY = this.offsetY = result; | ||
break; | ||
} | ||
} | ||
}, | ||
case 84: | ||
_context.prev = 84; | ||
if (!_didIteratorError3) { | ||
_context.next = 87; | ||
break; | ||
/** | ||
* circle渐隐 | ||
*/ | ||
fadeCircle() { | ||
return linearAccu((y, callback) => { | ||
const circleInfo = calcCircle(y, this.data.loadingHeight); | ||
if (circleInfo) { | ||
this.setData(circleInfo, callback); | ||
} | ||
throw _iteratorError3; | ||
case 87: | ||
return _context.finish(84); | ||
case 88: | ||
return _context.finish(81); | ||
case 89: | ||
if (!(touches.length || disabled)) { | ||
_context.next = 91; | ||
break; | ||
else { | ||
callback(); | ||
} | ||
}, this.data.loadingHeight, 0); | ||
}, | ||
return _context.abrupt("return"); | ||
/** | ||
* 渐隐loadingbar | ||
*/ | ||
async closeLoading() { | ||
// 防止关闭后,touchend还在触发中 | ||
this.closing = true; | ||
this.offsetY = 0; | ||
if (!this.data.enableScroll) { | ||
await syncSetData(this, {enableScroll: true}); | ||
} | ||
await syncSetData(this, {offsetY: 0}); | ||
// 关闭动画200ms | ||
await new Promise(r => setTimeout(r, 200)); | ||
// 放在后面防止小球和text重叠 | ||
await syncSetData(this, {status: STATUS.IDLE}); | ||
this.status = STATUS.IDLE; | ||
this.lastOffsetY = this.offsetY = 0; | ||
this.closing = false; | ||
}, | ||
case 91: | ||
this.touching = false; | ||
this.pos = {}; // 判断是否加载 | ||
shouldLoad = this.scrollTop <= 0 && this.offsetY >= this.data.loadingHeight; | ||
result = 0; | ||
if (shouldLoad) { | ||
// 只有status === 0时,触发加载 | ||
if (this.status === STATUS.IDLE) { | ||
this.triggerEvent('refresh'); | ||
this.setData({ | ||
status: STATUS.LOADING | ||
}); | ||
this.status = STATUS.LOADING; | ||
} | ||
this.startRefreshTime = Date.now(); | ||
result = this.data.loadingHeight; | ||
} else { | ||
this.fadeCircle(); | ||
/** | ||
* 调用模拟下拉刷新 | ||
*/ | ||
async startRefresh() { | ||
// 未关闭又调用 | ||
if (this.status !== STATUS.IDLE) { | ||
this.debCloseLoading.cancel(); | ||
await this.closeLoading(); | ||
} | ||
this.status = STATUS.LOADING; | ||
this.setData({ | ||
enableScroll: false, | ||
status: STATUS.LOADING | ||
}, () => { | ||
if (this.closing) { | ||
return; | ||
} | ||
this.offsetY = this.data.loadingHeight; | ||
this.touchHdl({type: 'touchend', manual: true}); | ||
}); | ||
}, | ||
this.setData({ | ||
enableScroll: true | ||
}, function () { | ||
_this2.setData({ | ||
offsetY: result | ||
}); | ||
}); | ||
this.lastOffsetY = this.offsetY = result; | ||
return _context.abrupt("break", 99); | ||
/** | ||
* 停止当前刷新 | ||
*/ | ||
async stopRefresh() { | ||
// 用户下拉,至少保证小球转1圈 | ||
let time = 500 - (Date.now() - this.startRefreshTime); | ||
time = time > 0 ? time : 0; | ||
await new Promise(r => setTimeout(r, time)); | ||
this.status = STATUS.SHOWTEXT; | ||
this.setData({ | ||
status: STATUS.SHOWTEXT | ||
}); | ||
await this.debCloseLoading(); | ||
}, | ||
case 99: | ||
case "end": | ||
return _context.stop(); | ||
} | ||
} | ||
}, _callee, this, [[11, 24, 28, 36], [29,, 31, 35], [41, 45, 49, 57], [50,, 52, 56], [73, 77, 81, 89], [82,, 84, 88]]); | ||
})); | ||
/** | ||
* 滚动到底部时触发 | ||
* @param {Object} param detail 事件 | ||
*/ | ||
scrollToLower({detail}) { | ||
this.triggerEvent('scrolltolower', detail); | ||
}, | ||
function touchHdl(_x) { | ||
return _touchHdl.apply(this, arguments); | ||
} | ||
return touchHdl; | ||
}(), | ||
/** | ||
* circle渐隐 | ||
*/ | ||
fadeCircle: function fadeCircle() { | ||
var _this3 = this; | ||
return (0, _index.linearAccu)(function (y, callback) { | ||
var circleInfo = (0, _index.calcCircle)(y, _this3.data.loadingHeight); | ||
if (circleInfo) { | ||
_this3.setData(circleInfo, callback); | ||
} else { | ||
callback(); | ||
setScrollTop(scrollTop) { | ||
this.setData({ | ||
scrollTop | ||
}); | ||
} | ||
}, this.data.loadingHeight, 0); | ||
}, | ||
/** | ||
* 渐隐loadingbar | ||
*/ | ||
closeLoading: function () { | ||
var _closeLoading = (0, _asyncToGenerator2["default"])( | ||
/*#__PURE__*/ | ||
_regenerator["default"].mark(function _callee2() { | ||
return _regenerator["default"].wrap(function _callee2$(_context2) { | ||
while (1) { | ||
switch (_context2.prev = _context2.next) { | ||
case 0: | ||
// 防止关闭后,touchend还在触发中 | ||
this.closing = true; | ||
this.offsetY = 0; | ||
created() { | ||
this.setData({ | ||
max: upx2dpx(this.data.maxDistance) | ||
}); | ||
if (this.data.enableScroll) { | ||
_context2.next = 5; | ||
break; | ||
} | ||
this.clipText(this.data.text); | ||
// 记录用户下拉开始时间,到加载结束至少保证小球转3圈 | ||
this.startRefreshTime = 0; | ||
_context2.next = 5; | ||
return (0, _index.syncSetData)(this, { | ||
enableScroll: true | ||
}); | ||
// 滚动高度,用于计算是否触顶下拉 | ||
this.scrollTop = 0; | ||
case 5: | ||
_context2.next = 7; | ||
return (0, _index.syncSetData)(this, { | ||
offsetY: 0 | ||
}); | ||
// 是否有手指在屏幕 | ||
this.touching = false; | ||
case 7: | ||
_context2.next = 9; | ||
return new Promise(function (r) { | ||
return setTimeout(r, 200); | ||
}); | ||
// 多点触控位置,解决手指交叉切换问题 | ||
this.pos = {}; | ||
case 9: | ||
_context2.next = 11; | ||
return (0, _index.syncSetData)(this, { | ||
status: STATUS.IDLE | ||
}); | ||
// 上次结束位置 | ||
this.lastOffsetY = 0; | ||
case 11: | ||
this.status = STATUS.IDLE; | ||
this.lastOffsetY = this.offsetY = 0; | ||
this.closing = false; | ||
// 手指移动位置 * 用这个来判断是否手机离开屏幕 | ||
this.offsetY = 0; | ||
case 14: | ||
case "end": | ||
return _context2.stop(); | ||
} | ||
} | ||
}, _callee2, this); | ||
})); | ||
// 0: 未开始 1: 加载中 2: 展示话术 | ||
this.status = STATUS.IDLE; | ||
function closeLoading() { | ||
return _closeLoading.apply(this, arguments); | ||
} | ||
// 是否正在关闭 | ||
this.closing = false; | ||
return closeLoading; | ||
}(), | ||
// 循环检测是否要关闭loading | ||
this.debOffsetCheck = () => new Promise(resolve => { | ||
const timer = setInterval(() => { | ||
if (this.touching) { | ||
return; | ||
} | ||
clearInterval(timer); | ||
resolve(); | ||
}, 300); | ||
}); | ||
/** | ||
* 调用模拟下拉刷新 | ||
*/ | ||
startRefresh: function () { | ||
var _startRefresh = (0, _asyncToGenerator2["default"])( | ||
/*#__PURE__*/ | ||
_regenerator["default"].mark(function _callee3() { | ||
var _this4 = this; | ||
// 关闭loading bar; text显示时长: 800ms | ||
this.debCloseLoading = promiseDebounce(async () => { | ||
await this.debOffsetCheck(); | ||
await new Promise(r => setTimeout(r, 800)); | ||
await this.closeLoading(); | ||
}, 100); | ||
}, | ||
return _regenerator["default"].wrap(function _callee3$(_context3) { | ||
while (1) { | ||
switch (_context3.prev = _context3.next) { | ||
case 0: | ||
if (!(this.status !== STATUS.IDLE)) { | ||
_context3.next = 4; | ||
break; | ||
ready() { | ||
// 计算滑动区域高度,用于计算阻尼值 | ||
swan.createSelectorQuery().in(this) | ||
.select('.smt-feed-wrap').boundingClientRect(res => { | ||
try { | ||
if (!res) { | ||
throw '未找到节点'; | ||
} | ||
this.debCloseLoading.cancel(); | ||
_context3.next = 4; | ||
return this.closeLoading(); | ||
case 4: | ||
this.status = STATUS.LOADING; | ||
this.setData({ | ||
enableScroll: false, | ||
status: STATUS.LOADING | ||
}, function () { | ||
if (_this4.closing) { | ||
return; | ||
} | ||
_this4.offsetY = _this4.data.loadingHeight; | ||
_this4.touchHdl({ | ||
type: 'touchend', | ||
manual: true | ||
}); | ||
}); | ||
case 6: | ||
case "end": | ||
return _context3.stop(); | ||
const clientHeight = res.height; | ||
this.setData({clientHeight}); | ||
} | ||
} | ||
}, _callee3, this); | ||
})); | ||
function startRefresh() { | ||
return _startRefresh.apply(this, arguments); | ||
} | ||
return startRefresh; | ||
}(), | ||
/** | ||
* 停止当前刷新 | ||
*/ | ||
stopRefresh: function () { | ||
var _stopRefresh = (0, _asyncToGenerator2["default"])( | ||
/*#__PURE__*/ | ||
_regenerator["default"].mark(function _callee4() { | ||
var time; | ||
return _regenerator["default"].wrap(function _callee4$(_context4) { | ||
while (1) { | ||
switch (_context4.prev = _context4.next) { | ||
case 0: | ||
// 用户下拉,至少保证小球转1圈 | ||
time = 500 - (Date.now() - this.startRefreshTime); | ||
time = time > 0 ? time : 0; | ||
_context4.next = 4; | ||
return new Promise(function (r) { | ||
return setTimeout(r, time); | ||
}); | ||
case 4: | ||
this.status = STATUS.SHOWTEXT; | ||
this.setData({ | ||
status: STATUS.SHOWTEXT | ||
}); | ||
_context4.next = 8; | ||
return this.debCloseLoading(); | ||
case 8: | ||
case "end": | ||
return _context4.stop(); | ||
catch (err) { | ||
console.error('获取节点信息错误'); | ||
} | ||
} | ||
}, _callee4, this); | ||
})); | ||
function stopRefresh() { | ||
return _stopRefresh.apply(this, arguments); | ||
} | ||
return stopRefresh; | ||
}(), | ||
/** | ||
* 滚动到底部时触发 | ||
* @param {Object} param detail 事件 | ||
*/ | ||
scrollToLower: function scrollToLower(_ref3) { | ||
var detail = _ref3.detail; | ||
this.triggerEvent('scrolltolower', detail); | ||
}, | ||
setScrollTop: function setScrollTop(scrollTop) { | ||
this.setData({ | ||
scrollTop: scrollTop | ||
}); | ||
}).exec(); | ||
} | ||
}, | ||
created: function created() { | ||
var _this5 = this; | ||
this.setData({ | ||
max: (0, _px.upx2dpx)(this.data.maxDistance) | ||
}); | ||
this.clipText(this.data.text); // 记录用户下拉开始时间,到加载结束至少保证小球转3圈 | ||
this.startRefreshTime = 0; // 滚动高度,用于计算是否触顶下拉 | ||
this.scrollTop = 0; // 是否有手指在屏幕 | ||
this.touching = false; // 多点触控位置,解决手指交叉切换问题 | ||
this.pos = {}; // 上次结束位置 | ||
this.lastOffsetY = 0; // 手指移动位置 * 用这个来判断是否手机离开屏幕 | ||
this.offsetY = 0; // 0: 未开始 1: 加载中 2: 展示话术 | ||
this.status = STATUS.IDLE; // 是否正在关闭 | ||
this.closing = false; // 循环检测是否要关闭loading | ||
this.debOffsetCheck = function () { | ||
return new Promise(function (resolve) { | ||
var timer = setInterval(function () { | ||
if (_this5.touching) { | ||
return; | ||
} | ||
clearInterval(timer); | ||
resolve(); | ||
}, 300); | ||
}); | ||
}; // 关闭loading bar; text显示时长: 800ms | ||
this.debCloseLoading = (0, _index.promiseDebounce)( | ||
/*#__PURE__*/ | ||
(0, _asyncToGenerator2["default"])( | ||
/*#__PURE__*/ | ||
_regenerator["default"].mark(function _callee5() { | ||
return _regenerator["default"].wrap(function _callee5$(_context5) { | ||
while (1) { | ||
switch (_context5.prev = _context5.next) { | ||
case 0: | ||
_context5.next = 2; | ||
return _this5.debOffsetCheck(); | ||
case 2: | ||
_context5.next = 4; | ||
return new Promise(function (r) { | ||
return setTimeout(r, 800); | ||
}); | ||
case 4: | ||
_context5.next = 6; | ||
return _this5.closeLoading(); | ||
case 6: | ||
case "end": | ||
return _context5.stop(); | ||
} | ||
} | ||
}, _callee5); | ||
})), 100); | ||
}, | ||
ready: function ready() { | ||
var _this6 = this; | ||
// 计算滑动区域高度,用于计算阻尼值 | ||
swan.createSelectorQuery()["in"](this).select('.smt-feed-wrap').boundingClientRect(function (res) { | ||
try { | ||
if (!res) { | ||
throw '未找到节点'; | ||
} | ||
var clientHeight = res.height; | ||
_this6.setData({ | ||
clientHeight: clientHeight | ||
}); | ||
} catch (err) { | ||
console.error('获取节点信息错误'); | ||
} | ||
}).exec(); | ||
} | ||
}); | ||
}); |
@@ -1,1 +0,1 @@ | ||
{"name":"component","label":"布局组件","type":"component","configPath":"./smart-design-config.json","version":"0.0.37-alpha.0"} | ||
{"name":"component","label":"布局组件","type":"component","configPath":"./smart-design-config.json","version":"0.0.38-alpha.0"} |
Sorry, the diff of this file is not supported yet
1419175
1
18734
+ Added@babel/runtime@^7.7.7
+ Added@babel/runtime@7.26.9(transitive)
+ Addedregenerator-runtime@0.14.1(transitive)