index.vue 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. <template>
  2. <zj-page-container>
  3. <zj-page-fill class="neibuview">
  4. <zj-form-container ref="formRef" :form-data="orderInfo" :form-attributes="{ size: 'mini' }">
  5. <zj-form-module title="预单信息" label-width="110px" :form-data="orderInfo"
  6. :form-items="serviceInfo"></zj-form-module>
  7. <zj-form-module title="已选工单" label-width="100px" :form-data="orderInfo"
  8. :form-items="selectedItems"></zj-form-module>
  9. </zj-form-container>
  10. </zj-page-fill>
  11. <!-- 操作按钮 -->
  12. <div>
  13. <div style="box-sizing: border-box;padding: 16px;text-align:right;">
  14. <el-button size="mini" @click="$emit('close')">
  15. 取消
  16. </el-button>
  17. <el-button type="primary" size="mini" @click="allVerify">
  18. 确定
  19. </el-button>
  20. </div>
  21. </div>
  22. </zj-page-container>
  23. </template>
  24. <script>
  25. import showRecordSelected from "../mixins/showRecordSelected.js"
  26. import { required } from '@/components/template/rules_verify.js'
  27. import { changeOrderChangeAppointmentTime } from "@/api/workOrderPool.js"
  28. import { addHours } from "@/utils/common.js"
  29. export default {
  30. mixins: [
  31. showRecordSelected
  32. ],
  33. data() {
  34. return {
  35. orderInfo: {
  36. appointmentTime: "",
  37. recordSelected: []
  38. }
  39. }
  40. },
  41. computed: {
  42. serviceInfo() {
  43. return [
  44. {
  45. isShow: this.formOptions.appointmentTime.isShow,
  46. name: 'el-date-picker',
  47. md: 8,
  48. attributes: {
  49. disabled: !this.formOptions.appointmentTime.isEdit,
  50. style: { width: '100%' },
  51. placeholder: '请选择',
  52. 'value-format': 'yyyy-MM-dd HH:mm:ss',
  53. },
  54. formItemAttributes: {
  55. label: '预约上门日期',
  56. prop: 'appointmentTime',
  57. rules: this.formOptions.appointmentTime.isRules
  58. }
  59. },
  60. ]
  61. },
  62. formOptions() {
  63. return {
  64. appointmentTime: {
  65. isEdit: true,
  66. isShow: true,
  67. isRules: [...required]
  68. },
  69. }
  70. },
  71. },
  72. methods: {
  73. allVerify() {
  74. this.$refs.formRef.validate((valid, invalidFields, errLabels) => {
  75. changeOrderChangeAppointmentTime({
  76. ids: this.orderInfo.recordSelected.map(item => item.id),
  77. appointmentTime: this.orderInfo.appointmentTime,
  78. appointmentEndTime: this.orderInfo.appointmentTime
  79. }).then(res => {
  80. this.$message({
  81. type: 'success',
  82. message: '约单成功!'
  83. })
  84. this.$emit("close")
  85. })
  86. })
  87. },
  88. }
  89. }
  90. </script>
  91. <style lang="scss" scoped>
  92. .neibuview {
  93. box-sizing: border-box;
  94. padding-left: 16px;
  95. ::v-deep & > .zj-page-fill-scroll {
  96. box-sizing: border-box;
  97. padding-right: 16px;
  98. &>div:nth-child(1) {
  99. margin-top: 20px;
  100. }
  101. }
  102. }
  103. </style>