proposalView.js 1.23 KB
import { mapOrderStatus } from '@/config/constants/orderStatus'

/**
 * 统一获取计划书前端状态。
 *
 * 兼容列表页传入的 `status` 和接口原始返回的 `order_status`,
 * 让页面显隐判断与查看逻辑都走同一套口径。
 */
export const getProposalStatus = (proposal = {}) => {
  if (proposal.status) {
    return proposal.status
  }

  return mapOrderStatus(proposal.order_status)
}

/**
 * 统一提取计划书文件列表。
 *
 * 列表页使用 `proposalFiles`,接口原始对象使用 `proposal_files`,
 * 这里做一次兼容,避免各处重复写字段分支。
 */
export const getProposalFiles = (proposal = {}) => {
  if (Array.isArray(proposal.proposal_files)) {
    return proposal.proposal_files
  }

  if (Array.isArray(proposal.proposalFiles)) {
    return proposal.proposalFiles
  }

  return []
}

/**
 * 统一判断计划书是否可查看。
 *
 * 当前业务规则:
 * - 待处理不可查看
 * - 只要存在文件,除待处理外都允许查看
 */
export const canViewProposal = (proposal = {}) => {
  const status = getProposalStatus(proposal)
  const proposalFiles = getProposalFiles(proposal)

  if (proposalFiles.length === 0) {
    return false
  }

  return status !== 'pending'
}