index.vue 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. <!-- 预售大厅-我参与的预售-详情 -->
  2. <template>
  3. <app-drawer title="详情" :width="960" v-model:show="show">
  4. <app-table-details title="预售信息" :label-width="140" :data="selectedRow" :cell-props="details1" :column="2">
  5. <!-- 采购保证金比例 -->
  6. <template #marginvalue="{ value }">
  7. {{ parsePercent(value) }}
  8. </template>
  9. <!-- 履约方式 -->
  10. <template #performancetemplateid="{ value }">
  11. <app-performance-rule :item="getPerformanceTemplateById(value)" />
  12. </template>
  13. </app-table-details>
  14. <app-table-details title="钻石参考信息" :label-width="140" :data="selectedRow" :cell-props="details2" :column="2">
  15. <!-- 生产方式 -->
  16. <template #ysproductionmode="{ value }">
  17. {{ handleNumberValue(getYSProductionModeName(value)) }}
  18. </template>
  19. <!-- 图片 -->
  20. <template #pictureurls>
  21. <template v-for="(url, index) in imageUrl" :key="index">
  22. <el-image :src="url" :preview-src-list="imageUrl" fit="cover" />
  23. </template>
  24. </template>
  25. </app-table-details>
  26. </app-drawer>
  27. </template>
  28. <script lang="ts" setup>
  29. import { shallowRef, reactive, PropType, onMounted } from 'vue'
  30. import { getFileUrl, parsePercent, handleNumberValue } from '@/filters'
  31. import { getYSProductionModeName } from '@/constants/presale'
  32. import { performanceStore } from '@/stores'
  33. import AppDrawer from '@pc/components/base/drawer/index.vue'
  34. import AppTableDetails from '@pc/components/base/table-details/index.vue'
  35. import AppPerformanceRule from '@pc/components/modules/performance-rule/index.vue'
  36. const props = defineProps({
  37. selectedRow: {
  38. type: Object as PropType<Ermcp.GZMyTradingPreSellRsp>,
  39. required: true
  40. },
  41. })
  42. const { getPerformanceTemplateById } = performanceStore.actions
  43. const show = shallowRef(true)
  44. const imageUrl = reactive<string[]>([])
  45. const details1 = [
  46. { prop: 'wrstandardname', label: '商品名称:' },
  47. { prop: 'customername', label: '发售方:' },
  48. { prop: 'orderqty', label: '认购数量:' },
  49. { prop: 'tradeprice', label: '预售价格:' },
  50. { prop: 'tradeamount', label: '认购货款:' },
  51. { prop: 'marginvalue', label: '保证金比例:' },
  52. { prop: 'freezemargin', label: '保证金:' },
  53. { prop: 'ordertime', label: '认购时间:' },
  54. { prop: 'performancetemplateid', label: '履约方式:', entireRow: true },
  55. ]
  56. const details2 = [
  57. { prop: 'zscolortypestr', label: '颜色:' },
  58. { prop: 'sizestr', label: '尺寸:' },
  59. { prop: 'zsclaritytypestr', label: '净度:' },
  60. { prop: 'yieldrate', label: '成品率:' },
  61. { prop: 'qtydesc', label: '数量描述:' },
  62. { prop: 'weightdesc', label: '重量描述:' },
  63. { prop: 'ysproductionmode', label: '生产方式:' },
  64. { prop: 'pictureurls', label: '图片:', entireRow: true },
  65. { prop: 'remark', label: '备注:', entireRow: true },
  66. ]
  67. onMounted(() => {
  68. const images = props.selectedRow.pictureurls.split(',')
  69. images.forEach((url) => {
  70. if (url) {
  71. imageUrl.push(getFileUrl(url))
  72. }
  73. })
  74. })
  75. </script>
  76. <style lang="less" scoped>
  77. .el-image {
  78. width: 64px;
  79. height: 64px;
  80. border: 1px solid #ccc;
  81. +.el-image {
  82. margin-left: 10px;
  83. }
  84. }
  85. </style>