公告结构化

This commit is contained in:
jlzhangyx5
2025-06-12 16:41:54 +08:00
parent 8ad07c0ecd
commit 4c5c02fa12

View File

@ -35,6 +35,8 @@ interface DataItem {
} }
const BiddingAnnouncementList: React.FC<{}> = (props) => { const BiddingAnnouncementList: React.FC<{}> = (props) => {
const [Refresh, setRefresh] = useState<any>(Math.random); const [Refresh, setRefresh] = useState<any>(Math.random);
@ -62,12 +64,18 @@ const BiddingAnnouncementList: React.FC<{}> = (props) => {
const [approvalViewVisible, setApprovalViewVisible] = useState<boolean>(false);//查看审批流程弹窗 const [approvalViewVisible, setApprovalViewVisible] = useState<boolean>(false);//查看审批流程弹窗
const [approvalViewUrl, setApprovalViewUrl] = useState<string>("");//查看审批流程参数-url const [approvalViewUrl, setApprovalViewUrl] = useState<string>("");//查看审批流程参数-url
const [annoPreviewVisible, setAnnoPreviewVisible] = useState<boolean>(false);//公告结构化预览
const [annoContent, setAnnoContent] = useState<string>("");//公告正文
const modalHeight = window.innerHeight * 96 / 100;
let name1 = "中标"; let name1 = "中标";
let name2 = "评标"; let name2 = "评标";
let name3 = "开标"; let name3 = "开标";
let name4 = "标段"; let name4 = "标段";
let proName = ""; let proName = "";
let proDict = getProMethod(); let proDict = getProMethod();
const proOpenTenderForm = getProOpenTenderForm();
let defId = getDefId(); let defId = getDefId();
if (proDict == "procurement_mode_1" || proDict == "procurement_mode_2") { if (proDict == "procurement_mode_1" || proDict == "procurement_mode_2") {
proName = "招标"; proName = "招标";
@ -177,7 +185,7 @@ const BiddingAnnouncementList: React.FC<{}> = (props) => {
); );
let btn3 = ( let btn3 = (
<> <>
<Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="text" disabled={pageloading} onClick={() => handleRelease(record)}></Button> <Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="text" disabled={pageloading} onClick={() => sensitiveWordConfirm(() => handleRelease(record))}></Button>
<Button type="text" onClick={() => toRead(record)}></Button> <Button type="text" onClick={() => toRead(record)}></Button>
<Button type="text" key="9" onClick={() => toApprovalFor(record)} hidden={!checkObjectId(record.id)}> <Button type="text" key="9" onClick={() => toApprovalFor(record)} hidden={!checkObjectId(record.id)}>
@ -208,7 +216,7 @@ const BiddingAnnouncementList: React.FC<{}> = (props) => {
); );
let btn6 = ( let btn6 = (
<> <>
<Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="text" disabled={pageloading} onClick={() => handleRelease(record)}></Button> <Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="text" disabled={pageloading} onClick={() => sensitiveWordConfirm(() => handleRelease(record))}></Button>
<Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="text" disabled={pageloading} onClick={() => handleReleaseOffline(record)}>线</Button> <Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="text" disabled={pageloading} onClick={() => handleReleaseOffline(record)}>线</Button>
<Button type="text" onClick={() => toRead(record)}></Button> <Button type="text" onClick={() => toRead(record)}></Button>
<Button type="text" key="9" onClick={() => toApprovalFor(record)} hidden={!checkObjectId(record.id)}> <Button type="text" key="9" onClick={() => toApprovalFor(record)} hidden={!checkObjectId(record.id)}>
@ -218,9 +226,79 @@ const BiddingAnnouncementList: React.FC<{}> = (props) => {
</> </>
); );
let jghbtn = (
<>
<Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="text" onClick={() => annoStrucPreview(record)}></Button>
<Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase']) || !record?.structuralFileId} type="text" onClick={() => downloadFileObjectId(record.structuralFileId)}></Button>
</>
);
let updatebtn = (
<>
<Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="text" onClick={() => editAnnoStruc(record.id, false)}></Button>
</>
);
let viewbtn = (
<>
<Button type="text" onClick={() => editAnnoStruc(record.id, true)}></Button>
</>
);
let delbtn = (
<>
<Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="text" onClick={() => handleRemove(record)}></Button>
</>
);
let releasebtn = (
<>
<Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="text" disabled={pageloading} onClick={() => sensitiveWordConfirm(() => handleRelease(record))}></Button>
</>
);
let approvalbtn = (
<>
<Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="text" disabled={pageloading} onClick={() => handleApproval(record)}></Button>
</>
);
let approvalviewbtn = (
<>
<Button type="text" key="9" onClick={() => toApprovalFor(record)} hidden={!checkObjectId(record.id)}> </Button>
</>
);
let changebtn = (
<>
<Button type="text" onClick={() => toChange(record)}></Button>
</>
);
let releaseOfflinebtn = (
<>
<Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="text" disabled={pageloading} onClick={() => handleReleaseOffline(record)}>线</Button>
</>
);
let hasCtpspbtn = (
<>
<Button hidden={isEmpty(record.hasCtpsp) || !record.hasCtpsp} type="text" key="common" onClick={() => window.open('/PublicPlatform' + '?id=' + record.id)}></Button>
</>
);
/*if(true){ /*if(true){
return btn3; return btn3;
}else*/ }else*/
if (proDict == "procurement_mode_1" && proOpenTenderForm === "open_tender_form_1" && record?.structuralFileId) {
if (record.status == 1) {
return [updatebtn, jghbtn, approvalbtn, hasCtpspbtn, delbtn];
} else if (record.status == 2) {
return [viewbtn, jghbtn, approvalviewbtn, hasCtpspbtn];
} else if (record.status == 3) {
return [releasebtn, viewbtn, jghbtn, approvalviewbtn, hasCtpspbtn];
} else if (record.status == 4) {
return [updatebtn, jghbtn, approvalbtn, approvalviewbtn, hasCtpspbtn, delbtn];
} else if (record.status == 5) {
return [viewbtn, jghbtn, approvalviewbtn, hasCtpspbtn, changebtn];
} else if (record.status == 6) {
return [releasebtn, releaseOfflinebtn, viewbtn, jghbtn, approvalviewbtn, hasCtpspbtn];
} else if (record.status == 9) {
return [viewbtn, jghbtn, approvalviewbtn, hasCtpspbtn];
} else {
return (<></>)
}
} else {
if (record.status == 1) { if (record.status == 1) {
return btn1; return btn1;
} else if (record.status == 2) { } else if (record.status == 2) {
@ -238,6 +316,7 @@ const BiddingAnnouncementList: React.FC<{}> = (props) => {
} else { } else {
return (<></>) return (<></>)
} }
}
}, },
@ -297,7 +376,7 @@ const BiddingAnnouncementList: React.FC<{}> = (props) => {
); );
let btn3 = ( let btn3 = (
<> <>
<Button type="text" hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} disabled={pageloading} onClick={() => handleRelease(record)}></Button> <Button type="text" hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} disabled={pageloading} onClick={() => sensitiveWordConfirm(() => handleRelease(record))}></Button>
<Button type="text" onClick={() => toRead(record)}></Button> <Button type="text" onClick={() => toRead(record)}></Button>
<Button type="text" key="9" onClick={() => toApprovalFor(record)} hidden={!checkObjectId(record.id)}> <Button type="text" key="9" onClick={() => toApprovalFor(record)} hidden={!checkObjectId(record.id)}>
@ -327,7 +406,7 @@ const BiddingAnnouncementList: React.FC<{}> = (props) => {
); );
let btn6 = ( let btn6 = (
<> <>
<Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="text" disabled={pageloading} onClick={() => handleRelease(record)}></Button> <Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="text" disabled={pageloading} onClick={() => sensitiveWordConfirm(() => handleRelease(record))}></Button>
<Button type="text" onClick={() => toRead(record)}></Button> <Button type="text" onClick={() => toRead(record)}></Button>
<Button type="text" key="9" onClick={() => toApprovalFor(record)} hidden={!checkObjectId(record.id)}> <Button type="text" key="9" onClick={() => toApprovalFor(record)} hidden={!checkObjectId(record.id)}>
@ -596,6 +675,25 @@ const BiddingAnnouncementList: React.FC<{}> = (props) => {
setPageloading(false); setPageloading(false);
}) })
}; };
//公告审批单&变更公告审批单
const toApprovalFor = async (record: any) => {
// await getApprovalFor(record.id).then(res => {
// if (res?.code == 200 || res?.success == true) {
// const data = res?.data;
// let durl = /http:\/\/([^\/]+)\//i;
// let d = data?.replace(durl, '/');
// setApprovalViewUrl(d);
// setApprovalViewVisible(true);
// }
// })
if (record.approvalInstanceId) {
setRecordData(record);
setApprovalViewVisible(true);
} else {
message.error("无法获取审批流程信息,请检查您的操作或联系管理员。");
}
}
//招标公告结构化 //招标公告结构化
const addAnnoStruc = async (annoId: any, editStatus: boolean) => { const addAnnoStruc = async (annoId: any, editStatus: boolean) => {
spinSet(true); spinSet(true);
@ -628,20 +726,22 @@ const BiddingAnnouncementList: React.FC<{}> = (props) => {
}) })
spinSet(false); spinSet(false);
} }
//公告审批单&变更公告审批单 //招标公告结构化
const toApprovalFor = async (record: any) => { const editAnnoStruc = (annoId: any, editStatus: boolean) => {
await getApprovalFor(record.id).then(res => { history.push({
if (res?.code == 200 || res?.success == true) { pathname: '/biddingAnnouncement/BiddingAnnoStructureForm',
const data = res?.data; state: {
let durl = /http:\/\/([^\/]+)\//i; projectId: tpId,
let d = data?.replace(durl, '/'); annoId: annoId ? annoId : undefined,
setApprovalViewUrl(d); editStatus: editStatus
setApprovalViewVisible(true);
} }
}) });
}
/*预览招标公告*/
const annoStrucPreview = (props: any) => {
setAnnoPreviewVisible(true);
setAnnoContent(props?.contentWithStyle);
} }
return ( return (
<div style={{ padding: '0px 24px' }}> <div style={{ padding: '0px 24px' }}>
<Spin spinning={spin}> <Spin spinning={spin}>
@ -650,8 +750,8 @@ const BiddingAnnouncementList: React.FC<{}> = (props) => {
loading={pageloading} loading={pageloading}
toolBarRender={() => [ toolBarRender={() => [
(defId === 'bid_qualification') && (defId === 'bid_qualification') &&
<Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase']) } type="primary" onClick={() => addAnnoStruc(null, false)}></Button>,
<Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="primary" onClick={() => history.push('/ProjectLayout/NoticeFileStruct')}></Button>, <Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="primary" onClick={() => history.push('/ProjectLayout/NoticeFileStruct')}></Button>,
<Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase']) || proDict !== "procurement_mode_1" || proOpenTenderForm !== "open_tender_form_1"} type="primary" onClick={() => addAnnoStruc(null, false)}></Button>,
<Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="primary" onClick={() => toEditAdd([])}>{proName}</Button>, <Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} type="primary" onClick={() => toEditAdd([])}>{proName}</Button>,
<Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} onClick={() => { <Button hidden={btnAuthority(['ebtp-agency-project-manager', 'ebtp-purchase'])} onClick={() => {
handleRemoveMore() handleRemoveMore()
@ -704,6 +804,22 @@ const BiddingAnnouncementList: React.FC<{}> = (props) => {
/> />
</Modal> </Modal>
) : null} ) : null}
{annoPreviewVisible ? (
<Modal
destroyOnClose
title={"公告预览"}
visible={annoPreviewVisible}
width={1000}
centered
closable={false}
bodyStyle={{ maxHeight: modalHeight - 107, overflowY: 'auto', }}
footer={[<Button onClick={() => { setAnnoPreviewVisible(false); setAnnoContent("") }}> </Button>]}
>
<div style={{ border: '1px solid #c9d8db', overflowX: 'auto' }} className='content-div'>
<div dangerouslySetInnerHTML={{ __html: annoContent }}></div>
</div>
</Modal>
) : null}
{updateVisible ? ( {updateVisible ? (
<BiddingAnnouncement SX={() => setRefresh(Math.random() + 1)} titleName={updateChange} <BiddingAnnouncement SX={() => setRefresh(Math.random() + 1)} titleName={updateChange}
pkId={pkId} type={type} tpId={tpId} pkId={pkId} type={type} tpId={tpId}
@ -729,7 +845,7 @@ const BiddingAnnouncementList: React.FC<{}> = (props) => {
} }
}} data={approvalData} annoId={recordData?.id} /> }} data={approvalData} annoId={recordData?.id} />
) : null} ) : null}
<ApprovalModal modalVisible={approvalViewVisible} onCancel={() => { setApprovalViewVisible(false) }} url={approvalViewUrl} /> <ApprovalModal modalVisible={approvalViewVisible} onCancel={() => { setApprovalViewVisible(false); setRecordData({}) }} record={recordData} />
</Spin> </Spin>
</div> </div>
) )