TransportForm.vue 4.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. <template>
  2. <div class="business-form">
  3. <el-form-item label="接送模式">
  4. <el-radio-group v-model="transportData.subType" size="large" @change="$emit('change', 'transport')">
  5. <el-radio-button label="round">往返接送</el-radio-button>
  6. <el-radio-button label="pick">单程接 (到店)</el-radio-button>
  7. <el-radio-button label="drop">单程送 (回家)</el-radio-button>
  8. </el-radio-group>
  9. </el-form-item>
  10. <div class="route-box">
  11. <!-- 接宠段 -->
  12. <div class="route-segment" v-if="['round', 'pick'].includes(transportData.subType)">
  13. <div class="seg-badge start">接</div>
  14. <div class="seg-content">
  15. <el-row :gutter="10">
  16. <el-col :span="8">
  17. <el-cascader v-model="transportData.pickRegion" :options="pcaOptions" placeholder="省/市/区" style="width: 100%" />
  18. </el-col>
  19. <el-col :span="16">
  20. <el-input v-model="transportData.pickDetail" placeholder="详细地址 (街道/门牌号)" prefix-icon="Location" />
  21. </el-col>
  22. </el-row>
  23. <el-row :gutter="10">
  24. <el-col :span="12"><el-input v-model="transportData.pickContact" placeholder="联系人" /></el-col>
  25. <el-col :span="12"><el-input v-model="transportData.pickPhone" placeholder="电话" /></el-col>
  26. </el-row>
  27. <el-row :gutter="10">
  28. <el-col :span="24">
  29. <el-date-picker v-model="transportData.pickTime" type="datetime" placeholder="选择接宠时间" style="width: 100%" />
  30. </el-col>
  31. </el-row>
  32. </div>
  33. </div>
  34. <!-- 门店中转标识 -->
  35. <div class="route-connector">
  36. <div class="line"></div>
  37. <div class="store-node"><el-icon><Shop /></el-icon> 服务门店</div>
  38. <div class="line"></div>
  39. </div>
  40. <!-- 送回段 -->
  41. <div class="route-segment" v-if="['round', 'drop'].includes(transportData.subType)">
  42. <div class="seg-badge end">送</div>
  43. <div class="seg-content">
  44. <el-row :gutter="10">
  45. <el-col :span="8">
  46. <el-cascader v-model="transportData.dropRegion" :options="pcaOptions" placeholder="省/市/区" style="width: 100%" />
  47. </el-col>
  48. <el-col :span="16">
  49. <el-input v-model="transportData.dropDetail" placeholder="详细地址" prefix-icon="Location" />
  50. </el-col>
  51. </el-row>
  52. <el-row :gutter="10">
  53. <el-col :span="12"><el-input v-model="transportData.dropContact" placeholder="联系人" /></el-col>
  54. <el-col :span="12"><el-input v-model="transportData.dropPhone" placeholder="电话" /></el-col>
  55. </el-row>
  56. <el-row :gutter="10">
  57. <el-col :span="24">
  58. <el-date-picker v-model="transportData.dropTime" type="datetime" placeholder="预计送回时间 (可选)" style="width: 100%" />
  59. </el-col>
  60. </el-row>
  61. </div>
  62. </div>
  63. </div>
  64. </div>
  65. </template>
  66. <script setup>
  67. import { defineProps, defineEmits } from 'vue'
  68. const props = defineProps({
  69. transportData: { type: Object, required: true },
  70. pcaOptions: { type: Array, default: () => [] }
  71. })
  72. const emit = defineEmits(['change'])
  73. </script>
  74. <style scoped>
  75. .business-form { padding-top: 5px; }
  76. .route-box { background: #f9f9f9; padding: 20px; border-radius: 8px; border: 1px solid #EBEEF5; }
  77. .route-segment { display: flex; gap: 15px; }
  78. .seg-badge {
  79. width: 32px; height: 32px; background: #409eff; color: white; border-radius: 8px;
  80. text-align: center; line-height: 32px; font-weight: bold; flex-shrink: 0;
  81. }
  82. .seg-badge.end { background: #67c23a; }
  83. .seg-content { flex: 1; display: flex; flex-direction: column; gap: 10px; }
  84. .route-connector { display: flex; align-items: center; justify-content: center; margin: 15px 0; gap: 10px; color: #909399; font-size: 12px; }
  85. .route-connector .line { height: 1px; width: 80px; background: #dcdfe6; }
  86. .route-connector .store-node { background: white; padding: 4px 12px; border-radius: 20px; border: 1px solid #dcdfe6; display: flex; align-items: center; gap: 5px; }
  87. </style>