5.24
This commit is contained in:
@ -41,6 +41,7 @@ const BiddingDocument: React.FC<BiddingDocumentProps> = (props) => {
|
|||||||
const [docSaveBtn, setDocSaveBtn] = useState<string>("compact");//保存按钮是否展示
|
const [docSaveBtn, setDocSaveBtn] = useState<string>("compact");//保存按钮是否展示
|
||||||
const [UploadList, setUploadList] = useState<any>(); //存upload列表
|
const [UploadList, setUploadList] = useState<any>(); //存upload列表
|
||||||
const [UploadID, setUploadID] = useState<any>("empty"); //upload 业务id
|
const [UploadID, setUploadID] = useState<any>("empty"); //upload 业务id
|
||||||
|
const [docName, setDocName] = useState<string>('');//文件名称格式化
|
||||||
|
|
||||||
const UploadProps: UploadProps = {
|
const UploadProps: UploadProps = {
|
||||||
name: "file",
|
name: "file",
|
||||||
@ -287,7 +288,7 @@ const BiddingDocument: React.FC<BiddingDocumentProps> = (props) => {
|
|||||||
},
|
},
|
||||||
]}
|
]}
|
||||||
>
|
>
|
||||||
<Input maxLength={200} readOnly={editInformation} />
|
<Input maxLength={200} readOnly={editInformation} value={docName} onChange={e => setDocName(trim(e.target.value))} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
|
|
||||||
{//单一来源简化流程
|
{//单一来源简化流程
|
||||||
|
@ -3,6 +3,7 @@ import { Button, Form, Input, Modal, Select, Spin } from 'antd';
|
|||||||
import { PackageInformationProps } from '../data';
|
import { PackageInformationProps } from '../data';
|
||||||
import SelectProcess from './SelectProcess';
|
import SelectProcess from './SelectProcess';
|
||||||
import { getChooseProcess } from '../service';
|
import { getChooseProcess } from '../service';
|
||||||
|
import { trim } from '@/utils/CommonUtils';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 公开比选编辑
|
* 公开比选编辑
|
||||||
@ -45,6 +46,8 @@ const PackageInformationChoose: React.FC<PackageInformationProps> = (props) => {
|
|||||||
const [spinningload, setSpinningload] = useState<boolean>(false);
|
const [spinningload, setSpinningload] = useState<boolean>(false);
|
||||||
//保存loading
|
//保存loading
|
||||||
const [saveLoading, setSaveLoading] = useState<boolean>(false);
|
const [saveLoading, setSaveLoading] = useState<boolean>(false);
|
||||||
|
//名称格式化
|
||||||
|
const [bidSectName, setBidSectName] = useState<string>('');
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (values.status == 0 || values.status == 1) {
|
if (values.status == 0 || values.status == 1) {
|
||||||
setStatus(false);
|
setStatus(false);
|
||||||
@ -256,7 +259,7 @@ const PackageInformationChoose: React.FC<PackageInformationProps> = (props) => {
|
|||||||
label="采购包名称"
|
label="采购包名称"
|
||||||
rules={[{ required: controlDisplay }, { max: 100, message: '最大不能超过100字' }]}
|
rules={[{ required: controlDisplay }, { max: 100, message: '最大不能超过100字' }]}
|
||||||
>
|
>
|
||||||
<Input disabled={!controlDisplay} placeholder="请填写采购包名称" />
|
<Input disabled={!controlDisplay} placeholder="请填写采购包名称" value={bidSectName} onChange={e => setBidSectName(trim(e.target.value))} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
<Form.Item name="bidSectContractPrice" label="标段预算">
|
<Form.Item name="bidSectContractPrice" label="标段预算">
|
||||||
<Input prefix="¥" suffix="元" disabled />
|
<Input prefix="¥" suffix="元" disabled />
|
||||||
|
@ -3,6 +3,7 @@ import { Button, Form, Input, Modal, Select } from 'antd';
|
|||||||
import { PackageInformationProps } from '@/pages/Project/ProjectManage/PackageDivided/data';
|
import { PackageInformationProps } from '@/pages/Project/ProjectManage/PackageDivided/data';
|
||||||
import { getChooseProcess } from '@/pages/Project/ProjectManage/PackageDivided/service';
|
import { getChooseProcess } from '@/pages/Project/ProjectManage/PackageDivided/service';
|
||||||
import SelectProcess from '@/pages/Project/ProjectManage/PackageDivided/components/SelectProcess';
|
import SelectProcess from '@/pages/Project/ProjectManage/PackageDivided/components/SelectProcess';
|
||||||
|
import { trim } from '@/utils/CommonUtils';
|
||||||
/*
|
/*
|
||||||
*
|
*
|
||||||
* 询价编辑
|
* 询价编辑
|
||||||
@ -44,6 +45,8 @@ const PackageInformationEnquiry: React.FC<PackageInformationProps> = (props) =>
|
|||||||
const [spinningload, setSpinningload] = useState<boolean>(false);
|
const [spinningload, setSpinningload] = useState<boolean>(false);
|
||||||
//loading
|
//loading
|
||||||
const [saveLoading, setSaveLoading] = useState<boolean>(false);
|
const [saveLoading, setSaveLoading] = useState<boolean>(false);
|
||||||
|
//名称格式化
|
||||||
|
const [bidSectName, setBidSectName] = useState<string>('');
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (values.status == 1 || values.status == 0) {
|
if (values.status == 1 || values.status == 0) {
|
||||||
setStatus(false);
|
setStatus(false);
|
||||||
@ -157,7 +160,7 @@ const PackageInformationEnquiry: React.FC<PackageInformationProps> = (props) =>
|
|||||||
label="采购包名称"
|
label="采购包名称"
|
||||||
rules={[{ required: controlDisplay }, { max: 100, message: '最大不能超过100字' }]}
|
rules={[{ required: controlDisplay }, { max: 100, message: '最大不能超过100字' }]}
|
||||||
>
|
>
|
||||||
<Input disabled={!controlDisplay} placeholder="请填写采购包名称" />
|
<Input disabled={!controlDisplay} placeholder="请填写采购包名称" value={bidSectName} onChange={e => setBidSectName(trim(e.target.value))} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
<Form.Item
|
<Form.Item
|
||||||
name="evalMethodDict"
|
name="evalMethodDict"
|
||||||
|
@ -3,6 +3,7 @@ import { Button, Form, Input, Modal, Select, Spin } from 'antd';
|
|||||||
import { PackageInformationProps } from '../data';
|
import { PackageInformationProps } from '../data';
|
||||||
import { getChooseProcess } from '../service';
|
import { getChooseProcess } from '../service';
|
||||||
import SelectProcess from './SelectProcess';
|
import SelectProcess from './SelectProcess';
|
||||||
|
import { trim } from '@/utils/CommonUtils';
|
||||||
/**
|
/**
|
||||||
* 邀请招标编辑
|
* 邀请招标编辑
|
||||||
*
|
*
|
||||||
@ -45,6 +46,8 @@ const PackageInformationInvite: React.FC<PackageInformationProps> = (props) => {
|
|||||||
const [spinningload, setSpinningload] = useState<boolean>(false);
|
const [spinningload, setSpinningload] = useState<boolean>(false);
|
||||||
//loading
|
//loading
|
||||||
const [saveLoading, setSaveLoading] = useState<boolean>(false);
|
const [saveLoading, setSaveLoading] = useState<boolean>(false);
|
||||||
|
//名称格式化
|
||||||
|
const [bidSectName, setBidSectName] = useState<string>('');
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (values.status == 0 || values.status == 1) {
|
if (values.status == 0 || values.status == 1) {
|
||||||
setStatus(false);
|
setStatus(false);
|
||||||
@ -185,7 +188,7 @@ const PackageInformationInvite: React.FC<PackageInformationProps> = (props) => {
|
|||||||
label="标段名称"
|
label="标段名称"
|
||||||
rules={[{ required: controlDisplay }, { max: 100, message: '最大不能超过100字' }]}
|
rules={[{ required: controlDisplay }, { max: 100, message: '最大不能超过100字' }]}
|
||||||
>
|
>
|
||||||
<Input disabled={!controlDisplay} placeholder="请填写标段名称" />
|
<Input disabled={!controlDisplay} placeholder="请填写标段名称" value={bidSectName} onChange={e => setBidSectName(trim(e.target.value))} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
<Form.Item name="bidSectContractPrice" label="标段预算">
|
<Form.Item name="bidSectContractPrice" label="标段预算">
|
||||||
<Input prefix="¥" suffix="元" disabled />
|
<Input prefix="¥" suffix="元" disabled />
|
||||||
|
@ -3,6 +3,7 @@ import { Button, Form, Input, Modal, Select, Spin } from 'antd';
|
|||||||
import { PackageInformationProps } from '../data';
|
import { PackageInformationProps } from '../data';
|
||||||
import { getChooseProcess } from '../service';
|
import { getChooseProcess } from '../service';
|
||||||
import SelectProcess from './SelectProcess';
|
import SelectProcess from './SelectProcess';
|
||||||
|
import { trim } from '@/utils/CommonUtils';
|
||||||
/**
|
/**
|
||||||
* 公开招标编辑
|
* 公开招标编辑
|
||||||
*
|
*
|
||||||
@ -46,6 +47,8 @@ const PackageInformationInviteBid: React.FC<PackageInformationProps> = (props) =
|
|||||||
const [spinningload, setSpinningload] = useState<boolean>(false);
|
const [spinningload, setSpinningload] = useState<boolean>(false);
|
||||||
//loading
|
//loading
|
||||||
const [saveLoading, setSaveLoading] = useState<boolean>(false);
|
const [saveLoading, setSaveLoading] = useState<boolean>(false);
|
||||||
|
//名称格式化
|
||||||
|
const [bidSectName, setBidSectName] = useState<string>('');
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (values.status == 1 || values.status == 0) {
|
if (values.status == 1 || values.status == 0) {
|
||||||
setStatus(false);
|
setStatus(false);
|
||||||
@ -266,7 +269,7 @@ const PackageInformationInviteBid: React.FC<PackageInformationProps> = (props) =
|
|||||||
label="标段名称"
|
label="标段名称"
|
||||||
rules={[{ required: controlDisplay }, { max: 100, message: '最大不能超过100字' }]}
|
rules={[{ required: controlDisplay }, { max: 100, message: '最大不能超过100字' }]}
|
||||||
>
|
>
|
||||||
<Input disabled={!controlDisplay} placeholder="请填写标段名称" />
|
<Input disabled={!controlDisplay} placeholder="请填写标段名称" value={bidSectName} onChange={e => setBidSectName(trim(e.target.value))} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
<Form.Item name="bidSectContractPrice" label="标段预算">
|
<Form.Item name="bidSectContractPrice" label="标段预算">
|
||||||
<Input prefix="¥" suffix="元" disabled />
|
<Input prefix="¥" suffix="元" disabled />
|
||||||
|
@ -3,6 +3,7 @@ import { Button, Form, Input, Modal, Select, Spin } from 'antd';
|
|||||||
import { PackageInformationProps } from '../data';
|
import { PackageInformationProps } from '../data';
|
||||||
import { getChooseProcess } from '../service';
|
import { getChooseProcess } from '../service';
|
||||||
import SelectProcess from './SelectProcess';
|
import SelectProcess from './SelectProcess';
|
||||||
|
import { trim } from '@/utils/CommonUtils';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 竞争性谈判编辑
|
* 竞争性谈判编辑
|
||||||
@ -46,7 +47,8 @@ const PackageInformationNegotiate: React.FC<PackageInformationProps> = (props) =
|
|||||||
const [spinningload, setSpinningload] = useState<boolean>(false);
|
const [spinningload, setSpinningload] = useState<boolean>(false);
|
||||||
//保存loading
|
//保存loading
|
||||||
const [saveLoading, setSaveLoading] = useState<boolean>(false);
|
const [saveLoading, setSaveLoading] = useState<boolean>(false);
|
||||||
|
//名称格式化
|
||||||
|
const [bidSectName, setBidSectName] = useState<string>('');
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (values.status == 0 || values.status == 1) {
|
if (values.status == 0 || values.status == 1) {
|
||||||
setStatus(false);
|
setStatus(false);
|
||||||
@ -176,7 +178,7 @@ const PackageInformationNegotiate: React.FC<PackageInformationProps> = (props) =
|
|||||||
label="采购包名称"
|
label="采购包名称"
|
||||||
rules={[{ required: controlDisplay }, { max: 100, message: '最大不能超过100字' }]}
|
rules={[{ required: controlDisplay }, { max: 100, message: '最大不能超过100字' }]}
|
||||||
>
|
>
|
||||||
<Input disabled={!controlDisplay} placeholder="请填写采购包名称" />
|
<Input disabled={!controlDisplay} placeholder="请填写采购包名称" value={bidSectName} onChange={e => setBidSectName(trim(e.target.value))} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
<Form.Item name="bidSectContractPrice" label="采购包预算">
|
<Form.Item name="bidSectContractPrice" label="采购包预算">
|
||||||
<Input prefix="¥" suffix="元" disabled />
|
<Input prefix="¥" suffix="元" disabled />
|
||||||
|
@ -3,6 +3,7 @@ import { Button, Form, Input, Modal, Select, Spin } from 'antd';
|
|||||||
import { PackageInformationProps } from '../data';
|
import { PackageInformationProps } from '../data';
|
||||||
import { getChooseProcess } from '../service';
|
import { getChooseProcess } from '../service';
|
||||||
import SelectProcess from './SelectProcess';
|
import SelectProcess from './SelectProcess';
|
||||||
|
import { trim } from '@/utils/CommonUtils';
|
||||||
/**
|
/**
|
||||||
* 单一来源编辑
|
* 单一来源编辑
|
||||||
*
|
*
|
||||||
@ -43,7 +44,8 @@ const PackageInformationOnly: React.FC<PackageInformationProps> = (props) => {
|
|||||||
const [spinningload, setSpinningload] = useState<boolean>(false);
|
const [spinningload, setSpinningload] = useState<boolean>(false);
|
||||||
//保存loading
|
//保存loading
|
||||||
const [saveLoading, setSaveLoading] = useState<boolean>(false);
|
const [saveLoading, setSaveLoading] = useState<boolean>(false);
|
||||||
|
//名称格式化
|
||||||
|
const [bidSectName, setBidSectName] = useState<string>('');
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (values.status == 0 || values.status == 1) {
|
if (values.status == 0 || values.status == 1) {
|
||||||
setStatus(false);
|
setStatus(false);
|
||||||
@ -144,7 +146,7 @@ const PackageInformationOnly: React.FC<PackageInformationProps> = (props) => {
|
|||||||
<Input disabled />
|
<Input disabled />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
<Form.Item name="bidSectName" label="采购包名称" rules={[{ required: controlDisplay }, { max: 100, message: "最大不能超过100字" }]}>
|
<Form.Item name="bidSectName" label="采购包名称" rules={[{ required: controlDisplay }, { max: 100, message: "最大不能超过100字" }]}>
|
||||||
<Input disabled={!controlDisplay} placeholder="请填写采购包名称" />
|
<Input disabled={!controlDisplay} placeholder="请填写采购包名称" value={bidSectName} onChange={e => setBidSectName(trim(e.target.value))} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
<Form.Item name="bidSectContractPrice" label="采购包预算">
|
<Form.Item name="bidSectContractPrice" label="采购包预算">
|
||||||
<Input prefix="¥" suffix="元" disabled />
|
<Input prefix="¥" suffix="元" disabled />
|
||||||
|
@ -3,6 +3,7 @@ import { Button, Form, Input, Modal, Select, Spin } from 'antd';
|
|||||||
import { PackageInformationProps } from '../data';
|
import { PackageInformationProps } from '../data';
|
||||||
import SelectProcess from './SelectProcess';
|
import SelectProcess from './SelectProcess';
|
||||||
import { getChooseProcess } from '../service';
|
import { getChooseProcess } from '../service';
|
||||||
|
import { trim } from '@/utils/CommonUtils';
|
||||||
/**
|
/**
|
||||||
* 公开招募编辑
|
* 公开招募编辑
|
||||||
*
|
*
|
||||||
@ -45,6 +46,8 @@ const PackageInformationRecruit: React.FC<PackageInformationProps> = (props) =>
|
|||||||
const [spinningload, setSpinningload] = useState<boolean>(false);
|
const [spinningload, setSpinningload] = useState<boolean>(false);
|
||||||
//保存loading
|
//保存loading
|
||||||
const [saveLoading, setSaveLoading] = useState<boolean>(false);
|
const [saveLoading, setSaveLoading] = useState<boolean>(false);
|
||||||
|
//名称格式化
|
||||||
|
const [bidSectName, setBidSectName] = useState<string>('');
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (values.status == 0 || values.status == 1) {
|
if (values.status == 0 || values.status == 1) {
|
||||||
setStatus(false);
|
setStatus(false);
|
||||||
@ -187,7 +190,7 @@ const PackageInformationRecruit: React.FC<PackageInformationProps> = (props) =>
|
|||||||
label="包件名称"
|
label="包件名称"
|
||||||
rules={[{ required: controlDisplay }, { max: 100, message: '最大不能超过100字' }]}
|
rules={[{ required: controlDisplay }, { max: 100, message: '最大不能超过100字' }]}
|
||||||
>
|
>
|
||||||
<Input disabled={!controlDisplay} placeholder="请填写包件名称" />
|
<Input disabled={!controlDisplay} placeholder="请填写包件名称" value={bidSectName} onChange={e => setBidSectName(trim(e.target.value))} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
<Form.Item
|
<Form.Item
|
||||||
name="reviewRules"
|
name="reviewRules"
|
||||||
|
@ -76,6 +76,8 @@ const ProjectDocumentation: React.FC<ProcurementMethodItem> = (props) => {
|
|||||||
const openTenderFormSelect = createSelect(dictData['open_tender_form=record']);
|
const openTenderFormSelect = createSelect(dictData['open_tender_form=record']);
|
||||||
//是否需要供应商ipass解密显隐
|
//是否需要供应商ipass解密显隐
|
||||||
const [isIPassDecode, isIPassDecodeSet] = useState<boolean>(false);
|
const [isIPassDecode, isIPassDecodeSet] = useState<boolean>(false);
|
||||||
|
//项目名称格式化
|
||||||
|
const [projectName, setProjectName] = useState<string>('');
|
||||||
function onChangeIpass(e: any) {//是否使用ipass制作
|
function onChangeIpass(e: any) {//是否使用ipass制作
|
||||||
isIPassDecodeSet(e.target.value === '0');
|
isIPassDecodeSet(e.target.value === '0');
|
||||||
}
|
}
|
||||||
@ -305,7 +307,7 @@ const ProjectDocumentation: React.FC<ProcurementMethodItem> = (props) => {
|
|||||||
name="projectName"
|
name="projectName"
|
||||||
rules={[{ required: true }]}
|
rules={[{ required: true }]}
|
||||||
>
|
>
|
||||||
<Input disabled={whetherReadonly} readOnly={whetherReadonly} maxLength={150} />
|
<Input disabled={whetherReadonly} readOnly={whetherReadonly} maxLength={150} value={projectName} onChange={e => setProjectName(trim(e.target.value))} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
</Col>
|
</Col>
|
||||||
<Col span={12}>
|
<Col span={12}>
|
||||||
|
@ -71,6 +71,8 @@ const ProjectDocumentation: React.FC<ProcurementMethodItem> = (props) => {
|
|||||||
const bidMethodSubDictSelect = createSelect(dictData['bid_method_sub=record']);
|
const bidMethodSubDictSelect = createSelect(dictData['bid_method_sub=record']);
|
||||||
//适用法律
|
//适用法律
|
||||||
const openTenderFormSelect = createSelect(dictData['open_tender_form=record']);
|
const openTenderFormSelect = createSelect(dictData['open_tender_form=record']);
|
||||||
|
//项目名称格式化
|
||||||
|
const [projectName, setProjectName] = useState<string>('');
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
/**
|
/**
|
||||||
* 根据id获取数据
|
* 根据id获取数据
|
||||||
@ -295,7 +297,7 @@ const ProjectDocumentation: React.FC<ProcurementMethodItem> = (props) => {
|
|||||||
name="projectName"
|
name="projectName"
|
||||||
rules={[{ required: true }]}
|
rules={[{ required: true }]}
|
||||||
>
|
>
|
||||||
<Input disabled={whetherReadonly} readOnly={whetherReadonly} maxLength={150} />
|
<Input disabled={whetherReadonly} readOnly={whetherReadonly} maxLength={150} value={projectName} onChange={e => setProjectName(trim(e.target.value))} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
</Col>
|
</Col>
|
||||||
<Col span={12}>
|
<Col span={12}>
|
||||||
|
@ -77,6 +77,8 @@ const ProjectDocumentation: React.FC<ProcurementMethodItem> = (props) => {
|
|||||||
const [noInformationFlag, setNoInformationFlag] = useState<boolean>(String(status) === '0');
|
const [noInformationFlag, setNoInformationFlag] = useState<boolean>(String(status) === '0');
|
||||||
//是否需要供应商ipass解密显隐
|
//是否需要供应商ipass解密显隐
|
||||||
const [isIPassDecode, isIPassDecodeSet] = useState<boolean>(false);
|
const [isIPassDecode, isIPassDecodeSet] = useState<boolean>(false);
|
||||||
|
//项目名称格式化
|
||||||
|
const [projectName, setProjectName] = useState<string>('');
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
/**
|
/**
|
||||||
* 根据id获取数据
|
* 根据id获取数据
|
||||||
@ -308,7 +310,7 @@ const ProjectDocumentation: React.FC<ProcurementMethodItem> = (props) => {
|
|||||||
name="projectName"
|
name="projectName"
|
||||||
rules={[{ required: true }]}
|
rules={[{ required: true }]}
|
||||||
>
|
>
|
||||||
<Input disabled={whetherReadonly} readOnly={whetherReadonly} maxLength={100} />
|
<Input disabled={whetherReadonly} readOnly={whetherReadonly} maxLength={100} value={projectName} onChange={e => setProjectName(trim(e.target.value))} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
</Col>
|
</Col>
|
||||||
<Col span={12}>
|
<Col span={12}>
|
||||||
|
@ -74,6 +74,8 @@ const ProjectDocumentation: React.FC<ProcurementMethodItem> = (props) => {
|
|||||||
const [noInformationFlag, setNoInformationFlag] = useState<boolean>(String(status) === '0');
|
const [noInformationFlag, setNoInformationFlag] = useState<boolean>(String(status) === '0');
|
||||||
//是否需要供应商ipass解密显隐
|
//是否需要供应商ipass解密显隐
|
||||||
const [isIPassDecode, isIPassDecodeSet] = useState<boolean>(false);
|
const [isIPassDecode, isIPassDecodeSet] = useState<boolean>(false);
|
||||||
|
//项目名称格式化
|
||||||
|
const [projectName, setProjectName] = useState<string>('');
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
/**
|
/**
|
||||||
* 根据id获取数据
|
* 根据id获取数据
|
||||||
@ -281,7 +283,7 @@ const ProjectDocumentation: React.FC<ProcurementMethodItem> = (props) => {
|
|||||||
name="projectName"
|
name="projectName"
|
||||||
rules={[{ required: true }]}
|
rules={[{ required: true }]}
|
||||||
>
|
>
|
||||||
<Input disabled={whetherReadonly} readOnly={whetherReadonly} maxLength={100} />
|
<Input disabled={whetherReadonly} readOnly={whetherReadonly} maxLength={100} value={projectName} onChange={e => setProjectName(trim(e.target.value))} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
</Col>
|
</Col>
|
||||||
<Col span={12}>
|
<Col span={12}>
|
||||||
|
@ -73,6 +73,8 @@ const ProjectDocumentation: React.FC<ProcurementMethodItem> = (props) => {
|
|||||||
const [noInformationFlag, setNoInformationFlag] = useState<boolean>(String(status) === '0');
|
const [noInformationFlag, setNoInformationFlag] = useState<boolean>(String(status) === '0');
|
||||||
//是否需要供应商ipass解密显隐
|
//是否需要供应商ipass解密显隐
|
||||||
const [isIPassDecode, isIPassDecodeSet] = useState<boolean>(false);
|
const [isIPassDecode, isIPassDecodeSet] = useState<boolean>(false);
|
||||||
|
//项目名称格式化
|
||||||
|
const [projectName, setProjectName] = useState<string>('');
|
||||||
function onChangeIpass(e: any) {//是否使用ipass制作
|
function onChangeIpass(e: any) {//是否使用ipass制作
|
||||||
isIPassDecodeSet(e.target.value === '0');
|
isIPassDecodeSet(e.target.value === '0');
|
||||||
}
|
}
|
||||||
@ -306,7 +308,7 @@ const ProjectDocumentation: React.FC<ProcurementMethodItem> = (props) => {
|
|||||||
name="projectName"
|
name="projectName"
|
||||||
rules={[{ required: true }]}
|
rules={[{ required: true }]}
|
||||||
>
|
>
|
||||||
<Input disabled={whetherReadonly} readOnly={whetherReadonly} maxLength={150} />
|
<Input disabled={whetherReadonly} readOnly={whetherReadonly} maxLength={150} value={projectName} onChange={e => setProjectName(trim(e.target.value))} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
</Col>
|
</Col>
|
||||||
<Col span={12}>
|
<Col span={12}>
|
||||||
|
@ -71,6 +71,8 @@ const ProjectDocumentation: React.FC<ProcurementMethodItem> = (props) => {
|
|||||||
const [noInformationFlag, setNoInformationFlag] = useState<boolean>(String(status) === '0');
|
const [noInformationFlag, setNoInformationFlag] = useState<boolean>(String(status) === '0');
|
||||||
//是否需要供应商ipass解密显隐
|
//是否需要供应商ipass解密显隐
|
||||||
const [isIPassDecode, isIPassDecodeSet] = useState<boolean>(false);
|
const [isIPassDecode, isIPassDecodeSet] = useState<boolean>(false);
|
||||||
|
//项目名称格式化
|
||||||
|
const [projectName, setProjectName] = useState<string>('');
|
||||||
function onChangeIpass(e: any) {//是否使用ipass制作
|
function onChangeIpass(e: any) {//是否使用ipass制作
|
||||||
isIPassDecodeSet(e.target.value === '0');
|
isIPassDecodeSet(e.target.value === '0');
|
||||||
}
|
}
|
||||||
@ -305,7 +307,7 @@ const ProjectDocumentation: React.FC<ProcurementMethodItem> = (props) => {
|
|||||||
name="projectName"
|
name="projectName"
|
||||||
rules={[{ required: true }]}
|
rules={[{ required: true }]}
|
||||||
>
|
>
|
||||||
<Input disabled={whetherReadonly} readOnly={whetherReadonly} maxLength={150} />
|
<Input disabled={whetherReadonly} readOnly={whetherReadonly} maxLength={150} value={projectName} onChange={e => setProjectName(trim(e.target.value))} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
</Col>
|
</Col>
|
||||||
<Col span={12}>
|
<Col span={12}>
|
||||||
|
@ -71,6 +71,8 @@ import { btnAuthority } from '@/utils/authority';
|
|||||||
const [noInformationFlag, setNoInformationFlag] = useState<boolean>(String(status) === '0');
|
const [noInformationFlag, setNoInformationFlag] = useState<boolean>(String(status) === '0');
|
||||||
//是否需要供应商ipass解密显隐
|
//是否需要供应商ipass解密显隐
|
||||||
const [isIPassDecode, isIPassDecodeSet] = useState<boolean>(false);
|
const [isIPassDecode, isIPassDecodeSet] = useState<boolean>(false);
|
||||||
|
//项目名称格式化
|
||||||
|
const [projectName, setProjectName] = useState<string>('');
|
||||||
function onChangeIpass(e: any) {//是否使用ipass制作
|
function onChangeIpass(e: any) {//是否使用ipass制作
|
||||||
isIPassDecodeSet(e.target.value === '0');
|
isIPassDecodeSet(e.target.value === '0');
|
||||||
}
|
}
|
||||||
@ -305,7 +307,7 @@ import { btnAuthority } from '@/utils/authority';
|
|||||||
name="projectName"
|
name="projectName"
|
||||||
rules={[{ required: true }]}
|
rules={[{ required: true }]}
|
||||||
>
|
>
|
||||||
<Input disabled={whetherReadonly} readOnly={whetherReadonly} maxLength={150} />
|
<Input disabled={whetherReadonly} readOnly={whetherReadonly} maxLength={150} value={projectName} onChange={e => setProjectName(trim(e.target.value))} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
</Col>
|
</Col>
|
||||||
<Col span={12}>
|
<Col span={12}>
|
||||||
|
@ -38,6 +38,7 @@ const BiddingDocument: React.FC<BiddingDocumentProps> = (props) => {
|
|||||||
const [docSaveBtn, setDocSaveBtn] = useState<string>("compact");//保存按钮是否展示
|
const [docSaveBtn, setDocSaveBtn] = useState<string>("compact");//保存按钮是否展示
|
||||||
const [UploadList, setUploadList] = useState<any>(); //存upload列表
|
const [UploadList, setUploadList] = useState<any>(); //存upload列表
|
||||||
const [UploadID, setUploadID] = useState<any>("empty"); //upload 业务id
|
const [UploadID, setUploadID] = useState<any>("empty"); //upload 业务id
|
||||||
|
const [docName, setDocName] = useState<string>('');//文件名称格式化
|
||||||
const UploadProps: UploadProps = {
|
const UploadProps: UploadProps = {
|
||||||
name: "file",
|
name: "file",
|
||||||
disabled: editInformation
|
disabled: editInformation
|
||||||
@ -244,7 +245,7 @@ const BiddingDocument: React.FC<BiddingDocumentProps> = (props) => {
|
|||||||
},
|
},
|
||||||
]}
|
]}
|
||||||
>
|
>
|
||||||
<Input maxLength={200} readOnly={editInformation} />
|
<Input maxLength={200} readOnly={editInformation} value={docName} onChange={e => setDocName(trim(e.target.value))} />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
<Form.Item
|
<Form.Item
|
||||||
label="关联标段"
|
label="关联标段"
|
||||||
|
@ -307,8 +307,11 @@ export const numberToChinese = (num: any) => {
|
|||||||
* @param str
|
* @param str
|
||||||
* @returns
|
* @returns
|
||||||
*/
|
*/
|
||||||
export const trim = (str: string | undefined) => {
|
export const trim = (str: string): string => {
|
||||||
let _str = str?.replace(/(^\s*)|(\s*$)/g, "");
|
if (isNotEmpty(str)) {
|
||||||
_str = _str?.replace(/[<>|\\/??::*""“”\s\r\n\t]/, "");
|
let _str = str.replace(/(^\s*)|(\s*$)/g, "");
|
||||||
|
_str = _str.replace(/[<>|\\/??::*""“”\s\r\n\t]/, "");
|
||||||
return _str;
|
return _str;
|
||||||
}
|
}
|
||||||
|
return '';
|
||||||
|
}
|
Reference in New Issue
Block a user