tableCell.vue 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. <template>
  2. <uni-collapse class='collapse' accordion ref="collapse" @change="collapseChange" @click.stop>
  3. <uni-collapse-item :key="key">
  4. <template v-slot:title>
  5. <view class="u-font-24 u-flex">
  6. <view style="width: 124rpx;text-align: right;">
  7. <text>{{label+':'}}</text>
  8. </view>
  9. <text style="color: #606266;" class="u-m-l-28">{{$t('app.apply.expandData')}}</text>
  10. </view>
  11. </template>
  12. <view class="collapse-item" v-for="(item,d) in dataList" :key="d">
  13. <view v-if="d<allPageLen" class="item-cell-children">
  14. <view class="item-cell" v-for="(cld,c) in children" :key="c">
  15. <text
  16. class="item-cell-label">{{cld.labelI18nCode ? $t(cld.labelI18nCode, cld.label) : cld.label}}:</text>
  17. <text class="item-cell-content"
  18. v-if="['calculate','inputNumber'].includes(cld.__config__.jnpfKey)">
  19. {{toThousands(item[cld.vModel],cld) }}
  20. </text>
  21. <text class="item-cell-content text-primary"
  22. v-else-if="cld.__config__.jnpfKey === 'relationForm'"
  23. @click.stop="relationFormClick(item,cld)">
  24. {{item[cld.vModel]}}
  25. </text>
  26. <view class="item-cell-content" v-else-if="cld.jnpfKey == 'sign'">
  27. <JnpfSign v-model="item[cld.vModel]" align="left" detailed />
  28. </view>
  29. <view class="item-cell-content" v-else-if="cld.jnpfKey == 'signature'">
  30. <JnpfSignature v-model="item[cld.vModel]" align="left" detailed />
  31. </view>
  32. <view class="item-cell-content" v-else-if="cld.jnpfKey == 'uploadImg'" @click.stop>
  33. <JnpfUploadImg v-model="item[cld.vModel]" detailed simple
  34. v-if="item[cld.vModel]&&item[cld.vModel].length" />
  35. </view>
  36. <!-- #ifndef APP-HARMONY -->
  37. <view class="item-cell-content" v-else-if="cld.jnpfKey == 'uploadFile'" @click.stop>
  38. <JnpfUploadFile v-model="item[cld.vModel]" detailed
  39. v-if="item[cld.vModel]&&item[cld.vModel].length" align="left" />
  40. </view>
  41. <!-- #endif -->
  42. <view class="item-cell-content" v-else-if="cld.jnpfKey == 'rate'">
  43. <JnpfRate v-model="item[cld.vModel]" :max="cld.count" :allowHalf="cld.allowHalf" disabled />
  44. </view>
  45. <view class="item-cell-content item-cell-slider" v-else-if="cld.jnpfKey == 'slider'">
  46. <JnpfSlider v-model="item[cld.vModel]" :min="cld.min" :max="cld.max" :step="cld.step"
  47. disabled />
  48. </view>
  49. <view class="item-cell-content" v-else-if="cld.jnpfKey == 'input'">
  50. <JnpfInput v-model="item[cld.vModel]" detailed showOverflow :useMask="cld.useMask"
  51. :maskConfig="cld.maskConfig" align='left' />
  52. </view>
  53. <text class="item-cell-content" v-else>{{item[cld.vModel]}}</text>
  54. </view>
  55. </view>
  56. </view>
  57. <view class="loadMore" @click.stop="loadMore" v-if="!isAllData&&this.dataList.length>allPageLen">
  58. 加载更多
  59. </view>
  60. </uni-collapse-item>
  61. </uni-collapse>
  62. </template>
  63. <script>
  64. export default {
  65. props: ['childList', 'label', 'children', 'pageLen', 'thousands', 'thousandsField'],
  66. data() {
  67. return {
  68. dataList: [],
  69. isAllData: false,
  70. key: +new Date(),
  71. allPageLen: 3
  72. }
  73. },
  74. watch: {
  75. childList: {
  76. handler(val) {
  77. this.dataList = val || []
  78. this.allPageLen = this.pageLen
  79. this.children.map(o => {
  80. if (o.childLabel.length > 4) o.childLabel = o.childLabel.substring(0, 4)
  81. })
  82. },
  83. immediate: true,
  84. }
  85. },
  86. methods: {
  87. toThousands(val, column) {
  88. if (val) {
  89. let valList = val.toString().split('.')
  90. let num = Number(valList[0])
  91. let newVal = column.thousands ? num.toLocaleString() : num
  92. return valList[1] ? newVal + '.' + valList[1] : newVal
  93. }
  94. },
  95. relationFormClick(item, cld) {
  96. this.$emit('cRelationForm', item, cld)
  97. },
  98. loadMore() {
  99. this.allPageLen = this.childList.length
  100. this.isAllData = true
  101. this.resizeCollapse()
  102. },
  103. collapseChange(e) {
  104. if (!e) {
  105. this.isAllData = false
  106. setTimeout(() => {
  107. this.allPageLen = this.pageLen
  108. }, 500)
  109. }
  110. this.resizeCollapse()
  111. },
  112. resizeCollapse() {
  113. setTimeout(() => {
  114. this.$refs.collapse && this.$refs.collapse.resize()
  115. }, 50)
  116. }
  117. }
  118. }
  119. </script>