tplus-components-touch 3.26.3 → 3.27.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (194) hide show
  1. package/README.md +16 -16
  2. package/dist/components/acCitySelect/CitySelect.js +18 -18
  3. package/dist/components/acCitySelect/CitySelect.js.map +1 -1
  4. package/dist/components/acCitySelect/CitySelect.less +9 -9
  5. package/dist/components/acCitySelect/citys.js.map +1 -1
  6. package/dist/components/acCitySelect/index.js.map +1 -1
  7. package/dist/components/acCitySelect/provinceData.js +7 -7
  8. package/dist/components/acCitySelect/provinceData.js.map +1 -1
  9. package/dist/components/addLog/AddLogProcessor.js +6 -6
  10. package/dist/components/addLog/AddLogProcessor.js.map +1 -1
  11. package/dist/components/addLog/OperationLogApi.js +3 -3
  12. package/dist/components/addLog/OperationLogApi.js.map +1 -1
  13. package/dist/components/autoComplete/index.js +14 -14
  14. package/dist/components/autoComplete/index.js.map +1 -1
  15. package/dist/components/autoComplete/index.less +89 -89
  16. package/dist/components/autoComplete/option.js.map +1 -1
  17. package/dist/components/autoCompleteWithKeyboard/index.js +14 -14
  18. package/dist/components/autoCompleteWithKeyboard/index.js.map +1 -1
  19. package/dist/components/autoCompleteWithKeyboard/index.less +7 -7
  20. package/dist/components/billSearch/api.js +98 -37
  21. package/dist/components/billSearch/api.js.map +1 -1
  22. package/dist/components/billSearch/index.js +6 -6
  23. package/dist/components/billSearch/index.js.map +1 -1
  24. package/dist/components/billSearch/index.less +373 -373
  25. package/dist/components/cloudPrint/BTPrintFormatUtil.js +17 -17
  26. package/dist/components/cloudPrint/BTPrintFormatUtil.js.map +1 -1
  27. package/dist/components/cloudPrint/api.js.map +1 -1
  28. package/dist/components/cloudPrint/index.js.map +1 -1
  29. package/dist/components/cloudPrint/printDispatch.js +7 -7
  30. package/dist/components/cloudPrint/printDispatch.js.map +1 -1
  31. package/dist/components/commonForm/addressPicker/index.js +23 -14
  32. package/dist/components/commonForm/addressPicker/index.js.map +1 -1
  33. package/dist/components/commonForm/addressPicker/style.less +10 -10
  34. package/dist/components/commonForm/autoComplete/index.js.map +1 -1
  35. package/dist/components/commonForm/autoComplete/style.less +2 -2
  36. package/dist/components/commonForm/datePicker/index.js.map +1 -1
  37. package/dist/components/commonForm/datePicker/style.less +4 -4
  38. package/dist/components/commonForm/formControl/index.js.map +1 -1
  39. package/dist/components/commonForm/index.js +13 -7
  40. package/dist/components/commonForm/index.js.map +1 -1
  41. package/dist/components/commonForm/inputNumber/index.js.map +1 -1
  42. package/dist/components/commonForm/inputNumber/style.less +10 -10
  43. package/dist/components/commonForm/radio/index.js.map +1 -1
  44. package/dist/components/commonForm/style.less +1 -1
  45. package/dist/components/deliverySearch/api.js +21 -21
  46. package/dist/components/deliverySearch/api.js.map +1 -1
  47. package/dist/components/deliverySearch/index.js +6 -6
  48. package/dist/components/deliverySearch/index.js.map +1 -1
  49. package/dist/components/deliverySearch/index.less +553 -553
  50. package/dist/components/form/index.js.map +1 -1
  51. package/dist/components/hardwareAPI/index.js.map +1 -1
  52. package/dist/components/hotKey/config.js +23 -23
  53. package/dist/components/hotKey/config.js.map +1 -1
  54. package/dist/components/hotKey/hotKeyModal.js.map +1 -1
  55. package/dist/components/hotKey/index.js +26 -26
  56. package/dist/components/hotKey/index.js.map +1 -1
  57. package/dist/components/hotKey/localConfig.js +66 -133
  58. package/dist/components/hotKey/localConfig.js.map +1 -1
  59. package/dist/components/hotKey/style.less +96 -96
  60. package/dist/components/hotKey/utils.js.map +1 -1
  61. package/dist/components/input/index.js +6 -6
  62. package/dist/components/input/index.js.map +1 -1
  63. package/dist/components/input/style.less +99 -99
  64. package/dist/components/input/tplusInput/index.js +30 -30
  65. package/dist/components/input/tplusInput/index.js.map +1 -1
  66. package/dist/components/input/tplusInput/inputContent.js.map +1 -1
  67. package/dist/components/input/tplusInput/inputs.js.map +1 -1
  68. package/dist/components/input/tplusInput/style.less +132 -132
  69. package/dist/components/input/utils/index.js.map +1 -1
  70. package/dist/components/inventorySearch/api.js +58 -58
  71. package/dist/components/inventorySearch/api.js.map +1 -1
  72. package/dist/components/inventorySearch/index.js +3 -3
  73. package/dist/components/inventorySearch/index.js.map +1 -1
  74. package/dist/components/inventorySearch/index.less +119 -119
  75. package/dist/components/inventorySearch/store.js.map +1 -1
  76. package/dist/components/inventorySearch/tab.js.map +1 -1
  77. package/dist/components/keyboard/index.js.map +1 -1
  78. package/dist/components/keyboard/index.less +469 -469
  79. package/dist/components/keyboard/letterKeyboard.js +2 -2
  80. package/dist/components/keyboard/letterKeyboard.js.map +1 -1
  81. package/dist/components/keyboard/numKeyboard.js +4 -4
  82. package/dist/components/keyboard/numKeyboard.js.map +1 -1
  83. package/dist/components/keyboard/numKeyboardScan.js.map +1 -1
  84. package/dist/components/keyboard/numberButton_input.js +5 -5
  85. package/dist/components/keyboard/numberButton_input.js.map +1 -1
  86. package/dist/components/keyboard/numkeyboardPassword.js +4 -4
  87. package/dist/components/keyboard/numkeyboardPassword.js.map +1 -1
  88. package/dist/components/keyboard/onlyKeyboard.js +7 -7
  89. package/dist/components/keyboard/onlyKeyboard.js.map +1 -1
  90. package/dist/components/keyboard/onlyLetterButton.js +2 -2
  91. package/dist/components/keyboard/onlyLetterButton.js.map +1 -1
  92. package/dist/components/keyboard/onlyLetterButton2.js +2 -2
  93. package/dist/components/keyboard/onlyLetterButton2.js.map +1 -1
  94. package/dist/components/keyboard/onlyLetterButton2.less +161 -161
  95. package/dist/components/keyboard/onlyNumberButton.js +2 -2
  96. package/dist/components/keyboard/onlyNumberButton.js.map +1 -1
  97. package/dist/components/keyboard/onlyNumberButton2.js +3 -3
  98. package/dist/components/keyboard/onlyNumberButton2.js.map +1 -1
  99. package/dist/components/keyboard/textKeyboard.js.map +1 -1
  100. package/dist/components/layout/hamburger.js.map +1 -1
  101. package/dist/components/layout/index.js +10 -10
  102. package/dist/components/layout/index.js.map +1 -1
  103. package/dist/components/layout/layout.js.map +1 -1
  104. package/dist/components/layout/sider.js +12 -12
  105. package/dist/components/layout/sider.js.map +1 -1
  106. package/dist/components/layout/style.less +82 -82
  107. package/dist/components/loading/index.js +15 -15
  108. package/dist/components/loading/index.js.map +1 -1
  109. package/dist/components/loading/loadingContent.js.map +1 -1
  110. package/dist/components/loading/style.less +61 -61
  111. package/dist/components/loading/utils.js.map +1 -1
  112. package/dist/components/message/index.js +8 -8
  113. package/dist/components/message/index.js.map +1 -1
  114. package/dist/components/message/index.less +101 -101
  115. package/dist/components/modal/index.js.map +1 -1
  116. package/dist/components/modal/index.less +19 -19
  117. package/dist/components/modalVertical/index.js +7 -7
  118. package/dist/components/modalVertical/index.js.map +1 -1
  119. package/dist/components/modalVertical/style.less +60 -60
  120. package/dist/components/modalWraper/index.js +15 -15
  121. package/dist/components/modalWraper/index.js.map +1 -1
  122. package/dist/components/modalWraper/style.less +257 -257
  123. package/dist/components/modalWraper/utils.js.map +1 -1
  124. package/dist/components/notification/index.js +4 -4
  125. package/dist/components/notification/index.js.map +1 -1
  126. package/dist/components/notification/index.less +51 -51
  127. package/dist/components/overflowTip/index.js +15 -15
  128. package/dist/components/overflowTip/index.js.map +1 -1
  129. package/dist/components/overflowTip/style.less +66 -66
  130. package/dist/components/page/index.js.map +1 -1
  131. package/dist/components/page/index.less +21 -21
  132. package/dist/components/presale/pickup.js +419 -0
  133. package/dist/components/presale/pickup.js.map +1 -0
  134. package/dist/components/presale/style.less +48 -0
  135. package/dist/components/product/detail.js +7 -7
  136. package/dist/components/product/detail.js.map +1 -1
  137. package/dist/components/product/getCard.js +5 -5
  138. package/dist/components/product/getCard.js.map +1 -1
  139. package/dist/components/product/index.less +128 -128
  140. package/dist/components/progressState/EmptyAndErrorView.js.map +1 -1
  141. package/dist/components/progressState/ProgressState.js +10 -10
  142. package/dist/components/progressState/ProgressState.js.map +1 -1
  143. package/dist/components/progressState/index.js.map +1 -1
  144. package/dist/components/progressState/style.less +65 -65
  145. package/dist/components/scan/index.js.map +1 -1
  146. package/dist/components/scan/index.less +33 -33
  147. package/dist/components/select/index.js.map +1 -1
  148. package/dist/components/select/index.less +11 -11
  149. package/dist/components/settlement/asyncModal.js.map +1 -1
  150. package/dist/components/settlement/index.js.map +1 -1
  151. package/dist/components/settlement/prototypeTable/index.js.map +1 -1
  152. package/dist/components/settlement/prototypeTable/style.less +58 -58
  153. package/dist/components/settlement/prototypeTable/utils.js.map +1 -1
  154. package/dist/components/settlement/settlement.js +617 -570
  155. package/dist/components/settlement/settlement.js.map +1 -1
  156. package/dist/components/settlement/settlement.less +1600 -1643
  157. package/dist/components/settlement/settlementStore.js +224 -292
  158. package/dist/components/settlement/settlementStore.js.map +1 -1
  159. package/dist/components/settlement/utils.js.map +1 -1
  160. package/dist/components/socket/index.js +11 -11
  161. package/dist/components/socket/index.js.map +1 -1
  162. package/dist/components/spin/index.js +6 -6
  163. package/dist/components/spin/index.js.map +1 -1
  164. package/dist/components/spin/spin-style.less +436 -436
  165. package/dist/components/test/index.js +3 -3
  166. package/dist/components/test/index.js.map +1 -1
  167. package/dist/components/ticon/iconfont/demo.css +539 -539
  168. package/dist/components/ticon/iconfont/demo_index.html +5225 -5248
  169. package/dist/components/ticon/iconfont/iconfont.css +891 -895
  170. package/dist/components/ticon/iconfont/iconfont.js +6 -6
  171. package/dist/components/ticon/iconfont/iconfont.js.map +1 -1
  172. package/dist/components/ticon/iconfont/iconfont.json +1542 -1549
  173. package/dist/components/ticon/iconfont/iconfont.svg +593 -593
  174. package/dist/components/ticon/iconfont/iconfont.ttf +0 -0
  175. package/dist/components/ticon/iconfont/iconfont.woff +0 -0
  176. package/dist/components/ticon/iconfont/iconfont.woff2 +0 -0
  177. package/dist/components/ticon/index.js.map +1 -1
  178. package/dist/components/touchScroll/index.js +9 -9
  179. package/dist/components/touchScroll/index.js.map +1 -1
  180. package/dist/components/touchTable/AuthProcess.js.map +1 -1
  181. package/dist/components/touchTable/generateWater.js.map +1 -1
  182. package/dist/components/touchTable/index.js +18 -9
  183. package/dist/components/touchTable/index.js.map +1 -1
  184. package/dist/components/touchTable/index.less +369 -369
  185. package/dist/components/touchTable/utils.js.map +1 -1
  186. package/dist/demo/PopOverDemo.js.map +1 -1
  187. package/dist/index.js +13 -8
  188. package/dist/index.js.map +1 -1
  189. package/dist/util/tools.js.map +1 -1
  190. package/locales/zh/tplus-components-touch.json +1 -1
  191. package/locales/zh-CN/tplus-components-touch.json +1 -1
  192. package/mocks/memberInfo.json +79 -79
  193. package/package.json +2 -2
  194. package/tsconfig.json +26 -26
@@ -21,21 +21,21 @@ var _createClass2 = require('babel-runtime/helpers/createClass');
21
21
 
22
22
  var _createClass3 = _interopRequireDefault(_createClass2);
23
23
 
24
- var _class, _temp, _initialiseProps; /**
25
- * Created by hzy on 2019/8/2.
26
- *
27
- * options
28
- * @target 实例化时传入的需要委托弹出tip外层容器class名 //new OverflowTip({target: '.member-content-tab'});
29
- * @maxWidth tip最大宽度, 默认220
30
- * @format 格式化展示内容方法, 参数为传入的原本字符串内容, 需要返回格式化后的字符串 // format(text) { return newText }
31
- * @style 弹出tip样式
32
- * 需要在弹出的提示的节点上绑定内容 data-overflow='tip' //<td data-overflow='tip'>{name}</td>
33
- *
34
- * @update 更新实例方法,参数与实例化时的options内容一致,不传项则用实例化时的内容或默认值 // update(options)
35
- * @destroy 组件销毁时候需要调用该方法清理
36
- * @hideTip 隐藏tip展示内容
37
- * @tipShow 实例属性,判断tip是否为展示显示状态
38
- * @containerDom 实例属性,委托时间外层容器dom节点
24
+ var _class, _temp, _initialiseProps; /**
25
+ * Created by hzy on 2019/8/2.
26
+ *
27
+ * options
28
+ * @target 实例化时传入的需要委托弹出tip外层容器class名 //new OverflowTip({target: '.member-content-tab'});
29
+ * @maxWidth tip最大宽度, 默认220
30
+ * @format 格式化展示内容方法, 参数为传入的原本字符串内容, 需要返回格式化后的字符串 // format(text) { return newText }
31
+ * @style 弹出tip样式
32
+ * 需要在弹出的提示的节点上绑定内容 data-overflow='tip' //<td data-overflow='tip'>{name}</td>
33
+ *
34
+ * @update 更新实例方法,参数与实例化时的options内容一致,不传项则用实例化时的内容或默认值 // update(options)
35
+ * @destroy 组件销毁时候需要调用该方法清理
36
+ * @hideTip 隐藏tip展示内容
37
+ * @tipShow 实例属性,判断tip是否为展示显示状态
38
+ * @containerDom 实例属性,委托时间外层容器dom节点
39
39
  */
40
40
 
41
41
 
@@ -1 +1 @@
1
- {"version":3,"sources":["tplus-components-touch/components/overflowTip/index.js"],"names":["currentDomId","OverflowTip","options","target","maxWidth","format","style","el","document","createElement","containerDom","tipShow","body","appendChild","addEventListener","bodyClickEvent","bodyTouchmoveEvent","init","querySelector","e","ev","window","event","srcElement","dataset","overflow","clientWidth","scrollWidth","pageX","pageY","textContent","renderText","stampId","String","Date","tipid","render","undefined","tipMaxWidth","bodyWidth","bodyHeight","clientHeight","offsetSize","params","getVirtualTipDomSize","virtualTipDomWidth","virtualTipDomHeight","pageXDirection","pageYDirection","arrowSize","arrowOffsetSize","arrowAndOffsetSize","marginLeftStyle","marginTopStyle","offsetY","tipNode","left","top","width","marginLeft","marginTop","forEach","v","ReactDOM","unmountComponentAtNode","removeChild","removeEventListener","className","virtualTipDom","position","opacity","virtualTipNode","firstElementChild","children","destroyBefore","props","newElement","React","cloneElement","setTimeout"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * Created by hzy on 2019/8/2.\n *\n * options\n * @target 实例化时传入的需要委托弹出tip外层容器class名 //new OverflowTip({target: '.member-content-tab'});\n * @maxWidth tip最大宽度, 默认220\n * @format 格式化展示内容方法, 参数为传入的原本字符串内容, 需要返回格式化后的字符串 // format(text) { return newText }\n * @style 弹出tip样式\n * 需要在弹出的提示的节点上绑定内容 data-overflow='tip' //<td data-overflow='tip'>{name}</td>\n *\n * @update 更新实例方法,参数与实例化时的options内容一致,不传项则用实例化时的内容或默认值 // update(options)\n * @destroy 组件销毁时候需要调用该方法清理\n * @hideTip 隐藏tip展示内容\n * @tipShow 实例属性,判断tip是否为展示显示状态\n * @containerDom 实例属性,委托时间外层容器dom节点\n */\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport './style.less';\n\nlet currentDomId;\nexport default class OverflowTip {\n\n constructor(options) {\n const {target, maxWidth = 220, format, style = {}} = options;\n\n this.target = target;\n this.maxWidth = maxWidth;\n this.format = format;\n this.style = style;\n this.el = document.createElement('div');\n this.containerDom = null;\n this.tipShow = false;\n\n document.body.appendChild(this.el);\n document.body.addEventListener('click', this.bodyClickEvent, false);\n document.body.addEventListener('touchmove', this.bodyTouchmoveEvent, false);\n\n this.init();\n }\n\n init() {\n this.containerDom = document.querySelector(this.target);\n if (this.containerDom) {\n this.containerDom.addEventListener('click', (e) => {\n const ev = e || window.event;\n const target = ev.target || ev.srcElement;\n if (target.dataset.overflow) {\n const clientWidth = target.clientWidth;\n const scrollWidth = target.scrollWidth;\n\n if (clientWidth < scrollWidth) {\n const {pageX, pageY} = ev;\n const {textContent} = target;\n const renderText = this.format ? this.format(textContent) : textContent;\n\n const stampId = String(+new Date());\n if (target.dataset.tipid && target.dataset.tipid === currentDomId) {\n return this.render(null);\n } else {\n target.dataset.tipid = stampId;\n this.tipShow && this.render(null, undefined, true);\n }\n\n const tipMaxWidth = this.maxWidth;\n const bodyWidth = document.body.clientWidth;\n const bodyHeight = document.body.clientHeight;\n const offsetSize = 20;\n\n const params = {tipMaxWidth, renderText, bodyWidth, bodyHeight};\n const {virtualTipDomWidth, virtualTipDomHeight} = this.getVirtualTipDomSize(params);\n\n let pageXDirection;\n let pageYDirection;\n\n if (bodyWidth - pageX - virtualTipDomWidth < 10) { //判断X轴是否超出可视区\n pageXDirection = true;\n }\n\n if (bodyHeight - pageY - virtualTipDomHeight < (offsetSize + 10)) { //判断Y轴是否超出可视区\n pageYDirection = true;\n }\n\n const arrowSize = 10;\n const arrowOffsetSize = 10;\n const arrowAndOffsetSize = arrowSize + arrowOffsetSize;\n const marginLeftStyle = pageXDirection ? -(virtualTipDomWidth - arrowAndOffsetSize) : -arrowOffsetSize;\n const marginTopStyle = pageYDirection ? -virtualTipDomHeight : 0;\n\n const offsetY = pageYDirection ? pageY - offsetSize : pageY + offsetSize;\n const tipNode = <div\n className={`overflow-tip-wrapper overflow-tip-show ${pageYDirection ? 'tip-arrow-bottom' : 'tip-arrow-top'}`}\n style={{left: pageX, top: offsetY, ...this.style}}\n >\n <div\n className='_overflow-tip'\n style={{width: virtualTipDomWidth, marginLeft: marginLeftStyle, marginTop: marginTopStyle}}\n >{renderText}</div>\n </div>\n\n this.render(tipNode, stampId);\n } else {\n this.render(null);\n }\n }\n }, false);\n }\n }\n\n bodyTouchmoveEvent = (e) => {\n if (this.tipShow) this.render(null);\n }\n\n bodyClickEvent = (e) => {\n const ev = e || window.event;\n const target = ev.target || ev.srcElement;\n if (target.className === '_overflow-tip') return;\n if(!target.dataset.overflow) {\n this.render(null);\n }\n }\n\n getVirtualTipDomSize = (params = {}) => {\n const {tipMaxWidth, renderText, bodyWidth, bodyHeight} = params;\n\n const virtualTipDom = document.createElement('div');\n virtualTipDom.style.position = 'fixed';\n virtualTipDom.style.left = '-99999px';\n virtualTipDom.style.top = '-99999px';\n virtualTipDom.style.opacity = 0;\n\n const virtualTipNode = <div\n className='_overflow-tip'\n style={{maxWidth: tipMaxWidth}}\n >{renderText}</div>\n\n document.body.appendChild(virtualTipDom);\n\n ReactDOM.render(\n virtualTipNode,\n virtualTipDom,\n );\n\n const virtualTipDomHeight = virtualTipDom.firstElementChild.clientHeight;\n const virtualTipDomWidth = virtualTipDom.firstElementChild.clientWidth;\n\n document.body.removeChild(virtualTipDom);\n\n return {virtualTipDomHeight, virtualTipDomWidth}\n }\n\n render = (children, stampId, destroyBefore) => {\n if (this.children && !destroyBefore) {\n const {props: {className}} = this.children;\n const newElement = React.cloneElement(\n this.children,\n {className: `${className} overflow-tip-hide`},\n );\n setTimeout(() => {\n ReactDOM.render(\n null,\n this.el,\n );\n }, 120);\n\n this.children = null;\n currentDomId = undefined;\n this.tipShow = false;\n return ReactDOM.render(\n newElement,\n this.el,\n );\n }\n\n ReactDOM.render(\n children,\n this.el,\n );\n currentDomId = stampId;\n this.children = children;\n this.tipShow = !!children;\n }\n\n update(options = {}) {\n Object.keys(options).forEach(v => this[v] = options[v]);\n\n this.init();\n }\n\n hideTip() {\n this.render(null);\n }\n\n destroy() {\n ReactDOM.unmountComponentAtNode(this.el);\n document.body.removeChild(this.el);\n document.body.removeEventListener('click', this.bodyClickEvent, false);\n document.body.removeEventListener('touchmove', this.bodyTouchmoveEvent, false);\n }\n}\n"]}
1
+ {"version":3,"sources":["tplus-components-touch/components/overflowTip/index.js"],"names":["currentDomId","OverflowTip","options","target","maxWidth","format","style","el","document","createElement","containerDom","tipShow","body","appendChild","addEventListener","bodyClickEvent","bodyTouchmoveEvent","init","querySelector","e","ev","window","event","srcElement","dataset","overflow","clientWidth","scrollWidth","pageX","pageY","textContent","renderText","stampId","String","Date","tipid","render","undefined","tipMaxWidth","bodyWidth","bodyHeight","clientHeight","offsetSize","params","getVirtualTipDomSize","virtualTipDomWidth","virtualTipDomHeight","pageXDirection","pageYDirection","arrowSize","arrowOffsetSize","arrowAndOffsetSize","marginLeftStyle","marginTopStyle","offsetY","tipNode","left","top","width","marginLeft","marginTop","forEach","v","ReactDOM","unmountComponentAtNode","removeChild","removeEventListener","className","virtualTipDom","position","opacity","virtualTipNode","firstElementChild","children","destroyBefore","props","newElement","React","cloneElement","setTimeout"],"mappings":"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","file":"index.js","sourcesContent":["/**\r\n * Created by hzy on 2019/8/2.\r\n *\r\n * options\r\n * @target 实例化时传入的需要委托弹出tip外层容器class名 //new OverflowTip({target: '.member-content-tab'});\r\n * @maxWidth tip最大宽度, 默认220\r\n * @format 格式化展示内容方法, 参数为传入的原本字符串内容, 需要返回格式化后的字符串 // format(text) { return newText }\r\n * @style 弹出tip样式\r\n * 需要在弹出的提示的节点上绑定内容 data-overflow='tip' //<td data-overflow='tip'>{name}</td>\r\n *\r\n * @update 更新实例方法,参数与实例化时的options内容一致,不传项则用实例化时的内容或默认值 // update(options)\r\n * @destroy 组件销毁时候需要调用该方法清理\r\n * @hideTip 隐藏tip展示内容\r\n * @tipShow 实例属性,判断tip是否为展示显示状态\r\n * @containerDom 实例属性,委托时间外层容器dom节点\r\n */\r\nimport React from 'react';\r\nimport ReactDOM from 'react-dom';\r\nimport './style.less';\r\n\r\nlet currentDomId;\r\nexport default class OverflowTip {\r\n\r\n constructor(options) {\r\n const {target, maxWidth = 220, format, style = {}} = options;\r\n\r\n this.target = target;\r\n this.maxWidth = maxWidth;\r\n this.format = format;\r\n this.style = style;\r\n this.el = document.createElement('div');\r\n this.containerDom = null;\r\n this.tipShow = false;\r\n\r\n document.body.appendChild(this.el);\r\n document.body.addEventListener('click', this.bodyClickEvent, false);\r\n document.body.addEventListener('touchmove', this.bodyTouchmoveEvent, false);\r\n\r\n this.init();\r\n }\r\n\r\n init() {\r\n this.containerDom = document.querySelector(this.target);\r\n if (this.containerDom) {\r\n this.containerDom.addEventListener('click', (e) => {\r\n const ev = e || window.event;\r\n const target = ev.target || ev.srcElement;\r\n if (target.dataset.overflow) {\r\n const clientWidth = target.clientWidth;\r\n const scrollWidth = target.scrollWidth;\r\n\r\n if (clientWidth < scrollWidth) {\r\n const {pageX, pageY} = ev;\r\n const {textContent} = target;\r\n const renderText = this.format ? this.format(textContent) : textContent;\r\n\r\n const stampId = String(+new Date());\r\n if (target.dataset.tipid && target.dataset.tipid === currentDomId) {\r\n return this.render(null);\r\n } else {\r\n target.dataset.tipid = stampId;\r\n this.tipShow && this.render(null, undefined, true);\r\n }\r\n\r\n const tipMaxWidth = this.maxWidth;\r\n const bodyWidth = document.body.clientWidth;\r\n const bodyHeight = document.body.clientHeight;\r\n const offsetSize = 20;\r\n\r\n const params = {tipMaxWidth, renderText, bodyWidth, bodyHeight};\r\n const {virtualTipDomWidth, virtualTipDomHeight} = this.getVirtualTipDomSize(params);\r\n\r\n let pageXDirection;\r\n let pageYDirection;\r\n\r\n if (bodyWidth - pageX - virtualTipDomWidth < 10) { //判断X轴是否超出可视区\r\n pageXDirection = true;\r\n }\r\n\r\n if (bodyHeight - pageY - virtualTipDomHeight < (offsetSize + 10)) { //判断Y轴是否超出可视区\r\n pageYDirection = true;\r\n }\r\n\r\n const arrowSize = 10;\r\n const arrowOffsetSize = 10;\r\n const arrowAndOffsetSize = arrowSize + arrowOffsetSize;\r\n const marginLeftStyle = pageXDirection ? -(virtualTipDomWidth - arrowAndOffsetSize) : -arrowOffsetSize;\r\n const marginTopStyle = pageYDirection ? -virtualTipDomHeight : 0;\r\n\r\n const offsetY = pageYDirection ? pageY - offsetSize : pageY + offsetSize;\r\n const tipNode = <div\r\n className={`overflow-tip-wrapper overflow-tip-show ${pageYDirection ? 'tip-arrow-bottom' : 'tip-arrow-top'}`}\r\n style={{left: pageX, top: offsetY, ...this.style}}\r\n >\r\n <div\r\n className='_overflow-tip'\r\n style={{width: virtualTipDomWidth, marginLeft: marginLeftStyle, marginTop: marginTopStyle}}\r\n >{renderText}</div>\r\n </div>\r\n\r\n this.render(tipNode, stampId);\r\n } else {\r\n this.render(null);\r\n }\r\n }\r\n }, false);\r\n }\r\n }\r\n\r\n bodyTouchmoveEvent = (e) => {\r\n if (this.tipShow) this.render(null);\r\n }\r\n\r\n bodyClickEvent = (e) => {\r\n const ev = e || window.event;\r\n const target = ev.target || ev.srcElement;\r\n if (target.className === '_overflow-tip') return;\r\n if(!target.dataset.overflow) {\r\n this.render(null);\r\n }\r\n }\r\n\r\n getVirtualTipDomSize = (params = {}) => {\r\n const {tipMaxWidth, renderText, bodyWidth, bodyHeight} = params;\r\n\r\n const virtualTipDom = document.createElement('div');\r\n virtualTipDom.style.position = 'fixed';\r\n virtualTipDom.style.left = '-99999px';\r\n virtualTipDom.style.top = '-99999px';\r\n virtualTipDom.style.opacity = 0;\r\n\r\n const virtualTipNode = <div\r\n className='_overflow-tip'\r\n style={{maxWidth: tipMaxWidth}}\r\n >{renderText}</div>\r\n\r\n document.body.appendChild(virtualTipDom);\r\n\r\n ReactDOM.render(\r\n virtualTipNode,\r\n virtualTipDom,\r\n );\r\n\r\n const virtualTipDomHeight = virtualTipDom.firstElementChild.clientHeight;\r\n const virtualTipDomWidth = virtualTipDom.firstElementChild.clientWidth;\r\n\r\n document.body.removeChild(virtualTipDom);\r\n\r\n return {virtualTipDomHeight, virtualTipDomWidth}\r\n }\r\n\r\n render = (children, stampId, destroyBefore) => {\r\n if (this.children && !destroyBefore) {\r\n const {props: {className}} = this.children;\r\n const newElement = React.cloneElement(\r\n this.children,\r\n {className: `${className} overflow-tip-hide`},\r\n );\r\n setTimeout(() => {\r\n ReactDOM.render(\r\n null,\r\n this.el,\r\n );\r\n }, 120);\r\n\r\n this.children = null;\r\n currentDomId = undefined;\r\n this.tipShow = false;\r\n return ReactDOM.render(\r\n newElement,\r\n this.el,\r\n );\r\n }\r\n\r\n ReactDOM.render(\r\n children,\r\n this.el,\r\n );\r\n currentDomId = stampId;\r\n this.children = children;\r\n this.tipShow = !!children;\r\n }\r\n\r\n update(options = {}) {\r\n Object.keys(options).forEach(v => this[v] = options[v]);\r\n\r\n this.init();\r\n }\r\n\r\n hideTip() {\r\n this.render(null);\r\n }\r\n\r\n destroy() {\r\n ReactDOM.unmountComponentAtNode(this.el);\r\n document.body.removeChild(this.el);\r\n document.body.removeEventListener('click', this.bodyClickEvent, false);\r\n document.body.removeEventListener('touchmove', this.bodyTouchmoveEvent, false);\r\n }\r\n}\r\n"]}
@@ -1,66 +1,66 @@
1
- .overflow-tip-wrapper{
2
- position: fixed;
3
- z-index: 9999;
4
- animation-duration: 0.1s;
5
- animation-fill-mode: both;
6
- animation-timing-function: ease-out;
7
- animation-play-state: paused;
8
- opacity: 0;
9
- width: 0px;
10
- &.overflow-tip-show{
11
- animation-name: tipZoomIn;
12
- animation-play-state: running;
13
- }
14
- &.overflow-tip-hide{
15
- animation-name: tipZoomOut;
16
- animation-play-state: running;
17
- }
18
- &.tip-arrow-top:before{
19
- content: '';
20
- display: block;
21
- width: 0;
22
- height: 0;
23
- border-right: 5px solid transparent;
24
- border-left: 5px solid transparent;
25
- border-bottom: 5px solid rgba(0,0,0,.8);
26
- }
27
- &.tip-arrow-bottom:after{
28
- content: '';
29
- display: block;
30
- width:0;
31
- height:0;
32
- border-right: 5px solid transparent;
33
- border-left: 5px solid transparent;
34
- border-top: 5px solid rgba(0,0,0,.8);
35
- }
36
- @keyframes tipZoomIn {
37
- 0% {
38
- opacity: .7;
39
- transform: scale3d(0.9,0.9,0.9) translate3d(0,0,0)
40
- }
41
- 100% {
42
- opacity: 1;
43
- transform: scale3d(1,1,1) translate3d(0,0,0)
44
- }
45
- }
46
- @keyframes tipZoomOut {
47
- 0% {
48
- opacity: 1;
49
- transform: scale3d(1,1,1) translate3d(0,0,0);
50
- }
51
- 100% {
52
- opacity: 0;
53
- transform: scale3d(0.8,0.8,1) translate3d(0, -8%,0);
54
- }
55
- }
56
- }
57
- ._overflow-tip{
58
- background-color: rgba(0,0,0,.8);
59
- font-size: 14px;
60
- color: #fff;
61
- padding: 5px 10px;
62
- text-align: left;
63
- border-radius: 4px;
64
- margin-top: -1px;
65
- word-break: break-all;
66
- }
1
+ .overflow-tip-wrapper{
2
+ position: fixed;
3
+ z-index: 9999;
4
+ animation-duration: 0.1s;
5
+ animation-fill-mode: both;
6
+ animation-timing-function: ease-out;
7
+ animation-play-state: paused;
8
+ opacity: 0;
9
+ width: 0px;
10
+ &.overflow-tip-show{
11
+ animation-name: tipZoomIn;
12
+ animation-play-state: running;
13
+ }
14
+ &.overflow-tip-hide{
15
+ animation-name: tipZoomOut;
16
+ animation-play-state: running;
17
+ }
18
+ &.tip-arrow-top:before{
19
+ content: '';
20
+ display: block;
21
+ width: 0;
22
+ height: 0;
23
+ border-right: 5px solid transparent;
24
+ border-left: 5px solid transparent;
25
+ border-bottom: 5px solid rgba(0,0,0,.8);
26
+ }
27
+ &.tip-arrow-bottom:after{
28
+ content: '';
29
+ display: block;
30
+ width:0;
31
+ height:0;
32
+ border-right: 5px solid transparent;
33
+ border-left: 5px solid transparent;
34
+ border-top: 5px solid rgba(0,0,0,.8);
35
+ }
36
+ @keyframes tipZoomIn {
37
+ 0% {
38
+ opacity: .7;
39
+ transform: scale3d(0.9,0.9,0.9) translate3d(0,0,0)
40
+ }
41
+ 100% {
42
+ opacity: 1;
43
+ transform: scale3d(1,1,1) translate3d(0,0,0)
44
+ }
45
+ }
46
+ @keyframes tipZoomOut {
47
+ 0% {
48
+ opacity: 1;
49
+ transform: scale3d(1,1,1) translate3d(0,0,0);
50
+ }
51
+ 100% {
52
+ opacity: 0;
53
+ transform: scale3d(0.8,0.8,1) translate3d(0, -8%,0);
54
+ }
55
+ }
56
+ }
57
+ ._overflow-tip{
58
+ background-color: rgba(0,0,0,.8);
59
+ font-size: 14px;
60
+ color: #fff;
61
+ padding: 5px 10px;
62
+ text-align: left;
63
+ border-radius: 4px;
64
+ margin-top: -1px;
65
+ word-break: break-all;
66
+ }
@@ -1 +1 @@
1
- {"version":3,"sources":["tplus-components-touch/components/page/index.js"],"names":["total","currentIndex","previous","next","className","hide"],"mappings":";;;;;;AAAA;;;;AACA;;AACA;;;;kBAEe,gBAA2D;AAAA,MAAxDA,KAAwD,QAAxDA,KAAwD;AAAA,MAAjDC,YAAiD,QAAjDA,YAAiD;AAAA,MAAnCC,QAAmC,QAAnCA,QAAmC;AAAA,MAAzBC,IAAyB,QAAzBA,IAAyB;AAAA,4BAAnBC,SAAmB;AAAA,MAAnBA,SAAmB,kCAAT,EAAS;;AACxEH,iBAAeD,SAAS,CAAT,GAAa,CAAb,GAAiBC,YAAhC;AACA,MAAII,OAAQL,SAAS,CAAT,IAAcA,SAAS,CAAvB,IAA4B,CAACA,KAAzC;AACA,SACEK,OACA,IADA,GAGA;AAAA;AAAA,MAAK,qBAAmBD,SAAxB;AACGH,oBAAgB,CAAhB,GACC,8BAAC,YAAD,IAAO,MAAK,WAAZ,EAAwB,WAAU,4CAAlC,GADD,GAIC,8BAAC,YAAD,IAAO,MAAK,MAAZ,EAAmB,WAAU,wDAA7B,EAAsF,SAASC,QAA/F,GALJ;AAQE;AAAA;AAAA,QAAM,WAAU,WAAhB;AAA4B;AAAA;AAAA;AAAOD;AAAP,OAA5B;AAAA;AAAwD;AAAA;AAAA;AAAOD;AAAP;AAAxD,KARF;AAWIC,oBAAgBD,KAAhB,IAAyBC,gBAAgB,CAAzC,GACE,8BAAC,YAAD,IAAO,MAAK,WAAZ,EAAwB,WAAU,6CAAlC,GADF,GAIE,8BAAC,YAAD,IAAO,MAAK,MAAZ,EAAmB,WAAU,yDAA7B,EAAuF,SAASE,IAAhG;AAfN,GAJF;AAuBD,C","file":"index.js","sourcesContent":["import React from 'react';\nimport { Ticon } from '../../index';\nimport './index.less';\n\nexport default ({ total, currentIndex, previous, next, className='' }) => {\n currentIndex = total == 0 ? 0 : currentIndex;\n let hide = (total == 0 || total == 1 || !total);\n return (\n hide ?\n null\n :\n <div className={`page ${className}`}>\n {currentIndex <= 1 ?\n <Ticon type='zuozhihui' className='page-button page-button-left page-disabled' />\n :\n\n <Ticon type='zuo1' className='page-button page-button-left page-active primary-color' onClick={previous} />\n\n }\n <span className='page-text'><span>{currentIndex}</span>/<span>{total}</span></span>\n\n {\n currentIndex >= total || currentIndex == 0 ?\n <Ticon type='youzhihui' className='page-button page-button-right page-disabled' />\n :\n\n <Ticon type='you1' className='page-button page-button-right page-active primary-color' onClick={next} />\n }\n </div>\n )\n}"]}
1
+ {"version":3,"sources":["tplus-components-touch/components/page/index.js"],"names":["total","currentIndex","previous","next","className","hide"],"mappings":";;;;;;AAAA;;;;AACA;;AACA;;;;kBAEe,gBAA2D;AAAA,MAAxDA,KAAwD,QAAxDA,KAAwD;AAAA,MAAjDC,YAAiD,QAAjDA,YAAiD;AAAA,MAAnCC,QAAmC,QAAnCA,QAAmC;AAAA,MAAzBC,IAAyB,QAAzBA,IAAyB;AAAA,4BAAnBC,SAAmB;AAAA,MAAnBA,SAAmB,kCAAT,EAAS;;AACxEH,iBAAeD,SAAS,CAAT,GAAa,CAAb,GAAiBC,YAAhC;AACA,MAAII,OAAQL,SAAS,CAAT,IAAcA,SAAS,CAAvB,IAA4B,CAACA,KAAzC;AACA,SACEK,OACA,IADA,GAGA;AAAA;AAAA,MAAK,qBAAmBD,SAAxB;AACGH,oBAAgB,CAAhB,GACC,8BAAC,YAAD,IAAO,MAAK,WAAZ,EAAwB,WAAU,4CAAlC,GADD,GAIC,8BAAC,YAAD,IAAO,MAAK,MAAZ,EAAmB,WAAU,wDAA7B,EAAsF,SAASC,QAA/F,GALJ;AAQE;AAAA;AAAA,QAAM,WAAU,WAAhB;AAA4B;AAAA;AAAA;AAAOD;AAAP,OAA5B;AAAA;AAAwD;AAAA;AAAA;AAAOD;AAAP;AAAxD,KARF;AAWIC,oBAAgBD,KAAhB,IAAyBC,gBAAgB,CAAzC,GACE,8BAAC,YAAD,IAAO,MAAK,WAAZ,EAAwB,WAAU,6CAAlC,GADF,GAIE,8BAAC,YAAD,IAAO,MAAK,MAAZ,EAAmB,WAAU,yDAA7B,EAAuF,SAASE,IAAhG;AAfN,GAJF;AAuBD,C","file":"index.js","sourcesContent":["import React from 'react';\r\nimport { Ticon } from '../../index';\r\nimport './index.less';\r\n\r\nexport default ({ total, currentIndex, previous, next, className='' }) => {\r\n currentIndex = total == 0 ? 0 : currentIndex;\r\n let hide = (total == 0 || total == 1 || !total);\r\n return (\r\n hide ?\r\n null\r\n :\r\n <div className={`page ${className}`}>\r\n {currentIndex <= 1 ?\r\n <Ticon type='zuozhihui' className='page-button page-button-left page-disabled' />\r\n :\r\n\r\n <Ticon type='zuo1' className='page-button page-button-left page-active primary-color' onClick={previous} />\r\n\r\n }\r\n <span className='page-text'><span>{currentIndex}</span>/<span>{total}</span></span>\r\n\r\n {\r\n currentIndex >= total || currentIndex == 0 ?\r\n <Ticon type='youzhihui' className='page-button page-button-right page-disabled' />\r\n :\r\n\r\n <Ticon type='you1' className='page-button page-button-right page-active primary-color' onClick={next} />\r\n }\r\n </div>\r\n )\r\n}"]}
@@ -1,22 +1,22 @@
1
-
2
- .page {
3
- .page-button {
4
- font-size: 32px;
5
- display: line-block;
6
- vertical-align: middle;
7
- }
8
- .page-active {
9
- cursor: pointer;
10
- }
11
- .page-disabled {
12
- color: #666666;
13
- cursor: not-allowed;
14
- }
15
- .page-text {
16
- font-size: 14px;
17
- color: rgba(0,0,0,0.65);
18
- display: inline-block;
19
- vertical-align: middle;
20
- padding: 0 32px;
21
- }
1
+
2
+ .page {
3
+ .page-button {
4
+ font-size: 32px;
5
+ display: line-block;
6
+ vertical-align: middle;
7
+ }
8
+ .page-active {
9
+ cursor: pointer;
10
+ }
11
+ .page-disabled {
12
+ color: #666666;
13
+ cursor: not-allowed;
14
+ }
15
+ .page-text {
16
+ font-size: 14px;
17
+ color: rgba(0,0,0,0.65);
18
+ display: inline-block;
19
+ vertical-align: middle;
20
+ padding: 0 32px;
21
+ }
22
22
  }