gaoluyang
2026-06-12 12a52dc0d4cb0c44bf2927942bcbf459c622d9bd
src/views/collaborativeApproval/notificationManagement/meetApplication/index.vue
@@ -84,34 +84,28 @@
        <el-row :gutter="20">
          <el-col :span="12">
            <el-form-item label="开始时间" prop="startTime">
              <el-select
                     <el-time-picker
                  v-model="meetingForm.startTime"
                  placeholder="请选择开始时间"
                        format="HH:mm"
                        value-format="HH:mm"
                        :disabled-hours="disabledStartHours"
                        :disabled-minutes="disabledStartMinutes"
                  style="width: 100%"
              >
                <el-option
                    v-for="time in startTimeOptions"
                    :key="time.value"
                    :label="time.label"
                    :value="time.value"
                />
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="结束时间" prop="endTime">
              <el-select
                     <el-time-picker
                  v-model="meetingForm.endTime"
                  placeholder="请选择结束时间"
                        format="HH:mm"
                        value-format="HH:mm"
                        :disabled-hours="disabledEndHours"
                        :disabled-minutes="disabledEndMinutes"
                  style="width: 100%"
              >
                <el-option
                    v-for="time in endTimeOptions"
                    :key="time.value"
                    :label="time.label"
                    :value="time.value"
                />
              </el-select>
            </el-form-item>
          </el-col>
        </el-row>
@@ -205,9 +199,6 @@
// 员工列表
const employees = ref([])
// 时间选项(以半小时为间隔)
const timeOptions = ref([])
const getTimeInMinutes = (time) => {
  if (!time) return -1
  const [hour, minute] = time.split(':').map(Number)
@@ -226,16 +217,6 @@
    callback()
    return
  }
  if (isToday(meetingForm.meetingDate)) {
    const now = new Date()
    const currentMinutes = now.getHours() * 60 + now.getMinutes()
    if (getTimeInMinutes(value) > currentMinutes) {
      callback(new Error('当天开始时间不能晚于当前时间'))
      return
    }
  }
  callback()
}
@@ -244,16 +225,13 @@
    callback()
    return
  }
  if (getTimeInMinutes(value) <= getTimeInMinutes(meetingForm.startTime)) {
    callback(new Error('结束时间必须大于开始时间'))
    return
  }
  callback()
}
// 表单校验规则
const rules = {
  title: [{required: true, message: '请输入会议主题', trigger: 'blur'}],
  roomId: [{required: true, message: '请选择会议室', trigger: 'change'}],
@@ -270,77 +248,70 @@
  participants: [{required: true, message: '请选择参会人员', trigger: 'change'}]
}
const startTimeOptions = computed(() => {
  if (!isToday(meetingForm.meetingDate)) {
    return timeOptions.value
// 时间选择器禁用逻辑
const disabledStartHours = () => {
   const hours = []
   for (let h = 0; h < 24; h++) {
      if (h < 8 || h > 18) hours.push(h)
  }
   if (isToday(meetingForm.meetingDate)) {
  const now = new Date()
  const currentMinutes = now.getHours() * 60 + now.getMinutes()
  return timeOptions.value.filter(item => getTimeInMinutes(item.value) <= currentMinutes)
})
const endTimeOptions = computed(() => {
  if (!meetingForm.startTime) {
    return timeOptions.value
      for (let h = 8; h < now.getHours(); h++) {
         if (!hours.includes(h)) hours.push(h)
  }
  const startMinutes = getTimeInMinutes(meetingForm.startTime)
  return timeOptions.value.filter(item => getTimeInMinutes(item.value) > startMinutes)
})
   }
   return hours
}
// 初始化时间选项
const initTimeOptions = () => {
  const options = []
const disabledStartMinutes = (hour) => {
   const minutes = []
   for (let m = 0; m < 60; m++) {
      if (m !== 0 && m !== 30) minutes.push(m)
   }
   if (isToday(meetingForm.meetingDate)) {
  const now = new Date()
  const currentHour = now.getHours()
  const currentMinute = now.getMinutes()
  // meetingDate 是 "yyyy-MM-dd"
  const meetingDate = new Date(meetingForm.meetingDate)
  const isSameDay =
    now.getFullYear() === meetingDate.getFullYear() &&
    now.getMonth() === meetingDate.getMonth() &&
    now.getDate() === meetingDate.getDate()
  console.log('是否同一天:', isSameDay)
  for (let hour = 8; hour <= 18; hour++) {
    // 开始时间必须晚于当前时间
    if (hour < currentHour && isSameDay) {
      continue
    }
    if (hour === currentHour && currentMinute > 30 && isSameDay) {
      continue
    }
    // 每个小时添加两个选项:整点和半点
    options.push({
      value: `${hour.toString().padStart(2, '0')}:00`,
      label: `${hour.toString().padStart(2, '0')}:00`
    })
    if (hour < 18) { // 18:00之后没有半点选项
      options.push({
        value: `${hour.toString().padStart(2, '0')}:30`,
        label: `${hour.toString().padStart(2, '0')}:30`
      })
      if (hour === now.getHours()) {
         if (now.getMinutes() >= 30) {
            minutes.push(0)
    }
  }
  timeOptions.value = options
   }
   return minutes
}
watch(() => meetingForm.meetingDate, () => {
  if (meetingForm.startTime && !startTimeOptions.value.some(item => item.value === meetingForm.startTime)) {
    meetingForm.startTime = ''
  }
  if (meetingForm.endTime && !endTimeOptions.value.some(item => item.value === meetingForm.endTime)) {
    meetingForm.endTime = ''
const disabledEndHours = () => {
   const hours = []
   for (let h = 0; h < 24; h++) {
      if (h < 8 || h > 18) hours.push(h)
  }
  if (meetingForm.startTime) {
    meetingFormRef.value?.validateField('startTime')
      const startHour = parseInt(meetingForm.startTime.split(':')[0])
      for (let h = 8; h < startHour; h++) {
         if (!hours.includes(h)) hours.push(h)
  }
  if (meetingForm.endTime) {
    meetingFormRef.value?.validateField('endTime')
  }
  initTimeOptions()
})
   return hours
}
const disabledEndMinutes = (hour) => {
   const minutes = []
   for (let m = 0; m < 60; m++) {
      if (m !== 0 && m !== 30) minutes.push(m)
   }
   if (meetingForm.startTime) {
      const startHour = parseInt(meetingForm.startTime.split(':')[0])
      const startMinute = parseInt(meetingForm.startTime.split(':')[1])
      if (hour === startHour) {
         if (startMinute >= 0) minutes.push(0)
         if (startMinute >= 30) minutes.push(30)
         // only keep minutes > startMinute
         for (let m = 0; m <= startMinute; m++) {
            if (!minutes.includes(m)) minutes.push(m)
         }
      }
   }
   return minutes
}
watch(() => meetingForm.startTime, () => {
  if (meetingForm.endTime && getTimeInMinutes(meetingForm.endTime) <= getTimeInMinutes(meetingForm.startTime)) {
@@ -389,19 +360,6 @@
        // 模拟提交操作
        ElMessage.success(`${getCurrentTypeName()}提交成功`)
        // 根据不同类型执行不同操作
        switch (currentType.value) {
          case 'approval':
            ElMessage.info('会议已提交审批流程')
            break
          case 'department':
            ElMessage.info('部门级会议申请已提交')
            break
          case 'notification':
            ElMessage.info('会议通知已发布')
            break
        }
        resetForm()
      })
@@ -411,7 +369,6 @@
// 页面加载时初始化
onMounted(() => {
  initTimeOptions()
  getRoomEnum().then(res => {
    meetingRooms.value = res.data
  })