ProjectFme.pas 40 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316
  1. unit ProjectFme;
  2. interface
  3. uses
  4. BillsCompileFme, BillsMeasureFme, PhaseCompareFme, DealPaymentFme,
  5. BillsGatherFme, ZJJLFme, BGLFme, ReportsFrm, SearchFme, BookmarkFme,
  6. ProjectData, UtilMethods, Globals, mEncryptEditions, DealBillsFme,
  7. Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  8. Dialogs, ImgList, XPMenu, Buttons, ComCtrls, ToolWin, ExtCtrls, JimPages,
  9. StdCtrls, JimCombos, dxsbar, ActnList, dxBar, OrderCheckerFme, CheckerFme,
  10. CslButton, UpFileManageFrame, UpFileManageUnit;
  11. type
  12. TProjectFrame = class(TFrame)
  13. xpm: TXPMenu;
  14. ilstExpend: TImageList;
  15. pnlViewControl: TPanel;
  16. pnlView: TPanel;
  17. pnlToolBar: TPanel;
  18. tbToolsButton: TToolBar;
  19. tobtnStandardBills: TToolButton;
  20. tobtnDealPayment: TToolButton;
  21. tobtnSearch: TToolButton;
  22. sbtnExpend: TSpeedButton;
  23. tbXmjBills: TToolBar;
  24. tbExpand: TToolButton;
  25. tbSeparator: TToolButton;
  26. sprAssistant: TSplitter;
  27. jpsAssistant: TJimPages;
  28. jpsAssistantDealPayment: TJimPage;
  29. jpsAssistantSearch: TJimPage;
  30. dxsbViewControl: TdxSideBar;
  31. dxsbsViewControl: TdxSideBarStore;
  32. xbiBillsCompile: TdxStoredSideItem;
  33. jpsAssistantStandardBills: TJimPage;
  34. jpsMain: TJimPages;
  35. jpsMainBillsMeasure: TJimPage;
  36. xbiBillsGather: TdxStoredSideItem;
  37. jpsMainBillsGather: TJimPage;
  38. ilstLarge: TImageList;
  39. ilstSmall: TImageList;
  40. xbiStageCompare: TdxStoredSideItem;
  41. xbiCompleteDegree: TdxStoredSideItem;
  42. xbiReport: TdxStoredSideItem;
  43. jpsMainStageCompare: TJimPage;
  44. tobtnZJJL: TToolButton;
  45. tobtnBGL: TToolButton;
  46. jpsAssistantZJJL: TJimPage;
  47. jpsAssistantBGL: TJimPage;
  48. dxpmExpandBills: TdxBarPopupMenu;
  49. alProject: TActionList;
  50. actnFirstLevel: TAction;
  51. actnSecondLevel: TAction;
  52. actnThirdLevel: TAction;
  53. actnFourthLevel: TAction;
  54. actnFifthLevel: TAction;
  55. actnAllLevel: TAction;
  56. actnAllXmj: TAction;
  57. xbiBillsMeasure: TdxStoredSideItem;
  58. jpsMainBillsCompile: TJimPage;
  59. pnlPhaseSelect: TPanel;
  60. jcbAudit: TJimComboBox;
  61. jcbPhase: TJimComboBox;
  62. tobtnShowChecker: TToolButton;
  63. jpsAssistantChecker: TJimPage;
  64. btnSubmit: TCslButton;
  65. btnPass: TCslButton;
  66. btnNotPass: TCslButton;
  67. pnlNewPhase: TPanel;
  68. btnNewPhase: TCslButton;
  69. pnlProjectCheckStatus: TPanel;
  70. actnCurPhase: TAction;
  71. tobtnBookmark: TToolButton;
  72. jpsAssistantBookmark: TJimPage;
  73. jpsAssistantUpFile: TJimPage;
  74. tobtnUpFile: TToolButton;
  75. jpsAssistantDealBills: TJimPage;
  76. tobtnDealBills: TToolButton;
  77. procedure tobtnStandardBillsClick(Sender: TObject);
  78. procedure jcbPhaseChanged(Sender: TObject);
  79. procedure sbtnExpendClick(Sender: TObject);
  80. procedure jcbAuditChanged(Sender: TObject);
  81. procedure dxsbViewControlItemClick(Sender: TObject;
  82. Item: TdxSideBarItem);
  83. procedure dxpmExpandBillsPopup(Sender: TObject);
  84. procedure actnFirstLevelExecute(Sender: TObject);
  85. procedure tbExpandClick(Sender: TObject);
  86. procedure actnAllXmjExecute(Sender: TObject);
  87. procedure btnSubmitClick(Sender: TObject);
  88. procedure btnPassClick(Sender: TObject);
  89. procedure btnNotPassClick(Sender: TObject);
  90. procedure btnNewPhaseClick(Sender: TObject);
  91. procedure actnCurPhaseExecute(Sender: TObject);
  92. procedure tobtnUpFileClick(Sender: TObject);
  93. procedure jpsAssistantActivePageChanged(Sender: TObject);
  94. private
  95. FProjectData: TProjectData;
  96. FBillsCompileFrame: TBillsCompileFrame;
  97. FBillsMeasureFrame: TBillsMeasureFrame;
  98. FPhaseCompareFrame: TPhaseCompareFrame;
  99. FBillsGatherFrame: TBillsGatherFrame;
  100. FCheckerFrame: TCheckerFrame;
  101. FDealPaymentFrame: TDealPaymentFrame;
  102. FZJJLFrame: TZJJLFrame;
  103. FBGLFrame: TBGLFrame;
  104. FSearchFrame: TSearchFrame;
  105. FBookmarkFrame: TBookmarkFrame;
  106. FUpFileManageView: TUpFileManageView;
  107. FDealBillsFrame: TDealBillsFrame;
  108. procedure CreateBillsFrame;
  109. procedure CreateDealPaymentFrame;
  110. procedure CreateBillsGatherFrame;
  111. procedure CreateCheckerFrame;
  112. procedure CreateUpFile;
  113. procedure CreateFrames;
  114. procedure InitialForVersions;
  115. procedure OpenCompare;
  116. procedure CloseCompare;
  117. // 刷新各界面只读、显示等
  118. procedure RefreshProjectState;
  119. procedure AdjustFramesDisplay;
  120. procedure SaveLog(AStr: string);
  121. procedure ExpandNodeTo(ALevel: Integer);
  122. procedure ExpandAllXmj;
  123. procedure ExpandCurPhase;
  124. procedure SetAssistantViewVisible(AVisible: Boolean);
  125. procedure SetImageOfsbtnExpend(AExpend: Boolean);
  126. procedure ControlAssistantButtonsDown(ATag: Integer);
  127. procedure ExpandBookmarkFrame(AExpandFrame: Boolean);
  128. procedure UpToWeb(ACheckPassed: Boolean);
  129. function CheckersHint: string;
  130. procedure SetUpFileManageView(const Value: TUpFileManageView);
  131. procedure CheckUpFile;
  132. public
  133. constructor Create(AProjectData: TProjectData);
  134. destructor Destroy; override;
  135. procedure ResetAssistantView;
  136. procedure GeneratePhaseChooseList;
  137. procedure GenerateStageChooseList;
  138. procedure CreateNewPhase;
  139. procedure CreateNewAudit;
  140. procedure RefreshColumnDisplay;
  141. procedure UnLockData;
  142. procedure ReLockData;
  143. function IsUped: Boolean;
  144. procedure ButtonControl_UpToWeb;
  145. procedure ButtonControl_NewPhase;
  146. procedure RepairAudits;
  147. function CheckFileAndCloudChekerList: Boolean;
  148. property ProjectData: TProjectData read FProjectData;
  149. property BillsCompileFrame: TBillsCompileFrame read FBillsCompileFrame;
  150. property BillsMeasureFrame: TBillsMeasureFrame read FBillsMeasureFrame;
  151. property BillsGatherFrame: TBillsGatherFrame read FBillsGatherFrame;
  152. property CheckerFrame: TCheckerFrame read FCheckerFrame;
  153. property UpFileManageView: TUpFileManageView read FUpFileManageView write SetUpFileManageView;
  154. property DealPaymentFrame: TDealPaymentFrame read FDealPaymentFrame;
  155. property ZJJLFrame: TZJJLFrame read FZJJLFrame;
  156. property BGLFrame: TBGLFrame read FBGLFrame;
  157. property SearchFrame: TSearchFrame read FSearchFrame;
  158. property BookmarkFrame: TBookmarkFrame read FBookmarkFrame;
  159. property DealBillsFrame: TDealBillsFrame read FDealBillsFrame;
  160. end;
  161. implementation
  162. uses
  163. PhaseData, BGLDm, MainFrm, ZhAPI, SearchDm, PHPWebDm, ActiveX,
  164. ConstUnit, MD5Unit, sdIDTree, sdDB, mProgressFrm, ConditionalDefines,
  165. ProjectCommands, ProjectProperty, CheckerMemoFrm, BillsMeasureDm,
  166. ProgressHintFrm;
  167. {$R *.dfm}
  168. { TProjectFrame }
  169. procedure TProjectFrame.AdjustFramesDisplay;
  170. begin
  171. jpsAssistant.Width := 395;
  172. SetAssistantViewVisible(False);
  173. end;
  174. procedure TProjectFrame.ControlAssistantButtonsDown(ATag: Integer);
  175. begin
  176. tobtnStandardBills.Down := ATag = tobtnStandardBills.Tag;
  177. tobtnDealPayment.Down := ATag = tobtnDealPayment.Tag;
  178. tobtnSearch.Down := ATag = tobtnSearch.Tag;
  179. tobtnZJJL.Down := ATag = tobtnZJJL.Tag;
  180. tobtnBGL.Down := ATag = tobtnBGL.Tag;
  181. tobtnShowChecker.Down := ATag = tobtnShowChecker.Tag;
  182. tobtnUpFile.Down := ATag = tobtnUpFile.Tag;
  183. tobtnBookmark.Down := ATag = tobtnBookmark.Tag;
  184. end;
  185. constructor TProjectFrame.Create(AProjectData: TProjectData);
  186. begin
  187. inherited Create(nil);
  188. FProjectData := AProjectData;
  189. ResetAssistantView;
  190. AdjustFramesDisplay;
  191. CreateFrames;
  192. RefreshProjectState;
  193. GeneratePhaseChooseList;
  194. GenerateStageChooseList;
  195. dxsbViewControl.SelectedItem := dxsbViewControl.ActiveGroup.Items.Items[0];
  196. InitialForVersions;
  197. CreateUpFile;
  198. if G_IsCloud then
  199. begin
  200. // 0号台帐无审核人,网络读取会出错。所以只有在有计量的情况下才创建审核人
  201. if (ProjectData.PhaseIndex > 0) then
  202. begin
  203. tobtnShowChecker.Visible := True;
  204. CreateCheckerFrame;
  205. end;
  206. ButtonControl_NewPhase;
  207. ButtonControl_UpToWeb;
  208. RepairAudits;
  209. end;
  210. end;
  211. destructor TProjectFrame.Destroy;
  212. begin
  213. FBookmarkFrame.Free;
  214. FZJJLFrame.Free;
  215. FBillsGatherFrame.Free;
  216. FDealPaymentFrame.Free;
  217. FBillsCompileFrame.Free;
  218. FBillsMeasureFrame.Free;
  219. FUpFileManageView.Free;
  220. SupportManager.ClearAssistantViewParent;
  221. inherited;
  222. end;
  223. procedure TProjectFrame.ResetAssistantView;
  224. begin
  225. AlignControl(SupportManager.StandardLibsFrame, jpsAssistantStandardBills, alClient);
  226. end;
  227. procedure TProjectFrame.SetAssistantViewVisible(AVisible: Boolean);
  228. begin
  229. jpsAssistant.Visible := AVisible;
  230. sprAssistant.Visible := AVisible;
  231. end;
  232. procedure TProjectFrame.SetImageOfsbtnExpend(AExpend: Boolean);
  233. begin
  234. sbtnExpend.Glyph := nil;
  235. ilstExpend.GetBitmap(Integer(AExpend), sbtnExpend.Glyph);
  236. end;
  237. procedure TProjectFrame.tobtnStandardBillsClick(Sender: TObject);
  238. begin
  239. with TToolButton(Sender) do
  240. begin
  241. if Down then
  242. begin
  243. jpsAssistant.ActivePageIndex := Tag;
  244. sbtnExpend.Tag := Tag;
  245. ControlAssistantButtonsDown(Tag);
  246. jpsMain.ActivePage.Tag := Tag;
  247. end;
  248. SetAssistantViewVisible(Down);
  249. SetImageOfsbtnExpend(Down);
  250. end;
  251. end;
  252. procedure TProjectFrame.GeneratePhaseChooseList;
  253. var
  254. iIndex: Integer;
  255. begin
  256. jcbPhase.Items.Clear;
  257. for iIndex := 1 to FProjectData.ProjProperties.PhaseCount do
  258. jcbPhase.Items.Add(Format(' 第 %d 期数据', [iIndex]));
  259. jcbPhase.ItemIndex := jcbPhase.Items.Count - 1;
  260. jcbPhase.Enabled := jcbPhase.Items.Count > 0;
  261. tobtnZJJL.Enabled := jcbPhase.Enabled;
  262. tobtnBGL.Enabled := jcbPhase.Enabled;
  263. end;
  264. procedure TProjectFrame.jcbPhaseChanged(Sender: TObject);
  265. begin
  266. if ProjectData.PhaseIndex = jcbPhase.ItemIndex + 1 then Exit;
  267. FProjectData.PhaseIndex := jcbPhase.ItemIndex + 1;
  268. GenerateStageChooseList;
  269. RefreshProjectState;
  270. if Assigned(FZJJLFrame) then
  271. begin
  272. FZJJLFrame.DataReadOnly := FProjectData.PhaseData.StageDataReadOnly;
  273. FZJJLFrame.ResetFrameLink(FProjectData.PhaseData.ZJJLData);
  274. end;
  275. if G_IsCloud then
  276. begin
  277. if Assigned(FCheckerFrame) then
  278. begin
  279. FCheckerFrame.Init;
  280. RepairAudits;
  281. end;
  282. end;
  283. end;
  284. procedure TProjectFrame.CreateNewPhase;
  285. var
  286. iBef: Integer;
  287. vArr: array of string;
  288. begin
  289. if QuestMessage('请检查合同支付的初始值,新增一期计量将锁定当前全部的清单数据,是否继续?') then
  290. begin
  291. // 网络版创建第二期、第三期等跟第一期有所不同:
  292. // 创建前,先发送信号给服务器,服务器自动根据第一期生成第二期的审核人列表。
  293. // 有了这个列表程序才能正常接下来的业务。
  294. if G_IsCloud then
  295. begin
  296. iBef := FProjectData.ProjProperties.PhaseCount;
  297. if iBef >= 1 then
  298. begin
  299. vArr := VarArrayOf(['msg']);
  300. if PHPWeb.Search(PHPWeb.MeasureURL + 'phaseno/userlist/create',
  301. ['tenderid', 'phaseno'], [IntToStr(FProjectData.WebID),
  302. IntToStr(iBef + 1)], vArr) <> 1 then
  303. begin
  304. Application.MessageBox(Pchar('云端自动创建本期审核人列表出错,请重新尝试!'), '警告', MB_OK + MB_ICONWARNING);
  305. Exit;
  306. end;
  307. end;
  308. end;
  309. FProjectData.CreateNewPhase;
  310. tobtnDealPayment.Enabled := True;
  311. tobtnZJJL.Enabled := True;
  312. tobtnBGL.Enabled := True;
  313. jcbPhase.Enabled := True;
  314. jcbAudit.Enabled := True;
  315. jcbPhase.Items.Add(Format(' 第 %d 期数据', [jcbPhase.Items.Count + 1]));
  316. jcbPhase.ItemIndex := jcbPhase.Items.Count - 1;
  317. FProjectData.PhaseData.CopyPreData;
  318. RefreshProjectState;
  319. if G_IsCloud then
  320. begin
  321. if Assigned(CheckerFrame) then
  322. CheckerFrame.Free;
  323. CreateCheckerFrame;
  324. tobtnShowChecker.Visible := True;
  325. tobtnShowChecker.Enabled := True;
  326. ButtonControl_NewPhase;
  327. ButtonControl_UpToWeb;
  328. end;
  329. end;
  330. end;
  331. procedure TProjectFrame.sbtnExpendClick(Sender: TObject);
  332. var
  333. bExpend: Boolean;
  334. begin
  335. bExpend := not jpsAssistant.Visible;
  336. jpsAssistant.ActivePageIndex := TSpeedButton(Sender).Tag;
  337. SetAssistantViewVisible(bExpend);
  338. SetImageOfsbtnExpend(bExpend);
  339. if bExpend then
  340. begin
  341. ControlAssistantButtonsDown(jpsAssistant.ActivePageIndex);
  342. jpsMain.ActivePage.Tag := jpsAssistant.ActivePageIndex;
  343. end
  344. else
  345. begin
  346. ControlAssistantButtonsDown(-1);
  347. jpsMain.ActivePage.Tag := -1;
  348. end;
  349. if G_IsCloud then
  350. CheckUpFile;
  351. end;
  352. procedure TProjectFrame.CreateNewAudit;
  353. begin
  354. FProjectData.PhaseData.CreateNewAuditData;
  355. jcbAudit.Items.Add(Format(' %d 审', [FProjectData.PhaseData.StageCount - 1]));
  356. if jcbAudit.ItemIndex <> jcbAudit.Items.Count - 1 then
  357. jcbAudit.ItemIndex := jcbAudit.Items.Count - 1
  358. else
  359. FProjectData.ResetPhaseDataLink;
  360. end;
  361. procedure TProjectFrame.GenerateStageChooseList;
  362. var
  363. iIndex: Integer;
  364. begin
  365. jcbAudit.Items.Clear;
  366. if not FProjectData.PhaseData.Active then Exit;
  367. for iIndex := 0 to FProjectData.PhaseData.AuditCount do
  368. begin
  369. if iIndex = 0 then
  370. jcbAudit.Items.Add(' 原报')
  371. else
  372. jcbAudit.Items.Add(Format(' %d 审', [iIndex]));
  373. end;
  374. if jcbAudit.ItemIndex <> jcbAudit.Items.Count - 1 then
  375. jcbAudit.ItemIndex := jcbAudit.Items.Count - 1
  376. else
  377. FProjectData.ResetPhaseDataLink;
  378. jcbAudit.Enabled := jcbAudit.Items.Count > 0;
  379. end;
  380. procedure TProjectFrame.jcbAuditChanged(Sender: TObject);
  381. begin
  382. if FProjectData.PhaseData.StageIndex = jcbAudit.ItemIndex then Exit;
  383. FProjectData.PhaseData.StageIndex := jcbAudit.ItemIndex;
  384. RefreshProjectState;
  385. end;
  386. procedure TProjectFrame.dxsbViewControlItemClick(Sender: TObject;
  387. Item: TdxSideBarItem);
  388. procedure BeforeChangeView;
  389. begin
  390. if G_IsCloud then
  391. begin
  392. tobtnShowChecker.Visible := ProjectData.PhaseIndex > 0;
  393. tobtnShowChecker.Enabled := (Item.Tag = xbiBillsMeasure.Tag);
  394. ButtonControl_NewPhase;
  395. if Item.Tag = xbiBillsCompile.Tag then
  396. begin
  397. if tobtnShowChecker.Down then
  398. begin
  399. tobtnShowChecker.Down := False;
  400. tobtnShowChecker.Click;
  401. tobtnStandardBills.Down := True;
  402. tobtnStandardBills.Click;
  403. tobtnStandardBills.Down := False;
  404. tobtnStandardBills.Click;
  405. end;
  406. end;
  407. end;
  408. // 记录台账分解、计量台账等的右侧展开情况
  409. if jpsAssistant.Visible then
  410. jpsMain.ActivePage.Tag := jpsAssistant.ActivePageIndex
  411. else
  412. jpsMain.ActivePage.Tag := -1;
  413. end;
  414. procedure AfterChangeView;
  415. begin
  416. // 仅计量台账界面可以选择计量期
  417. pnlPhaseSelect.Visible := Item.Tag = xbiBillsMeasure.Tag;
  418. // 台账分解、计量台账、审核比较 可使用"显示至"功能
  419. tbExpand.Visible := (Item.Tag = xbiBillsCompile.Tag)
  420. or (Item.Tag = xbiBillsMeasure.Tag)
  421. or (Item.Tag = xbiStageCompare.Tag);
  422. // 右侧按钮是否显示
  423. tbToolsButton.Visible := (Item.Tag = xbiBillsCompile.Tag)
  424. or (Item.Tag = xbiBillsMeasure.Tag);
  425. tobtnBGL.Visible := Item.Tag = xbiBillsMeasure.Tag;
  426. tobtnZJJL.Visible := Item.Tag = xbiBillsMeasure.Tag;
  427. // 根据当前View控制右侧按钮是否按下,右侧工具窗是否弹开
  428. jpsAssistant.ActivePageIndex := jpsMain.ActivePage.Tag;
  429. sbtnExpend.Tag := jpsMain.ActivePage.Tag;
  430. ControlAssistantButtonsDown(jpsMain.ActivePage.Tag);
  431. SetAssistantViewVisible(jpsMain.ActivePage.Tag <> -1);
  432. SetImageOfsbtnExpend(jpsMain.ActivePage.Tag <> -1);
  433. // 0号台账与计量台账的书签不同
  434. if Item.Tag = xbiBillsCompile.Tag then
  435. FBookmarkFrame.BMType := bmtCompile
  436. else if Item.Tag = xbiBillsMeasure.Tag then
  437. FBookmarkFrame.BMType := bmtMeasure;
  438. // 0号台账与计量台账的查找定位不同
  439. if Item.Tag = xbiBillsCompile.Tag then
  440. FSearchFrame.LocateType := ltCompile
  441. else if Item.Tag = xbiBillsMeasure.Tag then
  442. FSearchFrame.LocateType := ltMeasure;
  443. // 切换至清单汇总,须重新汇总
  444. if Item.Tag = xbiBillsGather.Tag then
  445. BillsGatherFrame.RefreshBills;
  446. if G_IsCloud then
  447. if (Item.Tag = xbiBillsCompile.Tag) or (Item.Tag = xbiBillsMeasure.Tag) then
  448. CheckUpFile;
  449. tobtnUpFile.Enabled := Item.Tag = xbiBillsMeasure.Tag;
  450. if (tobtnUpFile.Enabled = False) and (jpsAssistant.ActivePage = jpsAssistantUpFile) then
  451. jpsAssistant.ActivePage := jpsAssistantStandardBills;
  452. end;
  453. procedure ChangeView;
  454. begin
  455. BeforeChangeView;
  456. case Item.Tag of
  457. 0, 2: jpsMain.ActivePageIndex := Item.Tag;
  458. 1: if CheckMeasureEdition then jpsMain.ActivePageIndex := Item.Tag;
  459. //2: if CheckPlanEdition then jpsMain.ActivePageIndex := Item.Tag;
  460. end;
  461. AfterChangeView;
  462. end;
  463. procedure DisplayReports;
  464. begin
  465. // 准备数据
  466. if Item.Tag = xbiReport.Tag then
  467. FProjectData.CopyPhaseData;
  468. // 显示报表界面
  469. DisplayReportsForm(FProjectData);
  470. dxsbViewControl.SelectedItem := dxsbViewControl.ActiveGroup.Items[jpsMain.ActivePageIndex];
  471. end;
  472. procedure DisplayCompare;
  473. begin
  474. if FProjectData.ProjProperties.PhaseCount = 0 then
  475. begin
  476. ShowErrorMessage('当前项目未开始计量,暂无审核比较数据!');
  477. dxsbViewControl.SelectedItem := dxsbViewControl.ActiveGroup.Items[jpsMain.ActivePageIndex];
  478. Abort;
  479. end;
  480. ShowProgressHint('正在准备审核比较数据,请稍候...');
  481. Screen.Cursor := crHourGlass;
  482. try
  483. BeforeChangeView;
  484. if CheckMeasureEdition then
  485. begin
  486. OpenCompare;
  487. jpsMain.ActivePageIndex := Item.Tag;
  488. end;
  489. AfterChangeView;
  490. finally
  491. Screen.Cursor := crDefault;
  492. CloseProgressHint;
  493. end;
  494. end;
  495. begin
  496. if Item.Tag = jpsMain.ActivePageIndex then Exit;
  497. if (Item.Tag in [0..2]) and (jpsMain.ActivePageIndex = 3) then
  498. CloseCompare;
  499. case Item.Tag of
  500. 0..2: ChangeView;
  501. 3: DisplayCompare;
  502. 4: DisplayReports;
  503. end;
  504. end;
  505. procedure TProjectFrame.CreateBillsFrame;
  506. begin
  507. FBillsCompileFrame := TBillsCompileFrame.Create(Self, FProjectData.BillsCompileData);
  508. FBillsCompileFrame.ShowDesignQuantity := FProjectData.ProjProperties.ShowDesignQuantity;
  509. FBillsCompileFrame.ShowAlias := FProjectData.ProjProperties.ShowAlias;
  510. FBillsCompileFrame.OnAfterSetBookmark := ExpandBookmarkFrame;
  511. AlignControl(FBillsCompileFrame, jpsMainBillsCompile, alClient);
  512. UpdateSysProgress(65, '正在解析数据');
  513. FBillsMeasureFrame := TBillsMeasureFrame.Create(Self, FProjectData.BillsMeasureData);
  514. FBillsMeasureFrame.OnAfterSetBookmark := ExpandBookmarkFrame;
  515. FBillsMeasureFrame.ShowPriceChange := FProjectData.ProjProperties.ShowPriceChange;
  516. FBillsMeasureFrame.ShowBGLCode := FProjectData.ProjProperties.ShowBGLCode;
  517. FBillsMeasureFrame.ShowDesignQuantity := FProjectData.ProjProperties.ShowDesignQuantity;
  518. FBillsMeasureFrame.ShowAlias := FProjectData.ProjProperties.ShowAlias;
  519. AlignControl(FBillsMeasureFrame, jpsMainBillsMeasure, alClient);
  520. end;
  521. procedure TProjectFrame.CreateDealPaymentFrame;
  522. begin
  523. FDealPaymentFrame := TDealPaymentFrame.Create(Self, FProjectData.DealPaymentData);
  524. AlignControl(FDealPaymentFrame, jpsAssistantDealPayment, alClient);
  525. end;
  526. procedure TProjectFrame.CreateBillsGatherFrame;
  527. begin
  528. FBillsGatherFrame := TBillsGatherFrame.Create(Self, FProjectData.BillsGatherData);
  529. AlignControl(FBillsGatherFrame, jpsMainBillsGather, alClient);
  530. FBillsGatherFrame.ShowPriceChange := FProjectData.ProjProperties.ShowPriceChange;
  531. FBillsGatherFrame.ShowPhaseData := FProjectData.ProjProperties.PhaseCount > 0;
  532. end;
  533. procedure TProjectFrame.dxpmExpandBillsPopup(Sender: TObject);
  534. begin
  535. dxpmExpandBills.ItemLinks.Items[7].Visible := jpsMain.ActivePageIndex in [0, 1, 3];
  536. dxpmExpandBills.ItemLinks.Items[6].Visible := jpsMain.ActivePageIndex in [1, 3];
  537. SetDxBtnAction(actnFirstLevel, MainForm.dxbtnFirstLevel);
  538. SetDxBtnAction(actnSecondLevel, MainForm.dxbtnSecondLevel);
  539. SetDxBtnAction(actnThirdLevel, MainForm.dxbtnThirdLevel);
  540. SetDxBtnAction(actnFourthLevel, MainForm.dxbtnFourthLevel);
  541. SetDxBtnAction(actnFifthLevel, MainForm.dxbtnFifthLevel);
  542. SetDxBtnAction(actnAllLevel, MainForm.dxbtnAllLevel);
  543. SetDxBtnAction(actnCurPhase, MainForm.dxbtnCurPhase);
  544. SetDxBtnAction(actnAllXmj, MainForm.dxbtnAllXmj);
  545. end;
  546. procedure TProjectFrame.actnFirstLevelExecute(Sender: TObject);
  547. begin
  548. ExpandNodeTo(TAction(Sender).Tag);
  549. end;
  550. procedure TProjectFrame.tbExpandClick(Sender: TObject);
  551. var
  552. P: TPoint;
  553. begin
  554. P := pnlToolBar.ClientToScreen(Point(tbExpand.Left, tbExpand.Top + tbExpand.Height));
  555. dxpmExpandBills.Popup(P.X, P.Y);
  556. end;
  557. procedure TProjectFrame.actnAllXmjExecute(Sender: TObject);
  558. begin
  559. ExpandAllXmj;
  560. end;
  561. procedure TProjectFrame.ExpandNodeTo(ALevel: Integer);
  562. begin
  563. Screen.Cursor := crHourGlass;
  564. case ALevel of
  565. 0..4: UpdateSysProgress(0, Format('正在显示至第%d层', [ALevel + 1]));
  566. else UpdateSysProgress(0, '正在显示至最底层');
  567. end;
  568. try
  569. case jpsMain.ActivePageIndex of
  570. 0: FBillsCompileFrame.ExpandNodeTo(ALevel);
  571. 1: FBillsMeasureFrame.ExpandNodeTo(ALevel);
  572. 3: FPhaseCompareFrame.ExpandNodeTo(ALevel);
  573. end;
  574. finally
  575. UpdateSysProgress(0, '就绪');
  576. Screen.Cursor := crDefault;
  577. end;
  578. end;
  579. procedure TProjectFrame.ExpandAllXmj;
  580. begin
  581. Screen.Cursor := crHourGlass;
  582. UpdateSysProgress(0, '正在显示至项目节');
  583. try
  584. case jpsMain.ActivePageIndex of
  585. 0: FBillsCompileFrame.ExpandXmjNode;
  586. 1: FBillsMeasureFrame.ExpandXmjNode;
  587. 3: FPhaseCompareFrame.ExpandXmjNode;
  588. end;
  589. finally
  590. UpdateSysProgress(0, '就绪');
  591. Screen.Cursor := crDefault;
  592. end;
  593. end;
  594. procedure TProjectFrame.UnLockData;
  595. procedure DoUnLockData;
  596. begin
  597. FProjectData.CanUnlockInfo := True;
  598. FBillsCompileFrame.stdBillsCompile.Column('LockedInfo').ReadOnly := False;
  599. //FProjectData.BillsData.UnLockedBaseData;
  600. end;
  601. begin
  602. if FProjectData.CheckPassword then
  603. DoUnLockData;
  604. end;
  605. procedure TProjectFrame.CreateCheckerFrame;
  606. begin
  607. FCheckerFrame := TCheckerFrame.Create(Self);
  608. FCheckerFrame.Owner := Self;
  609. FCheckerFrame.ProjectData := FProjectData;
  610. AlignControl(FCheckerFrame, jpsAssistantChecker, alClient);
  611. FCheckerFrame.Init;
  612. end;
  613. procedure TProjectFrame.btnSubmitClick(Sender: TObject);
  614. begin
  615. Screen.Cursor := crHourGlass;
  616. try
  617. UpToWeb(True);
  618. finally
  619. Screen.Cursor := crDefault;
  620. end;
  621. end;
  622. procedure TProjectFrame.btnPassClick(Sender: TObject);
  623. begin
  624. btnSubmitClick(Sender);
  625. end;
  626. function TProjectFrame.IsUped: Boolean; // 是否上传过
  627. begin
  628. Result := False;
  629. // 只有0号台帐那肯定没上传过
  630. if ProjectData.PhaseIndex = 0 then Exit;
  631. // 当前显示的期小于最新期(当前期是旧期),则当前期肯定已经上传过了
  632. if ProjectData.PhaseIndex < ProjectData.ProjProperties.PhaseCount then
  633. begin
  634. Result := True;
  635. end
  636. // 当前显示的期是最新期,分两种情况判断,如果第一审核人已有状态,则上传过了
  637. else if ProjectData.PhaseIndex = ProjectData.ProjProperties.PhaseCount then
  638. begin
  639. if not CheckerFrame.HasChecker then
  640. Result := False
  641. else if CheckerFrame.FirstChecker.CheckStatus = csNotBegin then
  642. Result := False
  643. else
  644. Result := True;
  645. end;
  646. end;
  647. procedure TProjectFrame.ButtonControl_UpToWeb;
  648. begin
  649. if ProjectData.CurUserIsAuthor then
  650. begin
  651. btnSubmit.Visible := True;
  652. // 有计量(非0号台账状态),且当前计量期尚未上报过
  653. btnSubmit.Enabled := (ProjectData.PhaseIndex > 0) and (not IsUped);
  654. btnPass.Visible := False;
  655. btnNotPass.Visible := btnPass.Visible;
  656. btnSubmit.Left := jcbAudit.Left + jcbAudit.Width + 5;
  657. end
  658. else if ProjectData.CurUserIsOwner or ProjectData.CurUserIsChecker then
  659. begin
  660. btnSubmit.Visible := False;
  661. btnPass.Visible := True;
  662. btnNotPass.Visible := btnPass.Visible;
  663. // 当前计量期轮到自已审核(自已正在审核时一定未提交过)
  664. btnPass.Enabled := CheckerFrame.Me.IsChecking;
  665. btnNotPass.Enabled := btnPass.Enabled;
  666. btnPass.Left := jcbAudit.Left + jcbAudit.Width + 5;
  667. btnNotPass.Left := btnPass.Left + btnPass.Width + 1;
  668. end;
  669. if Assigned(CheckerFrame) then
  670. pnlProjectCheckStatus.Visible := CheckerFrame.OwnerFrame.CheckStatus = csFinished
  671. else
  672. pnlProjectCheckStatus.Visible := False;
  673. if Assigned(FCheckerFrame) then
  674. FCheckerFrame.RepairDelete(btnSubmit.Visible and btnSubmit.Enabled);
  675. end;
  676. procedure TProjectFrame.UpToWeb(ACheckPassed: Boolean);
  677. var sURL, sAppFile, sJsonFile_Bills, sJsonFile_Common, sAppFile_UnLock,
  678. sZipFile, sResult, sMD5_JL, sPassedHint1, sPassedHint2,
  679. sNoPassedHint1, sNoPassedHint2, sCheckerMemo: string;
  680. vA, vArr: array of string;
  681. vRec: TsdDataRecord;
  682. bSubmit: Boolean;
  683. vExportor: TTenderExport;
  684. vCF: TCheckerMemoForm;
  685. begin
  686. bSubmit := False;
  687. sAppFile := PHPWeb.UserPath + 'ProjectFile.rmf';
  688. // 只有编制人才真正需要该文件存在
  689. sAppFile_UnLock := PHPWeb.UserPath + 'ProjectFile_UnLock';
  690. sPassedHint1 :=
  691. '【审批通过】后,计量数据将自动交付给下一审批人进行审批,操作后将不可更改,是否通过审批?';
  692. sPassedHint2 :=
  693. '(终审)审批通过后本期计量审批将标记为审批完成,操作后将不可更改,是否通过审批?';
  694. sNoPassedHint1 :=
  695. '【审批不通过】后,本次审批将结束,后续的审批人也将不会审批本次计量,' +
  696. '本期数据也将直接打回给上报人进行重新计量报审。' + #10#13 +
  697. '点击【确定】进入操作确认。';
  698. sNoPassedHint2 := PHPWeb.RealName +
  699. ',请确认本期计量审批不通过。' + #10#13 + '点击【确定】本期计量审批' +
  700. '不通过,计量将不可再更改。';
  701. vCF := TCheckerMemoForm.Create(nil);
  702. try
  703. if ProjectData.CurUserIsAuthor then
  704. begin
  705. bSubmit := True;
  706. if not CheckerFrame.HasNormalChecker then
  707. begin
  708. Application.MessageBox('上报审批前请先配置审核人!', '提示', MB_OK + MB_ICONWARNING);
  709. tobtnShowChecker.Down := True;
  710. tobtnShowChecker.Click;
  711. Exit;
  712. end;
  713. // 保存一次缓存数据,以保证提示信息能读取正确的值
  714. ProjectData.SaveLastestPhaseMainData;
  715. if Application.MessageBox(PChar(CheckersHint), '询问', MB_YESNO + MB_ICONQUESTION) = ID_No then
  716. Exit;
  717. CreateProgress('正在保存项目');
  718. ProjectData.Save;
  719. // 生成无锁文件
  720. vRec := MainForm.ProjectManagerFrame.Rec(ProjectData.ProjectID);
  721. vExportor := TTenderExport.Create(vRec, sAppFile_UnLock, True);
  722. try
  723. vExportor.Execute;
  724. finally
  725. vExportor.Free;
  726. end;
  727. ProjectData.SubmitProject(sAppFile);
  728. end
  729. else if ProjectData.CurUserIsChecker then
  730. begin
  731. if ACheckPassed then
  732. begin
  733. vCF.Init(sPassedHint1, 1);
  734. if vCF.ShowModal = mrCancel then
  735. Exit
  736. else
  737. sCheckerMemo := vCF.Memo;
  738. end
  739. else
  740. begin
  741. vCF.Init(sNoPassedHint1, 0);
  742. if vCF.ShowModal = mrCancel then
  743. Exit
  744. else
  745. sCheckerMemo := vCF.Memo;
  746. if Application.MessageBox(PChar(sNoPassedHint2), '询问', MB_OKCANCEL + MB_ICONQUESTION) = ID_CANCEL then
  747. Exit;
  748. end;
  749. CreateProgress('正在保存项目');
  750. ProjectData.Save;
  751. ProjectData.SubmitProject(sAppFile);
  752. end
  753. else if ProjectData.CurUserIsOwner then
  754. begin
  755. if ACheckPassed then
  756. begin
  757. vCF.Init(sPassedHint2, 1);
  758. if vCF.ShowModal = mrCancel then
  759. Exit
  760. else
  761. sCheckerMemo := vCF.Memo;
  762. end
  763. else
  764. begin
  765. vCF.Init(sNoPassedHint1, 0);
  766. if vCF.ShowModal = mrCancel then
  767. Exit
  768. else
  769. sCheckerMemo := vCF.Memo;
  770. if Application.MessageBox(PChar(sNoPassedHint2), '询问', MB_OKCANCEL + MB_ICONQUESTION) = ID_CANCEL then
  771. Exit;
  772. end;
  773. CreateProgress('正在保存项目');
  774. ProjectData.Save;
  775. ProjectData.ReplyProject(sAppFile);
  776. end;
  777. finally
  778. vCF.Free;
  779. end;
  780. sCheckerMemo := ReplaceJsonChar(sCheckerMemo);
  781. try
  782. RefreshProgress('创建文件包');
  783. sJsonFile_Bills := ExtractFilePath(sAppFile) + 'JsonFile_Bills.json';
  784. sJsonFile_Common := ExtractFilePath(sAppFile) + 'JsonFile_Common.json';
  785. sMD5_JL := MD5_File(sAppFile);
  786. // 上传清单,每期都传,可覆盖旧的。
  787. ProjectData.ExportJson_Bills(sJsonFile_Bills);
  788. ProjectData.ExportJson_Common(sJsonFile_Common);
  789. sZipFile := PHPWeb.zip([sAppFile, sJsonFile_Bills, sJsonFile_Common, sAppFile_UnLock]);
  790. try
  791. // 上传标段文件
  792. RefreshProgress('上传到云端');
  793. if PHPWeb.UpDataFile(PHPWeb.UserID, ProjectData.WebID, ProjectData.PhaseIndex,
  794. sZipFile, sMD5_JL, bSubmit, sResult, ACheckPassed, sCheckerMemo) then
  795. begin
  796. if ProjectData.CurUserIsChecker then
  797. ProjectData.Checkers.FindByID(PHPWeb.UserID).Memo := sCheckerMemo;
  798. RefreshProgress('本地刷新显示');
  799. if ProjectData.PhaseIndex = 0 then // 0号台账,现已废弃
  800. begin
  801. MainForm.ProjectManagerFrame.ShowProjWebInfoTop(0);
  802. end
  803. else
  804. Begin
  805. vRec := MainForm.ProjectManagerFrame.Rec(ProjectData.ProjectID);
  806. vRec.BeginUpdate;
  807. vRec.ValueByName('WebMD5').AsString := sMD5_JL;
  808. vRec.EndUpdate;
  809. MainForm.ProjectManagerFrame.ShowProjWebInfoTop;
  810. if ProjectData.CurUserIsAuthor then
  811. begin
  812. CheckerFrame.FirstChecker.CheckStatus := csChecking;
  813. CheckerFrame.AddFrame.Visible := False;
  814. end
  815. else if ProjectData.CurUserIsChecker then
  816. begin
  817. if ACheckPassed then
  818. begin
  819. CheckerFrame.Me.CheckStatus := csFinished;
  820. CheckerFrame.NextChecker.CheckStatus := csChecking;
  821. end
  822. else
  823. CheckerFrame.Me.CheckStatus := csNotPass;
  824. CheckerFrame.Me.CheckerMemo := sCheckerMemo;
  825. end
  826. else if ProjectData.CurUserIsOwner then
  827. begin
  828. if ACheckPassed then
  829. CheckerFrame.Me.CheckStatus := csFinished
  830. else
  831. CheckerFrame.Me.CheckStatus := csNotPass;
  832. end;
  833. end;
  834. btnSubmit.Enabled := False;
  835. FCheckerFrame.RepairDelete(False);
  836. btnPass.Enabled := False;
  837. btnNotPass.Enabled := btnPass.Enabled;
  838. pnlProjectCheckStatus.Visible := CheckerFrame.OwnerFrame.CheckStatus = csFinished;
  839. Application.MessageBox('^_^ 恭喜!数据已成功上传到云端服务器。', '提示', MB_OK + MB_ICONINFORMATION);
  840. end
  841. else
  842. Application.MessageBox(PChar('数据上传失败请重试!服务器故障:' + sResult), '警告', MB_OK + MB_ICONWARNING);
  843. except
  844. Application.MessageBox(PChar('数据上传失败请重试!网络较差,数据文件无法送达云端:' +
  845. sResult), '警告', MB_OK + MB_ICONWARNING);
  846. end;
  847. finally
  848. CloseProgress;
  849. end;
  850. end;
  851. procedure TProjectFrame.btnNotPassClick(Sender: TObject);
  852. begin
  853. Screen.Cursor := crHourGlass;
  854. try
  855. UpToWeb(False);
  856. finally
  857. Screen.Cursor := crDefault;
  858. end;
  859. end;
  860. function TProjectFrame.CheckersHint: string;
  861. var vSL: TStringList;
  862. i: Integer;
  863. sChecker, sChar: string;
  864. Rec: TsdDataRecord;
  865. begin
  866. vSL := TStringList.Create;
  867. try
  868. CheckerFrame.CheckerNameList(vSL);
  869. for i := 0 to vSL.Count - 1 do
  870. begin
  871. if i = 0 then
  872. sChar := ''
  873. else
  874. sChar := ' > ';
  875. sChecker := sChecker + sChar + vSL[i];
  876. end;
  877. while Length(sChecker) < 38 do // 保证提示框的大小达到最佳效果
  878. sChecker := sChecker + ' ';
  879. Rec := ProjectData.MainListData.GetPhaseMainRecord(FProjectData.PhaseIndex);
  880. Result := Format('本期计量:%m元。%s审批流程:%s%s上报后将不可更改,确定要上报吗?',
  881. [Rec.ValueByName('GatherTotalPrice').AsFloat, #10#13#10#13, sChecker, #10#13#10#13]);
  882. finally
  883. vSL.Free;
  884. end;
  885. end;
  886. procedure TProjectFrame.btnNewPhaseClick(Sender: TObject);
  887. begin
  888. dxsbViewControl.SelectedItem := dxsbViewControl.Groups[0].Items[1];
  889. dxsbViewControl.OnItemClick(Sender, dxsbViewControl.Groups[0].Items[1]);
  890. CreateNewPhase;
  891. end;
  892. procedure TProjectFrame.ButtonControl_NewPhase;
  893. var b1, b2, b3: Boolean;
  894. begin
  895. // “新建一期计量”按钮的显示隐藏
  896. // 计量界面,且是原报才显示
  897. b1 := (dxsbViewControl.SelectedItem.Index = 0) and ProjectData.CurUserIsAuthor;
  898. // ①尚无审核人列表 ②当前期已审核完成
  899. b2 := (not Assigned(CheckerFrame)) or (Assigned(CheckerFrame) and CheckerFrame.OwnerFrame.IsFinished);
  900. // 当前查看的是最新期。查看历史期不显示。
  901. b3 := (FProjectData.ProjProperties.PhaseCount = FProjectData.PhaseIndex);
  902. pnlNewPhase.Visible := b1 and b2 and b3;
  903. end;
  904. procedure TProjectFrame.actnCurPhaseExecute(Sender: TObject);
  905. begin
  906. ExpandCurPhase;
  907. end;
  908. procedure TProjectFrame.RepairAudits;
  909. var i, iSel: Integer;
  910. UserArr: array of string;
  911. sURL: string;
  912. begin
  913. jcbAudit.ItemHeight := 20;
  914. jcbAudit.Font.Name := '微软雅黑';
  915. jcbAudit.Font.Size := 10;
  916. jcbAudit.DropDownBox.Height := jcbAudit.Items.Count * jcbAudit.ItemHeight + 35;
  917. iSel := jcbAudit.ItemIndex;
  918. for i := 0 to jcbAudit.Items.Count - 1 do
  919. begin
  920. if i = 0 then
  921. begin
  922. // 原报:编制人。没有跟审核人一个表,另外查询。个人觉得这里设计得不好。
  923. // 打开软件时自动扫描,杰哥那头返回不了编制人的项目,也是这个原因。
  924. // 说服不了特工,先这样吧。
  925. sURL := Format('%suser/get/%d/info', [PHPWeb.MeasureURL, FProjectData.WebAuthorID]);
  926. UserArr := VarArrayOf(['avatar', 'name', 'jobs', 'company']);
  927. if PHPWeb.Search(sURL, [], [], UserArr) = 1 then
  928. jcbAudit.Items[i] := jcbAudit.Items[i] + ' ' + UserArr[1] + '-' + UserArr[2];
  929. end
  930. else
  931. begin
  932. // 某种漏洞的操作下,文件中记载的审核人数和审核人列表中的审核人数不一致,
  933. // 匹配时会溢出。这里要加判断。
  934. if i > CheckerFrame.List.Count then Break;
  935. if TOrderCheckerFrame(CheckerFrame.List[i - 1]) = FCheckerFrame.OwnerFrame then
  936. begin
  937. jcbAudit.Items[i] := ' 终审 ' +
  938. TOrderCheckerFrame(CheckerFrame.List[i - 1]).UserName + '-' +
  939. TOrderCheckerFrame(CheckerFrame.List[i - 1]).UserRole
  940. end
  941. else
  942. begin
  943. jcbAudit.Items[i] := jcbAudit.Items[i] + ' ' +
  944. TOrderCheckerFrame(CheckerFrame.List[i - 1]).UserName + '-' +
  945. TOrderCheckerFrame(CheckerFrame.List[i - 1]).UserRole;
  946. end;
  947. end;
  948. end;
  949. jcbAudit.ItemIndex := iSel;
  950. end;
  951. procedure TProjectFrame.CreateFrames;
  952. begin
  953. UpdateSysProgress(10, '正在解析数据');
  954. CreateBillsFrame;
  955. UpdateSysProgress(130, '正在解析数据');
  956. CreateDealPaymentFrame;
  957. UpdateSysProgress(140, '正在解析数据');
  958. CreateBillsGatherFrame;
  959. UpdateSysProgress(150, '正在解析数据');
  960. FZJJLFrame := TZJJLFrame.Create(Self, FProjectData.PhaseData.ZJJLData);
  961. FZJJLFrame.DataReadOnly := FProjectData.PhaseData.StageDataReadOnly;
  962. AlignControl(FZJJLFrame, jpsAssistantZJJL, alClient);
  963. UpdateSysProgress(160, '正在解析数据');
  964. FBGLFrame := TBGLFrame.Create(Self, FProjectData.BGLData);
  965. AlignControl(FBGLFrame, jpsAssistantBGL, alClient);
  966. UpdateSysProgress(170, '正在解析数据');
  967. FSearchFrame := TSearchFrame.Create(Self, FProjectData.SearchData);
  968. AlignControl(FSearchFrame, jpsAssistantSearch, alClient);
  969. UpdateSysProgress(180, '正在解析数据');
  970. FBookmarkFrame := TBookmarkFrame.Create(Self, FProjectData);
  971. AlignControl(FBookmarkFrame, jpsAssistantBookmark, alClient);
  972. UpdateSysProgress(190, '正在解析数据');
  973. FDealBillsFrame := TDealBillsFrame.Create(Self, FProjectData.DealBillsData);
  974. AlignControl(FDealBillsFrame, jpsAssistantDealBills, alClient);
  975. UpdateSysProgress(200, '就绪');
  976. end;
  977. procedure TProjectFrame.InitialForVersions;
  978. begin
  979. if _ModuleType = mtCompile then
  980. begin
  981. // 去掉审核比较
  982. dxsbViewControl.Groups.Items[0].Items.Delete(3);
  983. // 去掉计量台账
  984. dxsbViewControl.Groups.Items[0].Items.Delete(1);
  985. end;
  986. end;
  987. procedure TProjectFrame.ExpandBookmarkFrame(AExpandFrame: Boolean);
  988. begin
  989. // 展开书签
  990. if AExpandFrame then
  991. begin
  992. jpsAssistant.ActivePageIndex := tobtnBookmark.Tag;
  993. sbtnExpend.Tag := tobtnBookmark.Tag;
  994. ControlAssistantButtonsDown(tobtnBookmark.Tag);
  995. jpsMain.ActivePage.Tag := tobtnBookmark.Tag;
  996. SetAssistantViewVisible(True);
  997. SetImageOfsbtnExpend(True);
  998. end;
  999. // 刷新书签批注
  1000. FBookmarkFrame.RefreshMarkMemo;
  1001. end;
  1002. {
  1003. 在意外情况下,文件中记录的审核人与云端记录的审核人不一致,文件中的审核表有时
  1004. 被多创建,有时少创建。这时不允许继续操作,需强制关闭:
  1005. 1、如果第x个人为审核中,则:
  1006. ①当前登录用户,如果非工作中,无论编制人、审核人还是业主,审核表个数应为x。
  1007. ②当前登录用户,如果工作中,必是审核人或业主,审核表个数应为x + 1。
  1008. 2、如果找不到审核中,找到了第x个人为审核不通过,则:
  1009. ①当前登录用户为编制人:
  1010. a.重新开始:审核表个数应为1。
  1011. b.仅查看不通过项目:审核表个数应为x + 1。
  1012. ②当前登录用户为审核人或业主:一定是非工作中(编制人工作中),审核表个数应为x + 1。
  1013. 3、如果找不到审核中,也找不到审核不通过,如果最后一个人是审核完成,则:
  1014. ①当前登录用户为编制人,此时编制人尚末开始新的一期,下拉还是上一期的,审核表个数亦为x+1。
  1015. ②当前登录用户为审核人或业主,审核表个数为x+1。
  1016. 4、如果找不到审核中,也找不到审核不通过,如果第一个人是末审核,则:
  1017. ①当前登录用户为编制人,审核表个数应为1。 }
  1018. function TProjectFrame.CheckFileAndCloudChekerList: Boolean;
  1019. var iNo, iC: Integer;
  1020. begin
  1021. Result := False;
  1022. iC := jcbAudit.Items.Count;
  1023. if not Assigned(FCheckerFrame) then // 0号台帐阶段还没有审核人业务
  1024. begin
  1025. Result := True;
  1026. Exit;
  1027. end;
  1028. iNo := FCheckerFrame.CheckNo(csChecking);
  1029. if iNo <> -1 then // 审核中
  1030. begin
  1031. // FCheckerFrame.Me = nil :编制 (这里体现出编制人不在审核人列表中极不合理!)
  1032. if (FCheckerFrame.Me <> nil) and FCheckerFrame.Me.IsChecking then
  1033. Result := (iC = iNo + 1)
  1034. else
  1035. Result := (iC = iNo);
  1036. end
  1037. else
  1038. begin
  1039. iNo := FCheckerFrame.CheckNo(csNotPass);
  1040. if iNo <> -1 then // 审核不通过
  1041. begin
  1042. if ProjectData.CurUserIsAuthor then
  1043. Result := ((iC = 1) or (iC = iNo + 1))
  1044. else if FCheckerFrame.InCheckerList(PHPWeb.UserID) then
  1045. Result := (iC = iNo + 1);
  1046. end
  1047. else
  1048. begin
  1049. if FCheckerFrame.LastChecker.CheckStatus = csFinished then // 最后一个人是审核完成
  1050. Result := (iC = FCheckerFrame.List.Count + 1)
  1051. else // 第一个人是末审核
  1052. Result := (iC = 1);
  1053. end;
  1054. end;
  1055. end;
  1056. procedure TProjectFrame.tobtnUpFileClick(Sender: TObject);
  1057. begin
  1058. with TToolButton(Sender) do
  1059. begin
  1060. if Down then
  1061. begin
  1062. jpsAssistant.ActivePageIndex := Tag;
  1063. sbtnExpend.Tag := Tag;
  1064. ControlAssistantButtonsDown(Tag);
  1065. jpsMain.ActivePage.Tag := Tag;
  1066. end;
  1067. SetAssistantViewVisible(Down);
  1068. SetImageOfsbtnExpend(Down);
  1069. end;
  1070. CheckUpFile;
  1071. end;
  1072. procedure TProjectFrame.CreateUpFile;
  1073. begin
  1074. FUpFileManageView := TUpFileManageView.Create(nil);
  1075. FUpFileManageView.Owner := Self;
  1076. FUpFileManageView.ProjectData := FProjectData;
  1077. FUpFileManageView.Datas := FProjectData.AttachmentData;
  1078. FUpFileManageView.Parent := jpsAssistantUpFile;
  1079. FUpFileManageView.Align := alClient;
  1080. end;
  1081. procedure TProjectFrame.SetUpFileManageView(
  1082. const Value: TUpFileManageView);
  1083. begin
  1084. FUpFileManageView := Value;
  1085. end;
  1086. procedure TProjectFrame.jpsAssistantActivePageChanged(Sender: TObject);
  1087. begin
  1088. if G_IsCloud then
  1089. CheckUpFile;
  1090. end;
  1091. procedure TProjectFrame.CheckUpFile;
  1092. var vRec: TsdDataRecord;
  1093. begin
  1094. if jpsAssistant.Visible and (jpsAssistant.ActivePage = jpsAssistantUpFile) then
  1095. begin
  1096. if jpsMain.ActivePage = jpsMainBillsCompile then
  1097. begin
  1098. vRec := FBillsCompileFrame.BillsCompileData.sdvBillsCompile.Current;
  1099. if vRec = nil then
  1100. vRec := FBillsCompileFrame.stdBillsCompile.IDTree.Items[0].Rec;
  1101. end
  1102. else if jpsMain.ActivePage = jpsMainBillsMeasure then
  1103. begin
  1104. vRec := FBillsMeasureFrame.BillsMeasureData.sdvBillsMeasure.Current;
  1105. if vRec = nil then
  1106. vRec := FBillsMeasureFrame.stdBillsMeasure.IDTree.Items[0].Rec;
  1107. end;
  1108. FUpFileManageView.DoOnBillChange(vRec);
  1109. end;
  1110. end;
  1111. procedure TProjectFrame.SaveLog(AStr: string);
  1112. var
  1113. sFileName: string;
  1114. F: TextFile;
  1115. begin
  1116. sFileName := GetAppFilePath + 'TimeLog.txt';
  1117. AssignFile(F, sFileName);
  1118. if FileExists(sFileName) then
  1119. Append(F)
  1120. else
  1121. Rewrite(F);
  1122. Writeln(F, AStr);
  1123. CloseFile(F);
  1124. end;
  1125. procedure TProjectFrame.ReLockData;
  1126. begin
  1127. FProjectData.CanUnlockInfo := False;
  1128. FBillsCompileFrame.stdBillsCompile.Column('LockedInfo').ReadOnly := True;
  1129. end;
  1130. procedure TProjectFrame.CloseCompare;
  1131. begin
  1132. FPhaseCompareFrame.Free;
  1133. FProjectData.PhaseCompareData.Close;
  1134. FProjectData.PhaseData.StageCompareData.Close;
  1135. end;
  1136. procedure TProjectFrame.OpenCompare;
  1137. begin
  1138. FProjectData.PhaseData.Save;
  1139. FProjectData.PhaseData.StageCompareData.Open;
  1140. FProjectData.PhaseCompareData.Open;
  1141. FPhaseCompareFrame := TPhaseCompareFrame.Create(Self, FProjectData.PhaseCompareData);
  1142. AlignControl(FPhaseCompareFrame, jpsMainStageCompare, alClient);
  1143. end;
  1144. procedure TProjectFrame.RefreshColumnDisplay;
  1145. begin
  1146. BillsCompileFrame.ShowDesignQuantity := FProjectData.ProjProperties.ShowDesignQuantity;
  1147. BillsCompileFrame.ShowAlias := FProjectData.ProjProperties.ShowAlias;
  1148. BillsMeasureFrame.ShowPriceChange := FProjectData.ProjProperties.ShowPriceChange;
  1149. BillsMeasureFrame.ShowBGLCode := FProjectData.ProjProperties.ShowBGLCode;
  1150. BillsMeasureFrame.ShowDesignQuantity := FProjectData.ProjProperties.ShowDesignQuantity;
  1151. BillsMeasureFrame.ShowAlias := FProjectData.ProjProperties.ShowAlias;
  1152. BillsGatherFrame.ShowPriceChange := FProjectData.ProjProperties.ShowPriceChange;
  1153. end;
  1154. procedure TProjectFrame.RefreshProjectState;
  1155. begin
  1156. FBillsCompileFrame.RefreshPhase_Stage;
  1157. FBillsMeasureFrame.RefreshPhase_Stage;
  1158. FDealPaymentFrame.RefreshPhase_Stage;
  1159. end;
  1160. procedure TProjectFrame.ExpandCurPhase;
  1161. begin
  1162. Screen.Cursor := crHourGlass;
  1163. UpdateSysProgress(0, '正在显示至项目节');
  1164. try
  1165. case jpsMain.ActivePageIndex of
  1166. 1: FBillsMeasureFrame.ExpandCurPhase;
  1167. 3: FPhaseCompareFrame.ExpandCurPhase;
  1168. end;
  1169. finally
  1170. UpdateSysProgress(0, '就绪');
  1171. Screen.Cursor := crDefault;
  1172. end;
  1173. end;
  1174. end.