ProjectFme.pas 53 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719
  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. PriceMarginFme, OtherMeasureFme,
  8. Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  9. Dialogs, ImgList, XPMenu, Buttons, ComCtrls, ToolWin, ExtCtrls, JimPages,
  10. StdCtrls, JimCombos, dxsbar, ActnList, dxBar, OrderCheckerFme, CheckerFme,
  11. CslButton, UpFileManageFrame, UpFileManageUnit;
  12. type
  13. TProjectFrame = class(TFrame)
  14. xpm: TXPMenu;
  15. ilstExpend: TImageList;
  16. pnlViewControl: TPanel;
  17. pnlView: TPanel;
  18. pnlToolBar: TPanel;
  19. tbToolsButton: TToolBar;
  20. tobtnStandardBills: TToolButton;
  21. tobtnDealPayment: TToolButton;
  22. tobtnSearch: TToolButton;
  23. sbtnExpend: TSpeedButton;
  24. tbXmjBills: TToolBar;
  25. tbExpand: TToolButton;
  26. tbSeparator: TToolButton;
  27. sprAssistant: TSplitter;
  28. jpsAssistant: TJimPages;
  29. jpsAssistantDealPayment: TJimPage;
  30. jpsAssistantSearch: TJimPage;
  31. dxsbViewControl: TdxSideBar;
  32. dxsbsViewControl: TdxSideBarStore;
  33. xbiBillsCompile: TdxStoredSideItem;
  34. jpsAssistantStandardBills: TJimPage;
  35. jpsMain: TJimPages;
  36. jpsMainBillsMeasure: TJimPage;
  37. xbiBillsGather: TdxStoredSideItem;
  38. jpsMainBillsGather: TJimPage;
  39. ilstLarge: TImageList;
  40. ilstSmall: TImageList;
  41. xbiStageCompare: TdxStoredSideItem;
  42. xbiCompleteDegree: TdxStoredSideItem;
  43. xbiReport: TdxStoredSideItem;
  44. jpsMainStageCompare: TJimPage;
  45. tobtnZJJL: TToolButton;
  46. tobtnBGL: TToolButton;
  47. jpsAssistantZJJL: TJimPage;
  48. jpsAssistantBGL: TJimPage;
  49. dxpmExpandBills: TdxBarPopupMenu;
  50. alProject: TActionList;
  51. actnFirstLevel: TAction;
  52. actnSecondLevel: TAction;
  53. actnThirdLevel: TAction;
  54. actnFourthLevel: TAction;
  55. actnFifthLevel: TAction;
  56. actnAllLevel: TAction;
  57. actnAllXmj: TAction;
  58. xbiBillsMeasure: TdxStoredSideItem;
  59. jpsMainBillsCompile: TJimPage;
  60. pnlPhaseSelect: TPanel;
  61. jcbAudit: TJimComboBox;
  62. jcbPhase: TJimComboBox;
  63. tobtnShowChecker: TToolButton;
  64. jpsAssistantChecker: TJimPage;
  65. btnSubmit: TCslButton;
  66. btnPass: TCslButton;
  67. btnNotPass: TCslButton;
  68. pnlNewPhase: TPanel;
  69. btnNewPhase: TCslButton;
  70. pnlProjectCheckStatus: TPanel;
  71. actnCurPhase: TAction;
  72. tobtnBookmark: TToolButton;
  73. jpsAssistantBookmark: TJimPage;
  74. jpsAssistantUpFile: TJimPage;
  75. tobtnUpFile: TToolButton;
  76. jpsAssistantDealBills: TJimPage;
  77. tobtnDealBills: TToolButton;
  78. actnAllPeg: TAction;
  79. jpsMainPriceMargin: TJimPage;
  80. xbiPriceMargin: TdxStoredSideItem;
  81. dxsbsViewControlItem8: TdxStoredSideItem;
  82. jpsMainOtherMeasure: TJimPage;
  83. procedure tobtnStandardBillsClick(Sender: TObject);
  84. procedure jcbPhaseChanged(Sender: TObject);
  85. procedure sbtnExpendClick(Sender: TObject);
  86. procedure jcbAuditChanged(Sender: TObject);
  87. procedure dxsbViewControlItemClick(Sender: TObject;
  88. Item: TdxSideBarItem);
  89. procedure dxpmExpandBillsPopup(Sender: TObject);
  90. procedure actnFirstLevelExecute(Sender: TObject);
  91. procedure tbExpandClick(Sender: TObject);
  92. procedure actnAllXmjExecute(Sender: TObject);
  93. procedure btnSubmitClick(Sender: TObject);
  94. procedure btnPassClick(Sender: TObject);
  95. procedure btnNotPassClick(Sender: TObject);
  96. procedure btnNewPhaseClick(Sender: TObject);
  97. procedure actnCurPhaseExecute(Sender: TObject);
  98. procedure tobtnUpFileClick(Sender: TObject);
  99. procedure jpsAssistantActivePageChanged(Sender: TObject);
  100. procedure actnAllPegExecute(Sender: TObject);
  101. private
  102. FProjectData: TProjectData;
  103. FBillsCompileFrame: TBillsCompileFrame;
  104. FBillsMeasureFrame: TBillsMeasureFrame;
  105. FBillsGatherFrame: TBillsGatherFrame;
  106. FPriceMarginFrame: TPriceMarginFrame;
  107. FPhaseCompareFrame: TPhaseCompareFrame;
  108. FOtherMeasureFrame: TOtherMeasureFrame;
  109. FCheckerFrame: TCheckerFrame;
  110. FDealPaymentFrame: TDealPaymentFrame;
  111. FZJJLFrame: TZJJLFrame;
  112. FBGLFrame: TBGLFrame;
  113. FSearchFrame: TSearchFrame;
  114. FBookmarkFrame: TBookmarkFrame;
  115. FUpFileManageView: TUpFileManageView;
  116. FDealBillsFrame: TDealBillsFrame;
  117. procedure CreateBillsFrame;
  118. procedure CreateDealPaymentFrame;
  119. procedure CreateBillsGatherFrame;
  120. procedure CreatePriceMarginFrame;
  121. procedure CreateCheckerFrame;
  122. procedure CreateUpFile;
  123. procedure CreateFrames;
  124. procedure InitialForVersions;
  125. procedure OpenCompare;
  126. procedure CloseCompare;
  127. // 刷新各界面只读、显示等
  128. procedure RefreshProjectState;
  129. // Change Main View
  130. procedure BeforeChangeView(APageIndex: Integer);
  131. procedure AfterChangeView(APageIndex: Integer);
  132. procedure ChangeView(APageIndex: Integer);
  133. procedure AdjustFramesDisplay;
  134. procedure SaveLog(AStr: string);
  135. procedure ExpandNodeTo(ALevel: Integer);
  136. procedure ExpandAllXmj;
  137. procedure ExpandCurPhase;
  138. procedure SetAssistantViewVisible(AVisible: Boolean);
  139. procedure SetImageOfsbtnExpend(AExpend: Boolean);
  140. procedure ControlAssistantButtonsDown(ATag: Integer);
  141. procedure ExpandBookmarkFrame(AExpandFrame: Boolean);
  142. procedure UpToWeb(ACheckPassed: Boolean);
  143. function CheckersHint: string;
  144. procedure SetUpFileManageView(const Value: TUpFileManageView);
  145. procedure CheckUpFile;
  146. procedure ShowPhaseHint;
  147. public
  148. constructor Create(AProjectData: TProjectData);
  149. destructor Destroy; override;
  150. procedure ResetAssistantView;
  151. procedure GeneratePhaseChooseList;
  152. procedure GenerateStageChooseList;
  153. function CreateNewPhase: Boolean;
  154. procedure CreateNewAudit;
  155. procedure RefreshColumnDisplay;
  156. function CheckCanReport: Boolean;
  157. procedure UnLockData;
  158. procedure ReLockData;
  159. function IsUped: Boolean;
  160. procedure ButtonControl_UpToWeb;
  161. procedure ButtonControl_NewPhase;
  162. procedure RepairAudits;
  163. function CheckFileAndCloudChekerList: Boolean;
  164. procedure LocateMeasureBills(AID: Integer);
  165. procedure LocateCompileBills(AID: Integer);
  166. procedure LocateZJJL(ABillsID: Integer);
  167. property ProjectData: TProjectData read FProjectData;
  168. property BillsCompileFrame: TBillsCompileFrame read FBillsCompileFrame;
  169. property BillsMeasureFrame: TBillsMeasureFrame read FBillsMeasureFrame;
  170. property BillsGatherFrame: TBillsGatherFrame read FBillsGatherFrame;
  171. property PriceMarginFrame: TPriceMarginFrame read FPriceMarginFrame;
  172. property OtherMeasureFrame: TOtherMeasureFrame read FOtherMeasureFrame;
  173. property CheckerFrame: TCheckerFrame read FCheckerFrame;
  174. property UpFileManageView: TUpFileManageView read FUpFileManageView write SetUpFileManageView;
  175. property DealPaymentFrame: TDealPaymentFrame read FDealPaymentFrame;
  176. property ZJJLFrame: TZJJLFrame read FZJJLFrame;
  177. property BGLFrame: TBGLFrame read FBGLFrame;
  178. property SearchFrame: TSearchFrame read FSearchFrame;
  179. property BookmarkFrame: TBookmarkFrame read FBookmarkFrame;
  180. property DealBillsFrame: TDealBillsFrame read FDealBillsFrame;
  181. end;
  182. implementation
  183. uses
  184. PhaseData, BGLDm, MainFrm, ZhAPI, SearchDm, PHPWebDm, ActiveX,
  185. ConstUnit, MD5Unit, sdIDTree, sdDB, mProgressFrm, ConditionalDefines,
  186. ProjectCommands, ProjectProperty, CheckerMemoFrm, BillsMeasureDm,
  187. ProgressHintFrm, mProgressProFrm, ReportManagerFrm, BillsCompileDm,
  188. ScFileArchiverConsts, Math, ZJJLDm, Checker;
  189. {$R *.dfm}
  190. { TProjectFrame }
  191. procedure TProjectFrame.AdjustFramesDisplay;
  192. begin
  193. jpsAssistant.Width := 395;
  194. SetAssistantViewVisible(False);
  195. end;
  196. procedure TProjectFrame.ControlAssistantButtonsDown(ATag: Integer);
  197. begin
  198. tobtnStandardBills.Down := ATag = tobtnStandardBills.Tag;
  199. tobtnDealPayment.Down := ATag = tobtnDealPayment.Tag;
  200. tobtnSearch.Down := ATag = tobtnSearch.Tag;
  201. tobtnZJJL.Down := ATag = tobtnZJJL.Tag;
  202. tobtnBGL.Down := ATag = tobtnBGL.Tag;
  203. tobtnShowChecker.Down := ATag = tobtnShowChecker.Tag;
  204. tobtnUpFile.Down := ATag = tobtnUpFile.Tag;
  205. tobtnBookmark.Down := ATag = tobtnBookmark.Tag;
  206. end;
  207. constructor TProjectFrame.Create(AProjectData: TProjectData);
  208. begin
  209. inherited Create(nil);
  210. FProjectData := AProjectData;
  211. ResetAssistantView;
  212. AdjustFramesDisplay;
  213. CreateFrames;
  214. RefreshProjectState;
  215. GeneratePhaseChooseList;
  216. GenerateStageChooseList;
  217. dxsbViewControl.SelectedItem := dxsbViewControl.ActiveGroup.Items.Items[0];
  218. InitialForVersions;
  219. CreateUpFile;
  220. if G_IsCloud then
  221. begin
  222. pnlProjectCheckStatus.Visible := True;
  223. // 0号台帐无审核人,网络读取会出错。所以只有在有计量的情况下才创建审核人
  224. if (ProjectData.PhaseIndex > 0) then
  225. begin
  226. tobtnShowChecker.Visible := True;
  227. CreateCheckerFrame;
  228. end;
  229. ButtonControl_NewPhase;
  230. ButtonControl_UpToWeb;
  231. RepairAudits;
  232. // if FProjectData.IsGuest then
  233. tobtnUpFile.Visible := False;
  234. end;
  235. end;
  236. destructor TProjectFrame.Destroy;
  237. begin
  238. FBookmarkFrame.Free;
  239. FZJJLFrame.Free;
  240. FOtherMeasureFrame.Free;
  241. FBillsGatherFrame.Free;
  242. FDealPaymentFrame.Free;
  243. FBillsCompileFrame.Free;
  244. FBillsMeasureFrame.Free;
  245. FUpFileManageView.Free;
  246. SupportManager.ClearAssistantViewParent;
  247. inherited;
  248. end;
  249. procedure TProjectFrame.ResetAssistantView;
  250. begin
  251. AlignControl(SupportManager.StandardLibsFrame, jpsAssistantStandardBills, alClient);
  252. end;
  253. procedure TProjectFrame.SetAssistantViewVisible(AVisible: Boolean);
  254. begin
  255. jpsAssistant.Visible := AVisible;
  256. sprAssistant.Visible := AVisible;
  257. end;
  258. procedure TProjectFrame.SetImageOfsbtnExpend(AExpend: Boolean);
  259. begin
  260. sbtnExpend.Glyph := nil;
  261. ilstExpend.GetBitmap(Integer(AExpend), sbtnExpend.Glyph);
  262. end;
  263. procedure TProjectFrame.tobtnStandardBillsClick(Sender: TObject);
  264. begin
  265. with TToolButton(Sender) do
  266. begin
  267. if Down then
  268. begin
  269. jpsAssistant.ActivePageIndex := Tag;
  270. sbtnExpend.Tag := Tag;
  271. ControlAssistantButtonsDown(Tag);
  272. if _IsCloud and (Tag = tobtnBGL.Tag) then
  273. BGLFrame.LoadBGLFromCloud;
  274. jpsMain.ActivePage.Tag := Tag;
  275. end;
  276. SetAssistantViewVisible(Down);
  277. SetImageOfsbtnExpend(Down);
  278. end;
  279. end;
  280. procedure TProjectFrame.GeneratePhaseChooseList;
  281. var
  282. iIndex: Integer;
  283. begin
  284. jcbPhase.Items.Clear;
  285. for iIndex := 1 to FProjectData.ProjProperties.PhaseCount do
  286. jcbPhase.Items.Add(Format(' 第 %d 期数据', [iIndex]));
  287. jcbPhase.ItemIndex := jcbPhase.Items.Count - 1;
  288. jcbPhase.Enabled := jcbPhase.Items.Count > 0;
  289. tobtnZJJL.Enabled := jcbPhase.Enabled;
  290. tobtnBGL.Enabled := jcbPhase.Enabled;
  291. end;
  292. procedure TProjectFrame.jcbPhaseChanged(Sender: TObject);
  293. var
  294. cr: TCursor;
  295. begin
  296. cr := Screen.Cursor;
  297. Screen.Cursor := crHourGlass;
  298. if ProjectData.PhaseIndex = jcbPhase.ItemIndex + 1 then Exit;
  299. FProjectData.PhaseIndex := jcbPhase.ItemIndex + 1;
  300. GenerateStageChooseList;
  301. RefreshProjectState;
  302. if Assigned(FZJJLFrame) then
  303. begin
  304. FZJJLFrame.DataReadOnly := FProjectData.PhaseData.StageDataReadOnly;
  305. FZJJLFrame.ResetFrameLink(FProjectData.PhaseData.ZJJLData);
  306. end;
  307. if G_IsCloud then
  308. begin
  309. if Assigned(FCheckerFrame) then
  310. begin
  311. FCheckerFrame.Init;
  312. RepairAudits;
  313. end;
  314. ButtonControl_UpToWeb;
  315. UpFileManageView.RefreshViews;
  316. end;
  317. jcbPhase.Invalidate;
  318. Screen.Cursor := cr;
  319. end;
  320. function TProjectFrame.CreateNewPhase: Boolean;
  321. var
  322. iBef: Integer;
  323. vArr: array of string;
  324. begin
  325. Result := False;
  326. if QuestMessage('请检查合同支付的初始值,新增一期计量将锁定当前全部的清单数据,是否继续?') then
  327. begin
  328. // 网络版创建第二期、第三期等跟第一期有所不同:
  329. // 创建前,先发送信号给服务器,服务器自动根据第一期生成第二期的审核人列表。
  330. // 有了这个列表程序才能正常接下来的业务。
  331. if G_IsCloud then
  332. begin
  333. iBef := FProjectData.ProjProperties.PhaseCount;
  334. if iBef >= 1 then
  335. begin
  336. vArr := VarArrayOf(['msg']);
  337. if PHPWeb.Search(PHPWeb.MeasureURL + 'phaseno/userlist/create',
  338. ['tenderid', 'phaseno'], [IntToStr(FProjectData.WebID),
  339. IntToStr(iBef + 1)], vArr) <> 1 then
  340. begin
  341. Application.MessageBox(Pchar('云端自动创建本期审批人列表出错,请重新尝试!'), '警告', MB_OK + MB_ICONWARNING);
  342. Exit;
  343. end;
  344. end;
  345. end;
  346. FProjectData.CreateNewPhase;
  347. tobtnDealPayment.Enabled := True;
  348. tobtnZJJL.Enabled := True;
  349. tobtnBGL.Enabled := True;
  350. jcbPhase.Enabled := True;
  351. jcbAudit.Enabled := True;
  352. jcbPhase.Items.Add(Format(' 第 %d 期数据', [jcbPhase.Items.Count + 1]));
  353. jcbPhase.ItemIndex := jcbPhase.Items.Count - 1;
  354. FProjectData.CopyPreData;
  355. RefreshProjectState;
  356. if G_IsCloud then
  357. begin
  358. if Assigned(CheckerFrame) then
  359. CheckerFrame.Free;
  360. CreateCheckerFrame;
  361. tobtnShowChecker.Visible := True;
  362. tobtnShowChecker.Enabled := True;
  363. ButtonControl_NewPhase;
  364. ButtonControl_UpToWeb;
  365. end;
  366. Result := True;
  367. end;
  368. end;
  369. procedure TProjectFrame.sbtnExpendClick(Sender: TObject);
  370. var
  371. bExpend: Boolean;
  372. begin
  373. bExpend := not jpsAssistant.Visible;
  374. jpsAssistant.ActivePageIndex := TSpeedButton(Sender).Tag;
  375. SetAssistantViewVisible(bExpend);
  376. SetImageOfsbtnExpend(bExpend);
  377. if bExpend then
  378. begin
  379. ControlAssistantButtonsDown(jpsAssistant.ActivePageIndex);
  380. jpsMain.ActivePage.Tag := jpsAssistant.ActivePageIndex;
  381. end
  382. else
  383. begin
  384. ControlAssistantButtonsDown(-1);
  385. jpsMain.ActivePage.Tag := -1;
  386. end;
  387. if G_IsCloud then
  388. CheckUpFile;
  389. end;
  390. procedure TProjectFrame.CreateNewAudit;
  391. begin
  392. FProjectData.PhaseData.CreateNewAuditData;
  393. jcbAudit.Items.Add(Format(' %d 审', [FProjectData.PhaseData.StageCount - 1]));
  394. if jcbAudit.ItemIndex <> jcbAudit.Items.Count - 1 then
  395. jcbAudit.ItemIndex := jcbAudit.Items.Count - 1
  396. else
  397. FProjectData.ResetPhaseDataLink;
  398. end;
  399. procedure TProjectFrame.GenerateStageChooseList;
  400. var
  401. iIndex: Integer;
  402. begin
  403. jcbAudit.Items.Clear;
  404. if not FProjectData.PhaseData.Active then Exit;
  405. for iIndex := 0 to FProjectData.PhaseData.AuditCount do
  406. begin
  407. if iIndex = 0 then
  408. jcbAudit.Items.Add(' 原报')
  409. else
  410. jcbAudit.Items.Add(Format(' %d 审', [iIndex]));
  411. end;
  412. if jcbAudit.ItemIndex <> jcbAudit.Items.Count - 1 then
  413. jcbAudit.ItemIndex := jcbAudit.Items.Count - 1
  414. else
  415. FProjectData.ResetPhaseDataLink;
  416. jcbAudit.Enabled := jcbAudit.Items.Count > 0;
  417. end;
  418. procedure TProjectFrame.jcbAuditChanged(Sender: TObject);
  419. begin
  420. if FProjectData.PhaseData.StageIndex = jcbAudit.ItemIndex then Exit;
  421. FProjectData.StageIndex := jcbAudit.ItemIndex;
  422. RefreshProjectState;
  423. end;
  424. procedure TProjectFrame.dxsbViewControlItemClick(Sender: TObject;
  425. Item: TdxSideBarItem);
  426. procedure BeforeChangeView;
  427. begin
  428. if G_IsCloud then
  429. begin
  430. tobtnShowChecker.Visible := ProjectData.PhaseIndex > 0;
  431. tobtnShowChecker.Enabled := (Item.Tag = xbiBillsMeasure.Tag);
  432. ButtonControl_NewPhase;
  433. if Item.Tag = xbiBillsCompile.Tag then
  434. begin
  435. if tobtnShowChecker.Down then
  436. begin
  437. tobtnShowChecker.Down := False;
  438. tobtnShowChecker.Click;
  439. tobtnStandardBills.Down := True;
  440. tobtnStandardBills.Click;
  441. tobtnStandardBills.Down := False;
  442. tobtnStandardBills.Click;
  443. end;
  444. end;
  445. end;
  446. // 记录台账分解、计量台账等的右侧展开情况
  447. if jpsAssistant.Visible then
  448. jpsMain.ActivePage.Tag := jpsAssistant.ActivePageIndex
  449. else
  450. jpsMain.ActivePage.Tag := -1;
  451. end;
  452. procedure AfterChangeView;
  453. begin
  454. // 仅计量台账界面可以选择计量期
  455. pnlPhaseSelect.Visible := Item.Tag = xbiBillsMeasure.Tag;
  456. // 台账分解、计量台账、审核比较 可使用"显示至"功能
  457. tbExpand.Visible := (Item.Tag = xbiBillsCompile.Tag)
  458. or (Item.Tag = xbiBillsMeasure.Tag)
  459. or (Item.Tag = xbiStageCompare.Tag);
  460. // 右侧按钮是否显示
  461. tbToolsButton.Visible := (Item.Tag = xbiBillsCompile.Tag)
  462. or (Item.Tag = xbiBillsMeasure.Tag);
  463. tobtnBGL.Visible := Item.Tag = xbiBillsMeasure.Tag;
  464. tobtnZJJL.Visible := Item.Tag = xbiBillsMeasure.Tag;
  465. // 控制整个按钮工具栏显示,
  466. pnlToolBar.Visible := pnlPhaseSelect.Visible or tbExpand.Visible or tbToolsButton.Visible;
  467. // 根据当前View控制右侧按钮是否按下,右侧工具窗是否弹开
  468. jpsAssistant.ActivePageIndex := jpsMain.ActivePage.Tag;
  469. sbtnExpend.Tag := jpsMain.ActivePage.Tag;
  470. ControlAssistantButtonsDown(jpsMain.ActivePage.Tag);
  471. SetAssistantViewVisible(jpsMain.ActivePage.Tag <> -1);
  472. SetImageOfsbtnExpend(jpsMain.ActivePage.Tag <> -1);
  473. // 0号台账与计量台账的书签不同
  474. if Item.Tag = xbiBillsCompile.Tag then
  475. FBookmarkFrame.BMType := bmtCompile
  476. else if Item.Tag = xbiBillsMeasure.Tag then
  477. FBookmarkFrame.BMType := bmtMeasure;
  478. // 0号台账与计量台账的查找定位不同
  479. if Item.Tag = xbiBillsCompile.Tag then
  480. FSearchFrame.LocateType := ltCompile
  481. else if Item.Tag = xbiBillsMeasure.Tag then
  482. FSearchFrame.LocateType := ltMeasure;
  483. // 切换至清单汇总,须重新汇总
  484. if Item.Tag = xbiBillsGather.Tag then
  485. BillsGatherFrame.RefreshBills;
  486. // 切换至材料调差,须重新汇总展示调差清单
  487. if Item.Tag = xbiPriceMargin.Tag then
  488. PriceMarginFrame.RefreshBills;
  489. if G_IsCloud then
  490. begin
  491. if (Item.Tag = xbiBillsCompile.Tag) or (Item.Tag = xbiBillsMeasure.Tag) then
  492. CheckUpFile;
  493. tobtnUpFile.Visible := (Item.Tag = xbiBillsMeasure.Tag){ and (not ProjectData.IsGuest)};
  494. if (tobtnUpFile.Visible = False) and (jpsAssistant.ActivePage = jpsAssistantUpFile) then
  495. jpsAssistant.ActivePage := jpsAssistantStandardBills;
  496. end;
  497. end;
  498. (*
  499. procedure ChangeView;
  500. begin
  501. BeforeChangeView;
  502. case Item.Tag of
  503. 0, 2: jpsMain.ActivePageIndex := Item.Tag;
  504. 1, 3, 5: if CheckMeasureEdition then jpsMain.ActivePageIndex := Item.Tag;
  505. end;
  506. AfterChangeView;
  507. end;
  508. *)
  509. procedure ClearOldReports(AReportsPath: string);
  510. var
  511. SRec: TSearchRec;
  512. iRetval, iPos: Integer;
  513. vHead7: TScFile7Head;
  514. sProp, sFile, sPath: string;
  515. vFS: TFileStream;
  516. begin
  517. iRetval := FindFirst(AReportsPath + '*.srt', faAnyFile, sRec);
  518. try
  519. while iRetval = 0 do
  520. begin
  521. if (SRec.Attr and faDirectory) = 0 then
  522. begin
  523. sFile := AReportsPath + SRec.Name;
  524. vFS := TFileStream.Create(sFile, fmOpenRead);
  525. try
  526. vFS.Read(vHead7, SizeOf(vHead7));
  527. finally
  528. vFS.Free;
  529. end;
  530. SetString(sProp, vHead7.ReportProperties, 256);
  531. iPos := Pos('报表ID=', sProp);
  532. if iPos <= 0 then
  533. DeleteFile(PChar(sFile));
  534. end;
  535. iRetval := FindNext(SRec);
  536. end;
  537. finally
  538. SysUtils.FindClose(SRec);
  539. end;
  540. end;
  541. procedure DisplayReports;
  542. var vRMForm: TReportManagerForm;
  543. sPath: string;
  544. begin
  545. if G_IsCloud then
  546. begin
  547. sPath := ExtractFilePath(ParamStr(0)) + 'ReportTemplates\';
  548. ClearOldReports(sPath);
  549. if FileCount(sPath, '.srt') = 0 then
  550. begin
  551. Screen.Cursor := crHourGlass;
  552. vRMForm := TReportManagerForm.Create(nil);
  553. try
  554. vRMForm.ShowModal;
  555. finally
  556. vRMForm.Free;
  557. Screen.Cursor := crDefault;
  558. end;
  559. end;
  560. end;
  561. // 准备数据
  562. if Item.Tag = xbiReport.Tag then
  563. FProjectData.CopyPhaseData;
  564. // 显示报表界面
  565. DisplayReportsForm(FProjectData);
  566. dxsbViewControl.SelectedItem := dxsbViewControl.ActiveGroup.Items[jpsMain.ActivePageIndex];
  567. end;
  568. procedure DisplayCompare;
  569. begin
  570. if FProjectData.ProjProperties.PhaseCount = 0 then
  571. begin
  572. ErrorMessage('当前项目未开始计量,暂无审批比较数据!');
  573. dxsbViewControl.SelectedItem := dxsbViewControl.ActiveGroup.Items[jpsMain.ActivePageIndex];
  574. Abort;
  575. end;
  576. ShowProgressHint('正在准备审批比较数据,请稍候...');
  577. Screen.Cursor := crHourGlass;
  578. try
  579. BeforeChangeView;
  580. if CheckMeasureEdition then
  581. begin
  582. OpenCompare;
  583. jpsMain.ActivePageIndex := Item.Tag;
  584. end;
  585. AfterChangeView;
  586. finally
  587. Screen.Cursor := crDefault;
  588. CloseProgressHint;
  589. end;
  590. end;
  591. procedure DisplayPriceMargin;
  592. var
  593. vPM_Node: TsdIDTreeNode;
  594. begin
  595. vPM_Node := FProjectData.BillsCompileData.BillsCompileTree.FindNode(iPriceMarginID);
  596. {if not Assigned(vPM_Node) then
  597. begin
  598. ErrorMessage('台账中无预定义价差节点,不可使用价差功能。');
  599. dxsbViewControl.SelectedItem := dxsbViewControl.ActiveGroup.Items[jpsMain.ActivePageIndex];
  600. Abort;
  601. end
  602. else }if ProjectData.ProjProperties.PhaseCount = 0 then
  603. begin
  604. TipMessage('未计量前不可进行材料调差。');
  605. dxsbViewControl.SelectedItem := dxsbViewControl.ActiveGroup.Items[jpsMain.ActivePageIndex];
  606. Abort;
  607. end;
  608. ChangeView(Item.Tag);
  609. end;
  610. var
  611. bCloseCompare: Boolean;
  612. begin
  613. if Item.Tag = jpsMain.ActivePageIndex then Exit;
  614. bCloseCompare := (Item.Tag in [0..3, 5]) and (jpsMain.ActivePageIndex = 4);
  615. case Item.Tag of
  616. 0..2, 5: ChangeView(Item.Tag);
  617. 3: DisplayPriceMargin;
  618. 4: DisplayCompare;
  619. 6: DisplayReports;
  620. end;
  621. if bCloseCompare then
  622. CloseCompare;
  623. end;
  624. procedure TProjectFrame.CreateBillsFrame;
  625. begin
  626. FBillsCompileFrame := TBillsCompileFrame.Create(Self, FProjectData.BillsCompileData);
  627. FBillsCompileFrame.ShowDesignQuantity := FProjectData.ProjProperties.ShowDesignQuantity;
  628. FBillsCompileFrame.ShowAlias := FProjectData.ProjProperties.ShowAlias;
  629. FBillsCompileFrame.ShowApprovalCode := FProjectData.ProjProperties.ShowApprovalCode;
  630. FBillsCompileFrame.OnAfterSetBookmark := ExpandBookmarkFrame;
  631. AlignControl(FBillsCompileFrame, jpsMainBillsCompile, alClient);
  632. UpdateSysProgress(65, '正在解析数据');
  633. FBillsMeasureFrame := TBillsMeasureFrame.Create(Self, FProjectData.BillsMeasureData);
  634. FBillsMeasureFrame.OnAfterSetBookmark := ExpandBookmarkFrame;
  635. FBillsMeasureFrame.OnLocateZJJL := LocateZJJL;
  636. FBillsMeasureFrame.ShowPriceChange := FProjectData.ProjProperties.ShowPriceChange;
  637. FBillsMeasureFrame.ShowBGLCode := FProjectData.ProjProperties.ShowBGLCode;
  638. FBillsMeasureFrame.ShowDesignQuantity := FProjectData.ProjProperties.ShowDesignQuantity;
  639. FBillsMeasureFrame.ShowAlias := FProjectData.ProjProperties.ShowAlias;
  640. FBillsMeasureFrame.ShowApprovalCode := FProjectData.ProjProperties.ShowApprovalCode;
  641. FBillsMeasureFrame.ShowIsGather := True;
  642. AlignControl(FBillsMeasureFrame, jpsMainBillsMeasure, alClient);
  643. end;
  644. procedure TProjectFrame.CreateDealPaymentFrame;
  645. begin
  646. FDealPaymentFrame := TDealPaymentFrame.Create(Self, FProjectData.DealPaymentData);
  647. AlignControl(FDealPaymentFrame, jpsAssistantDealPayment, alClient);
  648. end;
  649. procedure TProjectFrame.CreateBillsGatherFrame;
  650. begin
  651. FBillsGatherFrame := TBillsGatherFrame.Create(Self, FProjectData.BillsGatherData);
  652. AlignControl(FBillsGatherFrame, jpsMainBillsGather, alClient);
  653. FBillsGatherFrame.ShowPriceChange := FProjectData.ProjProperties.ShowPriceChange;
  654. FBillsGatherFrame.ShowPhaseData := FProjectData.ProjProperties.PhaseCount > 0;
  655. FBillsGatherFrame.OnLocateMeasureBills := LocateMeasureBills;
  656. FBillsGatherFrame.OnLocateCompileBills := LocateCompileBills;
  657. end;
  658. procedure TProjectFrame.dxpmExpandBillsPopup(Sender: TObject);
  659. begin
  660. dxpmExpandBills.ItemLinks.Items[8].Visible := _IsDebugView;
  661. dxpmExpandBills.ItemLinks.Items[7].Visible := jpsMain.ActivePageIndex in [0, 1, 4];
  662. dxpmExpandBills.ItemLinks.Items[6].Visible := jpsMain.ActivePageIndex in [1, 4];
  663. SetDxBtnAction(actnFirstLevel, MainForm.dxbtnFirstLevel);
  664. SetDxBtnAction(actnSecondLevel, MainForm.dxbtnSecondLevel);
  665. SetDxBtnAction(actnThirdLevel, MainForm.dxbtnThirdLevel);
  666. SetDxBtnAction(actnFourthLevel, MainForm.dxbtnFourthLevel);
  667. SetDxBtnAction(actnFifthLevel, MainForm.dxbtnFifthLevel);
  668. SetDxBtnAction(actnAllLevel, MainForm.dxbtnAllLevel);
  669. SetDxBtnAction(actnCurPhase, MainForm.dxbtnCurPhase);
  670. SetDxBtnAction(actnAllXmj, MainForm.dxbtnAllXmj);
  671. SetDxBtnAction(actnAllPeg, MainForm.dxbtnAllPeg);
  672. end;
  673. procedure TProjectFrame.actnFirstLevelExecute(Sender: TObject);
  674. begin
  675. ExpandNodeTo(TAction(Sender).Tag);
  676. end;
  677. procedure TProjectFrame.tbExpandClick(Sender: TObject);
  678. var
  679. P: TPoint;
  680. begin
  681. P := pnlToolBar.ClientToScreen(Point(tbExpand.Left, tbExpand.Top + tbExpand.Height));
  682. dxpmExpandBills.Popup(P.X, P.Y);
  683. end;
  684. procedure TProjectFrame.actnAllXmjExecute(Sender: TObject);
  685. begin
  686. ExpandAllXmj;
  687. end;
  688. procedure TProjectFrame.ExpandNodeTo(ALevel: Integer);
  689. begin
  690. Screen.Cursor := crHourGlass;
  691. case ALevel of
  692. 0..4: UpdateSysProgress(0, Format('正在显示至第%d层', [ALevel + 1]));
  693. else UpdateSysProgress(0, '正在显示至最底层');
  694. end;
  695. try
  696. case jpsMain.ActivePageIndex of
  697. 0: FBillsCompileFrame.ExpandNodeTo(ALevel);
  698. 1: FBillsMeasureFrame.ExpandNodeTo(ALevel);
  699. 4: FPhaseCompareFrame.ExpandNodeTo(ALevel);
  700. end;
  701. finally
  702. UpdateSysProgress(0, '就绪');
  703. Screen.Cursor := crDefault;
  704. end;
  705. end;
  706. procedure TProjectFrame.ExpandAllXmj;
  707. begin
  708. Screen.Cursor := crHourGlass;
  709. UpdateSysProgress(0, '正在显示至项目节');
  710. try
  711. case jpsMain.ActivePageIndex of
  712. 0: FBillsCompileFrame.ExpandXmjNode;
  713. 1: FBillsMeasureFrame.ExpandXmjNode;
  714. 4: FPhaseCompareFrame.ExpandXmjNode;
  715. end;
  716. finally
  717. UpdateSysProgress(0, '就绪');
  718. Screen.Cursor := crDefault;
  719. end;
  720. end;
  721. procedure TProjectFrame.UnLockData;
  722. procedure DoUnLockData;
  723. begin
  724. FProjectData.CanUnlockInfo := True;
  725. FBillsCompileFrame.stdBillsCompile.Column('LockedInfo').ReadOnly := False;
  726. //FProjectData.BillsData.UnLockedBaseData;
  727. end;
  728. begin
  729. if FProjectData.CheckPassword then
  730. DoUnLockData;
  731. end;
  732. procedure TProjectFrame.CreateCheckerFrame;
  733. begin
  734. FCheckerFrame := TCheckerFrame.Create(Self);
  735. FCheckerFrame.Owner := Self;
  736. FCheckerFrame.ProjectData := FProjectData;
  737. AlignControl(FCheckerFrame, jpsAssistantChecker, alClient);
  738. FCheckerFrame.Init;
  739. end;
  740. procedure TProjectFrame.btnSubmitClick(Sender: TObject);
  741. begin
  742. if not CheckCanReport then Exit;
  743. Screen.Cursor := crHourGlass;
  744. try
  745. UpToWeb(True);
  746. finally
  747. Screen.Cursor := crDefault;
  748. end;
  749. end;
  750. procedure TProjectFrame.btnPassClick(Sender: TObject);
  751. begin
  752. btnSubmitClick(Sender);
  753. end;
  754. function TProjectFrame.IsUped: Boolean; // 是否上传过
  755. begin
  756. Result := False;
  757. // 只有0号台帐那肯定没上传过
  758. if ProjectData.PhaseIndex = 0 then Exit;
  759. // 当前期是旧期
  760. if ProjectData.IsHistoryPhase then
  761. Result := True
  762. // 当前显示的期是最新期,分两种情况判断,如果第一审核人已有状态,则上传过了
  763. else
  764. begin
  765. // 当用户点击新增一期计量后,会调用该方法,此时,有一期数据,却为上传过
  766. if not Assigned(CheckerFrame) then
  767. Result := False
  768. else if not CheckerFrame.HasChecker then
  769. Result := False
  770. else if CheckerFrame.FirstChecker.CheckStatus = csNotBegin then
  771. Result := False
  772. else
  773. Result := True;
  774. end;
  775. end;
  776. procedure TProjectFrame.ButtonControl_UpToWeb;
  777. begin
  778. if ProjectData.CurUserIsAuthor then
  779. begin
  780. btnSubmit.Visible := True;
  781. // 有计量(非0号台账状态),且当前计量期尚未上报过
  782. btnSubmit.Enabled := (ProjectData.PhaseIndex > 0) and (not IsUped);
  783. btnPass.Visible := False;
  784. btnNotPass.Visible := btnPass.Visible;
  785. btnSubmit.Left := jcbAudit.Left + jcbAudit.Width + 5;
  786. end
  787. else if ProjectData.CurUserIsOwner or ProjectData.CurUserIsChecker then
  788. begin
  789. btnSubmit.Visible := False;
  790. btnPass.Visible := True;
  791. btnNotPass.Visible := btnPass.Visible;
  792. // 在本期我是审核人,切换到历史期有可能我没参与。 所以当CheckerFrame.Me为空时,有可能我是编制人,有可能历史期我没参与。
  793. // 历史期,管你那么多,直接按钮不见。
  794. if ProjectData.PhaseIndex < ProjectData.ProjProperties.PhaseCount then
  795. btnPass.Enabled := False
  796. else
  797. begin
  798. if CheckerFrame.Me <> nil then
  799. btnPass.Enabled := CheckerFrame.Me.IsChecking
  800. else // 游客,关注人身份
  801. btnPass.Enabled := False;
  802. end;
  803. btnNotPass.Enabled := btnPass.Enabled;
  804. btnPass.Left := jcbAudit.Left + jcbAudit.Width + 5;
  805. btnNotPass.Left := btnPass.Left + btnPass.Width + 1;
  806. end;
  807. ShowPhaseHint;
  808. if Assigned(FCheckerFrame) then
  809. FCheckerFrame.RepairDelete(btnSubmit.Visible and btnSubmit.Enabled);
  810. end;
  811. procedure TProjectFrame.UpToWeb(ACheckPassed: Boolean);
  812. var sURL, sAppFile, sJsonFile_Bills, sJsonFile_Common, sAppFile_UnLock,
  813. sZipFile, sResult, sMD5_JL, sPassedHint1, sPassedHint2,
  814. sNoPassedHint1, sNoPassedHint2, sCheckerMemo: string;
  815. vA, vArr: array of string;
  816. vRec: TsdDataRecord;
  817. bSubmit: Boolean;
  818. vExportor: TTenderExport;
  819. vCF: TCheckerMemoForm;
  820. bNeedFreeEarlier: Boolean;
  821. // 1 审核; 2 批复。
  822. function SaveAndExport(AType: Integer): Boolean;
  823. function InnerSubmit(AType: Integer): Boolean;
  824. begin
  825. if AType = 1 then
  826. Result := ProjectData.SubmitProject(sAppFile)
  827. else if AType = 2 then
  828. Result := ProjectData.ReplyProject(sAppFile);
  829. end;
  830. begin
  831. Result := False;
  832. ProgressProCreate(100, '本地数据文件上传到云端');
  833. ProgressProRun('保存本地数据...', 0);
  834. ProjectData.Checkers.LastChecker := ProjectData.Checkers.FindByID(PHPWeb.UserID);
  835. ProjectData.SaveAndCheck;
  836. ProgressProRun('保存本地数据。OK', 10, pmtEdit);
  837. ProgressProRun('导出并检验文件...', 0);
  838. if not InnerSubmit(AType) then
  839. if not InnerSubmit(AType) then
  840. begin
  841. bNeedFreeEarlier := True;
  842. Application.MessageBox('Sorry!本地文件连续2次导出检验失败!如果重试后仍不能解决该问题,请联系纵横客服。', '提示', MB_OK + MB_ICONWARNING);
  843. Exit;
  844. end;
  845. Result := True;
  846. ProgressProRun('导出并检验文件。OK', 10, pmtEdit);
  847. end;
  848. begin
  849. bSubmit := False;
  850. bNeedFreeEarlier := False;
  851. sAppFile := PHPWeb.UserPath + 'ProjectFile.rmf';
  852. // 只有编制人才真正需要该文件存在
  853. // sAppFile_UnLock := PHPWeb.UserPath + 'ProjectFile_UnLock';
  854. sPassedHint1 :=
  855. '【审批通过】后,计量数据将自动交付给下一审批人进行审批,操作后将不可更改,是否通过审批?';
  856. sPassedHint2 :=
  857. '(终审)审批通过后本期计量审批将标记为审批完成,操作后将不可更改,是否通过审批?';
  858. sNoPassedHint1 :=
  859. '【审批不通过】后,本次审批将结束,后续的审批人也将不会审批本次计量,' +
  860. '本期数据也将直接打回给上报人进行重新计量报审。' + #10#13 +
  861. '点击【确定】进入操作确认。';
  862. sNoPassedHint2 := PHPWeb.RealName +
  863. ',请确认本期计量审批不通过。' + #10#13 + '点击【确定】本期计量审批' +
  864. '不通过,计量将不可再更改。';
  865. vCF := TCheckerMemoForm.Create(nil);
  866. try
  867. if ProjectData.CurUserIsAuthor then
  868. begin
  869. bSubmit := True;
  870. if not CheckerFrame.HasNormalChecker then
  871. begin
  872. Application.MessageBox('上报审批前请先配置审批人!', '提示', MB_OK + MB_ICONWARNING);
  873. tobtnShowChecker.Down := True;
  874. tobtnShowChecker.Click;
  875. Exit;
  876. end;
  877. // 保存一次缓存数据,以保证提示信息能读取正确的值
  878. ProjectData.SaveLastestPhaseMainData;
  879. if Application.MessageBox(PChar(CheckersHint), '询问', MB_YESNO + MB_ICONQUESTION) = ID_No then
  880. Exit;
  881. if not SaveAndExport(1) then Exit;
  882. end
  883. else if ProjectData.CurUserIsChecker then
  884. begin
  885. if ACheckPassed then
  886. begin
  887. vCF.Init(sPassedHint1, 1);
  888. if vCF.ShowModal = mrCancel then
  889. Exit
  890. else
  891. sCheckerMemo := vCF.Memo;
  892. end
  893. else
  894. begin
  895. vCF.Init(sNoPassedHint1, 0);
  896. if vCF.ShowModal = mrCancel then
  897. Exit
  898. else
  899. sCheckerMemo := vCF.Memo;
  900. if Application.MessageBox(PChar(sNoPassedHint2), '询问', MB_OKCANCEL + MB_ICONQUESTION) = ID_CANCEL then
  901. Exit;
  902. end;
  903. if not SaveAndExport(1) then Exit;
  904. end
  905. else if ProjectData.CurUserIsOwner then
  906. begin
  907. if ACheckPassed then
  908. begin
  909. vCF.Init(sPassedHint2, 1);
  910. if vCF.ShowModal = mrCancel then
  911. Exit
  912. else
  913. sCheckerMemo := vCF.Memo;
  914. end
  915. else
  916. begin
  917. vCF.Init(sNoPassedHint1, 0);
  918. if vCF.ShowModal = mrCancel then
  919. Exit
  920. else
  921. sCheckerMemo := vCF.Memo;
  922. if not QuestMessage(sNoPassedHint2) then
  923. Exit;
  924. end;
  925. if not SaveAndExport(2) then Exit;
  926. end;
  927. finally
  928. vCF.Free;
  929. if bNeedFreeEarlier then
  930. ProgressProFree;
  931. end;
  932. try
  933. ProgressProRun('生成汇总数据...', 0);
  934. sJsonFile_Bills := ExtractFilePath(sAppFile) + 'JsonFile_Bills.json';
  935. sJsonFile_Common := ExtractFilePath(sAppFile) + 'JsonFile_Common.json';
  936. sMD5_JL := MD5_File(sAppFile);
  937. // 上传清单,每期都传,可覆盖旧的。
  938. ProjectData.ExportJson_Bills(sJsonFile_Bills);
  939. ProjectData.ExportJson_Common(sJsonFile_Common);
  940. ProgressProRun('生成汇总数据。OK', 10, pmtEdit);
  941. ProgressProRun('生成并检验up数据包文件...', 0);
  942. sZipFile := PHPWeb.zip([sAppFile, sJsonFile_Bills, sJsonFile_Common]);
  943. if not PHPWeb.CheckZip(sZipFile, 3) then
  944. begin
  945. WarningMessage('up数据包无法正确解压检验,请重试!如果重试后仍不能解决该问题,请联系纵横客服。', ProgressProHandle);
  946. Exit;
  947. end;
  948. ProgressProRun('校验数据包。OK', 10, pmtEdit);
  949. try
  950. ProgressProRun('上传数据包到云端...(温馨提示:请不要乱点哦,Windows容易死机)', 0);
  951. if PHPWeb.UpDataFile(PHPWeb.UserID, ProjectData.WebID, ProjectData.PhaseIndex,
  952. sZipFile, sMD5_JL, bSubmit, sResult, ACheckPassed, sCheckerMemo) then
  953. begin
  954. DeleteFile(sAppFile);
  955. ProgressProRun('上传数据包到云端。OK', 100, pmtEdit, pptSet);
  956. if ProjectData.CurUserIsChecker then
  957. begin
  958. ProjectData.Checkers.FindByID(PHPWeb.UserID).Memo := sCheckerMemo;
  959. end;
  960. if ProjectData.PhaseIndex = 0 then // 0号台账,现已废弃
  961. begin
  962. MainForm.ProjectManagerFrame.ShowProjectInfoTop(0);
  963. end
  964. else
  965. Begin
  966. vRec := MainForm.ProjectManagerFrame.Rec(ProjectData.ProjectID);
  967. vRec.BeginUpdate;
  968. vRec.ValueByName('WebMD5').AsString := sMD5_JL;
  969. if ProjectData.CurUserIsOwner then
  970. vRec.ValueByName('AuditStatus').AsInteger := -1;
  971. vRec.EndUpdate;
  972. MainForm.ProjectManagerFrame.ShowProjectInfoTop;
  973. if ProjectData.CurUserIsAuthor then
  974. begin
  975. CheckerFrame.FirstChecker.CheckStatus := csChecking;
  976. CheckerFrame.AddFrame.Visible := False;
  977. end
  978. else
  979. begin
  980. if ACheckPassed then
  981. begin
  982. CheckerFrame.Me.CheckStatus := csFinished;
  983. if ProjectData.CurUserIsChecker then
  984. CheckerFrame.NextChecker.CheckStatus := csChecking;
  985. end
  986. else
  987. CheckerFrame.Me.CheckStatus := csNotPass;
  988. CheckerFrame.Me.CheckerMemo := sCheckerMemo;
  989. CheckerFrame.Me.CheckedTime := Format('[%s][线下审批]',[DateToStr(Date)]);
  990. end;
  991. end;
  992. btnSubmit.Enabled := False;
  993. FCheckerFrame.RepairDelete(False);
  994. btnPass.Enabled := False;
  995. btnNotPass.Enabled := btnPass.Enabled;
  996. ShowPhaseHint;
  997. ProgressProHide;
  998. TipMessage('^_^ 恭喜!数据已成功上传到云端服务器。', ProgressProHandle);
  999. end
  1000. else
  1001. begin
  1002. ProgressProHide;
  1003. WarningMessage('数据无法上传:' + sResult, ProgressProHandle);
  1004. if Pos('审批完毕', sResult) > 0 then
  1005. begin
  1006. btnSubmit.Enabled := False;
  1007. btnPass.Enabled := False;
  1008. btnNotPass.Enabled := btnPass.Enabled;
  1009. end;
  1010. end;
  1011. except
  1012. ProgressProHide;
  1013. WarningMessage('与服务器断开连接,请稍后重试。' + sResult, ProgressProHandle);
  1014. end;
  1015. finally
  1016. ProgressProFree;
  1017. end;
  1018. end;
  1019. procedure TProjectFrame.btnNotPassClick(Sender: TObject);
  1020. begin
  1021. Screen.Cursor := crHourGlass;
  1022. try
  1023. UpToWeb(False);
  1024. finally
  1025. Screen.Cursor := crDefault;
  1026. end;
  1027. end;
  1028. function TProjectFrame.CheckersHint: string;
  1029. var vSL: TStringList;
  1030. i: Integer;
  1031. sChecker, sChar: string;
  1032. Rec: TsdDataRecord;
  1033. begin
  1034. vSL := TStringList.Create;
  1035. try
  1036. CheckerFrame.CheckerNameList(vSL);
  1037. for i := 0 to vSL.Count - 1 do
  1038. begin
  1039. if i = 0 then
  1040. sChar := ''
  1041. else
  1042. sChar := ' > ';
  1043. sChecker := sChecker + sChar + vSL[i];
  1044. end;
  1045. while Length(sChecker) < 38 do // 保证提示框的大小达到最佳效果
  1046. sChecker := sChecker + ' ';
  1047. Rec := ProjectData.MainListData.GetPhaseMainRecord(FProjectData.PhaseIndex);
  1048. Result := Format('本期计量:%m元。%s审批流程:%s%s上报后将不可更改,确定要上报吗?',
  1049. [Rec.ValueByName('GatherTotalPrice').AsFloat, #10#13#10#13, sChecker, #10#13#10#13]);
  1050. finally
  1051. vSL.Free;
  1052. end;
  1053. end;
  1054. procedure TProjectFrame.btnNewPhaseClick(Sender: TObject);
  1055. begin
  1056. if not CreateNewPhase then Exit;
  1057. dxsbViewControl.SelectedItem := dxsbViewControl.Groups[0].Items[1];
  1058. dxsbViewControl.OnItemClick(Sender, dxsbViewControl.Groups[0].Items[1]);
  1059. end;
  1060. procedure TProjectFrame.ButtonControl_NewPhase;
  1061. var b1, b2, b3: Boolean;
  1062. begin
  1063. // “新建一期计量”按钮的显示隐藏
  1064. // 计量界面,且是原报才显示
  1065. b1 := (dxsbViewControl.SelectedItem.Index = 0) and ProjectData.CurUserIsAuthor;
  1066. // ①尚无审核人列表 ②当前期已审核完成
  1067. b2 := (not Assigned(CheckerFrame)) or (Assigned(CheckerFrame) and CheckerFrame.OwnerFrame.IsFinished);
  1068. // 当前查看的是最新期。查看历史期不显示。
  1069. b3 := (FProjectData.ProjProperties.PhaseCount = FProjectData.PhaseIndex);
  1070. pnlNewPhase.Visible := b1 and b2 and b3;
  1071. end;
  1072. procedure TProjectFrame.actnCurPhaseExecute(Sender: TObject);
  1073. begin
  1074. ExpandCurPhase;
  1075. end;
  1076. procedure TProjectFrame.RepairAudits;
  1077. var i, iSel: Integer;
  1078. UserArr: array of string;
  1079. sURL: string;
  1080. begin
  1081. jcbAudit.ItemHeight := 20;
  1082. jcbAudit.Font.Name := '微软雅黑';
  1083. jcbAudit.Font.Size := 10;
  1084. jcbAudit.DropDownBox.Height := jcbAudit.Items.Count * jcbAudit.ItemHeight + 35;
  1085. iSel := jcbAudit.ItemIndex;
  1086. for i := 0 to jcbAudit.Items.Count - 1 do
  1087. begin
  1088. if i = 0 then
  1089. begin
  1090. // 原报:编制人。没有跟审核人一个表,另外查询。个人觉得这里设计得不好。
  1091. // 打开软件时自动扫描,杰哥那头返回不了编制人的项目,也是这个原因。
  1092. // 说服不了特工,先这样吧。
  1093. sURL := Format('%suser/get/%d/info', [PHPWeb.MeasureURL, FProjectData.WebAuthorID]);
  1094. UserArr := VarArrayOf(['avatar', 'name', 'jobs', 'company']);
  1095. if PHPWeb.Search(sURL, [], [], UserArr) = 1 then
  1096. jcbAudit.Items[i] := jcbAudit.Items[i] + ' ' + UserArr[1] + '-' + UserArr[2];
  1097. end
  1098. else
  1099. begin
  1100. // 某种漏洞的操作下,文件中记载的审核人数和审核人列表中的审核人数不一致,
  1101. // 匹配时会溢出。这里要加判断。
  1102. if i > CheckerFrame.List.Count then Break;
  1103. if TOrderCheckerFrame(CheckerFrame.List[i - 1]) = FCheckerFrame.OwnerFrame then
  1104. begin
  1105. jcbAudit.Items[i] := ' 终审 ' +
  1106. TOrderCheckerFrame(CheckerFrame.List[i - 1]).UserName + '-' +
  1107. TOrderCheckerFrame(CheckerFrame.List[i - 1]).UserRole
  1108. end
  1109. else
  1110. begin
  1111. jcbAudit.Items[i] := jcbAudit.Items[i] + ' ' +
  1112. TOrderCheckerFrame(CheckerFrame.List[i - 1]).UserName + '-' +
  1113. TOrderCheckerFrame(CheckerFrame.List[i - 1]).UserRole;
  1114. end;
  1115. end;
  1116. end;
  1117. jcbAudit.ItemIndex := iSel;
  1118. end;
  1119. procedure TProjectFrame.CreateFrames;
  1120. begin
  1121. UpdateSysProgress(10, '正在解析数据');
  1122. CreateBillsFrame;
  1123. UpdateSysProgress(130, '正在解析数据');
  1124. CreateDealPaymentFrame;
  1125. UpdateSysProgress(135, '正在解析数据');
  1126. CreateBillsGatherFrame;
  1127. UpdateSysProgress(140, '正在解析数据');
  1128. CreatePriceMarginFrame;
  1129. UpdateSysProgress(145, '正在解析数据');
  1130. FOtherMeasureFrame := TOtherMeasureFrame.Create(FProjectData);
  1131. AlignControl(FOtherMeasureFrame, jpsMainOtherMeasure, alClient);
  1132. UpdateSysProgress(150, '正在解析数据');
  1133. FZJJLFrame := TZJJLFrame.Create(Self, FProjectData.PhaseData.ZJJLData);
  1134. FZJJLFrame.DataReadOnly := FProjectData.PhaseData.StageDataReadOnly;
  1135. AlignControl(FZJJLFrame, jpsAssistantZJJL, alClient);
  1136. UpdateSysProgress(160, '正在解析数据');
  1137. FBGLFrame := TBGLFrame.Create(Self, FProjectData.BGLData);
  1138. AlignControl(FBGLFrame, jpsAssistantBGL, alClient);
  1139. UpdateSysProgress(170, '正在解析数据');
  1140. FSearchFrame := TSearchFrame.Create(Self, FProjectData.SearchData);
  1141. AlignControl(FSearchFrame, jpsAssistantSearch, alClient);
  1142. UpdateSysProgress(180, '正在解析数据');
  1143. FBookmarkFrame := TBookmarkFrame.Create(Self, FProjectData);
  1144. AlignControl(FBookmarkFrame, jpsAssistantBookmark, alClient);
  1145. UpdateSysProgress(190, '正在解析数据');
  1146. FDealBillsFrame := TDealBillsFrame.Create(Self, FProjectData.DealBillsData);
  1147. AlignControl(FDealBillsFrame, jpsAssistantDealBills, alClient);
  1148. UpdateSysProgress(200, '就绪');
  1149. end;
  1150. procedure TProjectFrame.InitialForVersions;
  1151. begin
  1152. if _ModuleType = mtCompile then
  1153. begin
  1154. // 去掉审核比较
  1155. dxsbViewControl.Groups.Items[0].Items.Delete(3);
  1156. // 去掉计量台账
  1157. dxsbViewControl.Groups.Items[0].Items.Delete(1);
  1158. end;
  1159. end;
  1160. procedure TProjectFrame.ExpandBookmarkFrame(AExpandFrame: Boolean);
  1161. begin
  1162. // 展开书签
  1163. if AExpandFrame then
  1164. begin
  1165. jpsAssistant.ActivePageIndex := tobtnBookmark.Tag;
  1166. sbtnExpend.Tag := tobtnBookmark.Tag;
  1167. ControlAssistantButtonsDown(tobtnBookmark.Tag);
  1168. jpsMain.ActivePage.Tag := tobtnBookmark.Tag;
  1169. SetAssistantViewVisible(True);
  1170. SetImageOfsbtnExpend(True);
  1171. end;
  1172. // 刷新书签批注
  1173. FBookmarkFrame.RefreshMarkMemo;
  1174. end;
  1175. {
  1176. 在意外情况下,文件中记录的审核人与云端记录的审核人不一致,文件中的审核表有时
  1177. 被多创建,有时少创建。这时不允许继续操作,需强制关闭:
  1178. 1、如果第x个人为审核中,则:
  1179. ①当前登录用户,如果非工作中,无论编制人、审核人还是业主,审核表个数应为x。
  1180. ②当前登录用户,如果工作中,必是审核人或业主,审核表个数应为x + 1。
  1181. 2、如果找不到审核中,找到了第x个人为审核不通过,则:
  1182. ①当前登录用户为编制人:
  1183. a.重新开始:审核表个数应为1。
  1184. b.仅查看不通过项目:审核表个数应为x + 1。
  1185. ②当前登录用户为审核人或业主:一定是非工作中(编制人工作中),审核表个数应为x + 1。
  1186. 3、如果找不到审核中,也找不到审核不通过,如果最后一个人是审核完成,则:
  1187. ①当前登录用户为编制人,此时编制人尚末开始新的一期,下拉还是上一期的,审核表个数亦为x+1。
  1188. ②当前登录用户为审核人或业主,审核表个数为x+1。
  1189. 4、如果找不到审核中,也找不到审核不通过,如果第一个人是末审核,则:
  1190. ①当前登录用户为编制人,审核表个数应为1。 }
  1191. function TProjectFrame.CheckFileAndCloudChekerList: Boolean;
  1192. var iNo, iC: Integer;
  1193. begin
  1194. Result := False;
  1195. iC := jcbAudit.Items.Count;
  1196. if not Assigned(FCheckerFrame) then // 0号台帐阶段还没有审核人业务
  1197. begin
  1198. Result := True;
  1199. Exit;
  1200. end;
  1201. iNo := FCheckerFrame.CheckNo(csChecking);
  1202. if iNo <> -1 then // 审核中
  1203. begin
  1204. // FCheckerFrame.Me = nil :编制 (这里体现出编制人不在审核人列表中极不合理!)
  1205. if (FCheckerFrame.Me <> nil) and FCheckerFrame.Me.IsChecking then
  1206. Result := (iC = iNo + 1)
  1207. else
  1208. Result := (iC = iNo);
  1209. end
  1210. else // 三种情况:①原报阶段,一个状态都没有 ②审核完成 ③审核不通过
  1211. begin
  1212. iNo := FCheckerFrame.CheckNo(csNotPass);
  1213. if iNo <> -1 then // 情况③,审核不通过
  1214. begin
  1215. if ProjectData.CurUserIsAuthor then
  1216. Result := ((iC = 1) or (iC = iNo + 1))
  1217. // else if FCheckerFrame.InCheckerList(PHPWeb.UserID) then // 这个条件会漏掉关注人
  1218. else
  1219. Result := (iC = iNo + 1);
  1220. end
  1221. else
  1222. begin
  1223. // 情况②,审核完成
  1224. if FCheckerFrame.LastChecker.CheckStatus = csFinished then // 最后一个人是审核完成
  1225. Result := (iC = FCheckerFrame.List.Count + 1)
  1226. else
  1227. // 情况①,原报阶段,一个状态都没有
  1228. begin
  1229. if ProjectData.CurUserIsAuthor then // 如果是原报,则只有一张表
  1230. Result := (iC = 1)
  1231. else
  1232. // 其它人时,原报尚末上传,表的数量是上一期的。
  1233. // 如果是打回,上一期的数量也是不固定的(中途打回)。反正这里只看不改,不限制。
  1234. Result := True;
  1235. end;
  1236. end;
  1237. end;
  1238. end;
  1239. procedure TProjectFrame.tobtnUpFileClick(Sender: TObject);
  1240. begin
  1241. with TToolButton(Sender) do
  1242. begin
  1243. if Down then
  1244. begin
  1245. jpsAssistant.ActivePageIndex := Tag;
  1246. sbtnExpend.Tag := Tag;
  1247. ControlAssistantButtonsDown(Tag);
  1248. jpsMain.ActivePage.Tag := Tag;
  1249. end;
  1250. SetAssistantViewVisible(Down);
  1251. SetImageOfsbtnExpend(Down);
  1252. end;
  1253. CheckUpFile;
  1254. end;
  1255. procedure TProjectFrame.CreateUpFile;
  1256. begin
  1257. FUpFileManageView := TUpFileManageView.Create(nil);
  1258. FUpFileManageView.Owner := Self;
  1259. FUpFileManageView.ProjectData := FProjectData;
  1260. FUpFileManageView.Datas := FProjectData.AttachmentData;
  1261. FUpFileManageView.Parent := jpsAssistantUpFile;
  1262. FUpFileManageView.Align := alClient;
  1263. end;
  1264. procedure TProjectFrame.SetUpFileManageView(
  1265. const Value: TUpFileManageView);
  1266. begin
  1267. FUpFileManageView := Value;
  1268. end;
  1269. procedure TProjectFrame.jpsAssistantActivePageChanged(Sender: TObject);
  1270. begin
  1271. if G_IsCloud then
  1272. CheckUpFile;
  1273. end;
  1274. procedure TProjectFrame.CheckUpFile;
  1275. var vRec: TsdDataRecord;
  1276. begin
  1277. if jpsAssistant.Visible and (jpsAssistant.ActivePage = jpsAssistantUpFile) then
  1278. begin
  1279. if jpsMain.ActivePage = jpsMainBillsCompile then
  1280. begin
  1281. vRec := FBillsCompileFrame.BillsCompileData.sdvBillsCompile.Current;
  1282. if vRec = nil then
  1283. vRec := FBillsCompileFrame.stdBillsCompile.IDTree.Items[0].Rec;
  1284. end
  1285. else if jpsMain.ActivePage = jpsMainBillsMeasure then
  1286. begin
  1287. vRec := FBillsMeasureFrame.BillsMeasureData.sdvBillsMeasure.Current;
  1288. if vRec = nil then
  1289. vRec := FBillsMeasureFrame.stdBillsMeasure.IDTree.Items[0].Rec;
  1290. end;
  1291. FUpFileManageView.DoOnBillChange(vRec);
  1292. end;
  1293. end;
  1294. procedure TProjectFrame.SaveLog(AStr: string);
  1295. var
  1296. sFileName: string;
  1297. F: TextFile;
  1298. begin
  1299. sFileName := GetAppFilePath + 'TimeLog.txt';
  1300. AssignFile(F, sFileName);
  1301. if FileExists(sFileName) then
  1302. Append(F)
  1303. else
  1304. Rewrite(F);
  1305. Writeln(F, AStr);
  1306. CloseFile(F);
  1307. end;
  1308. procedure TProjectFrame.ReLockData;
  1309. begin
  1310. FProjectData.CanUnlockInfo := False;
  1311. FBillsCompileFrame.stdBillsCompile.Column('LockedInfo').ReadOnly := True;
  1312. end;
  1313. procedure TProjectFrame.CloseCompare;
  1314. begin
  1315. FPhaseCompareFrame.Free;
  1316. FProjectData.PhaseCompareData.Close;
  1317. FProjectData.PhaseData.StageCompareData.Close;
  1318. end;
  1319. procedure TProjectFrame.OpenCompare;
  1320. begin
  1321. FProjectData.PhaseData.Save;
  1322. FProjectData.PhaseData.StageCompareData.Open;
  1323. FProjectData.PhaseCompareData.Open;
  1324. FPhaseCompareFrame := TPhaseCompareFrame.Create(Self, FProjectData.PhaseCompareData);
  1325. AlignControl(FPhaseCompareFrame, jpsMainStageCompare, alClient);
  1326. end;
  1327. procedure TProjectFrame.RefreshColumnDisplay;
  1328. begin
  1329. BillsCompileFrame.ShowDesignQuantity := FProjectData.ProjProperties.ShowDesignQuantity;
  1330. BillsCompileFrame.ShowAlias := FProjectData.ProjProperties.ShowAlias;
  1331. BillsCompileFrame.ShowApprovalCode := FProjectData.ProjProperties.ShowApprovalCode;
  1332. BillsMeasureFrame.ShowPriceChange := FProjectData.ProjProperties.ShowPriceChange;
  1333. BillsMeasureFrame.ShowBGLCode := FProjectData.ProjProperties.ShowBGLCode;
  1334. BillsMeasureFrame.ShowDesignQuantity := FProjectData.ProjProperties.ShowDesignQuantity;
  1335. BillsMeasureFrame.ShowAlias := FProjectData.ProjProperties.ShowAlias;
  1336. BillsMeasureFrame.ShowApprovalCode := FProjectData.ProjProperties.ShowApprovalCode;
  1337. BillsGatherFrame.ShowPriceChange := FProjectData.ProjProperties.ShowPriceChange;
  1338. BillsGatherFrame.zgGclBills.Invalidate;
  1339. end;
  1340. procedure TProjectFrame.RefreshProjectState;
  1341. begin
  1342. FBillsCompileFrame.RefreshPhase_Stage;
  1343. FBillsMeasureFrame.RefreshPhase_Stage;
  1344. FDealPaymentFrame.RefreshPhase_Stage;
  1345. FPriceMarginFrame.ResetViewControl;
  1346. FOtherMeasureFrame.ResetViewControl;
  1347. end;
  1348. procedure TProjectFrame.ExpandCurPhase;
  1349. begin
  1350. Screen.Cursor := crHourGlass;
  1351. UpdateSysProgress(0, '正在显示至项目节');
  1352. try
  1353. case jpsMain.ActivePageIndex of
  1354. 1: FBillsMeasureFrame.ExpandCurPhase;
  1355. 4: FPhaseCompareFrame.ExpandCurPhase;
  1356. end;
  1357. finally
  1358. UpdateSysProgress(0, '就绪');
  1359. Screen.Cursor := crDefault;
  1360. end;
  1361. end;
  1362. function TProjectFrame.CheckCanReport: Boolean;
  1363. begin
  1364. if not _IsCloud or ProjectData.CurUserIsAuthor then
  1365. Result := QuestMessageYesNo('请检查中间计量数据是否生成。')
  1366. else
  1367. Result := QuestMessageYesNo('如修改过本期计量数据,请先点击【否】完善【中间计量】窗口数据。');
  1368. // 使用控件点击进行定位,重新定义方法太复杂
  1369. if not Result then
  1370. begin
  1371. // 先定位至计量台账界面
  1372. dxsbViewControl.SelectedItem := dxsbViewControl.ActiveGroup.Items[1];
  1373. dxsbViewControlItemClick(dxsbViewControl, dxsbViewControl.ActiveGroup.Items[1]);
  1374. // 再定位至中间计量界面
  1375. tobtnZJJL.Down := True;
  1376. tobtnZJJL.Click;
  1377. end;
  1378. FZJJLFrame.GenerateZJJL;
  1379. end;
  1380. procedure TProjectFrame.actnAllPegExecute(Sender: TObject);
  1381. begin
  1382. Screen.Cursor := crHourGlass;
  1383. UpdateSysProgress(0, '正在显示至桩号(项目节)');
  1384. try
  1385. case jpsMain.ActivePageIndex of
  1386. 0: FBillsCompileFrame.ExpandPegXmjNode;
  1387. end;
  1388. finally
  1389. UpdateSysProgress(0, '就绪');
  1390. Screen.Cursor := crDefault;
  1391. end;
  1392. end;
  1393. procedure TProjectFrame.CreatePriceMarginFrame;
  1394. begin
  1395. FPriceMarginFrame := TPriceMarginFrame.Create(FProjectData);
  1396. AlignControl(FPriceMarginFrame, jpsMainPriceMargin, alClient);
  1397. end;
  1398. procedure TProjectFrame.ShowPhaseHint;
  1399. begin
  1400. pnlProjectCheckStatus.Caption := '';
  1401. if Assigned(CheckerFrame) then
  1402. begin
  1403. if CheckerFrame.FirstChecker.CheckStatus = csNotBegin then
  1404. begin
  1405. // 对于原报,要区分新建项目和打回重新开始两种情况。前者不能显示。
  1406. // 为了区分需要去服务器查询,势必影响速度。简单点,原报干脆不显示。
  1407. if not FProjectData.CurUserIsAuthor then
  1408. begin
  1409. pnlProjectCheckStatus.Caption := '本期重新开始';
  1410. pnlProjectCheckStatus.Font.Color := clRed;
  1411. end;
  1412. end
  1413. else if CheckerFrame.OwnerFrame.CheckStatus = csFinished then
  1414. begin
  1415. pnlProjectCheckStatus.Caption := '本期已完成';
  1416. pnlProjectCheckStatus.Font.Color := clGreen;
  1417. end;
  1418. end;
  1419. pnlProjectCheckStatus.Update;
  1420. end;
  1421. procedure TProjectFrame.LocateMeasureBills(AID: Integer);
  1422. var
  1423. vNode: TsdIDTreeNode;
  1424. begin
  1425. dxsbViewControl.SelectedItem := dxsbViewControl.Groups[0].Items[xbiBillsMeasure.Tag];
  1426. ChangeView(xbiBillsMeasure.Tag);
  1427. with FProjectData.BillsMeasureData do
  1428. begin
  1429. vNode := BillsMeasureTree.FindNode(AID);
  1430. if Assigned(vNode) then
  1431. sdvBillsMeasure.LocateInControl(vNode.Rec);
  1432. end;
  1433. end;
  1434. procedure TProjectFrame.ChangeView(APageIndex: Integer);
  1435. begin
  1436. BeforeChangeView(APageIndex);
  1437. case APageIndex of
  1438. 0, 2: jpsMain.ActivePageIndex := APageIndex;
  1439. 1, 3, 5: if CheckMeasureEdition then jpsMain.ActivePageIndex := APageIndex;
  1440. end;
  1441. AfterChangeView(APageIndex);
  1442. end;
  1443. procedure TProjectFrame.AfterChangeView(APageIndex: Integer);
  1444. begin
  1445. // 仅计量台账界面可以选择计量期
  1446. pnlPhaseSelect.Visible := APageIndex = xbiBillsMeasure.Tag;
  1447. // 台账分解、计量台账、审核比较 可使用"显示至"功能
  1448. tbExpand.Visible := (APageIndex = xbiBillsCompile.Tag)
  1449. or (APageIndex = xbiBillsMeasure.Tag)
  1450. or (APageIndex = xbiStageCompare.Tag);
  1451. // 右侧按钮是否显示
  1452. tbToolsButton.Visible := (APageIndex = xbiBillsCompile.Tag)
  1453. or (APageIndex = xbiBillsMeasure.Tag);
  1454. tobtnBGL.Visible := APageIndex = xbiBillsMeasure.Tag;
  1455. tobtnZJJL.Visible := APageIndex = xbiBillsMeasure.Tag;
  1456. // 控制整个按钮工具栏显示,
  1457. pnlToolBar.Visible := pnlPhaseSelect.Visible or tbExpand.Visible or tbToolsButton.Visible;
  1458. // 根据当前View控制右侧按钮是否按下,右侧工具窗是否弹开
  1459. jpsAssistant.ActivePageIndex := jpsMain.ActivePage.Tag;
  1460. sbtnExpend.Tag := jpsMain.ActivePage.Tag;
  1461. ControlAssistantButtonsDown(jpsMain.ActivePage.Tag);
  1462. SetAssistantViewVisible(jpsMain.ActivePage.Tag <> -1);
  1463. SetImageOfsbtnExpend(jpsMain.ActivePage.Tag <> -1);
  1464. // 0号台账与计量台账的书签不同
  1465. if APageIndex = xbiBillsCompile.Tag then
  1466. FBookmarkFrame.BMType := bmtCompile
  1467. else if APageIndex = xbiBillsMeasure.Tag then
  1468. FBookmarkFrame.BMType := bmtMeasure;
  1469. // 0号台账与计量台账的查找定位不同
  1470. if APageIndex = xbiBillsCompile.Tag then
  1471. FSearchFrame.LocateType := ltCompile
  1472. else if APageIndex = xbiBillsMeasure.Tag then
  1473. FSearchFrame.LocateType := ltMeasure;
  1474. // 切换至清单汇总,须重新汇总
  1475. if APageIndex = xbiBillsGather.Tag then
  1476. BillsGatherFrame.RefreshBills;
  1477. // 切换至材料调差,须重新汇总展示调差清单
  1478. if APageIndex = xbiPriceMargin.Tag then
  1479. PriceMarginFrame.RefreshBills;
  1480. if G_IsCloud then
  1481. begin
  1482. if (APageIndex = xbiBillsCompile.Tag) or (APageIndex = xbiBillsMeasure.Tag) then
  1483. CheckUpFile;
  1484. tobtnUpFile.Visible := (APageIndex = xbiBillsMeasure.Tag) {and (not ProjectData.IsGuest)};
  1485. if (tobtnUpFile.Visible = False) and (jpsAssistant.ActivePage = jpsAssistantUpFile) then
  1486. jpsAssistant.ActivePage := jpsAssistantStandardBills;
  1487. end;
  1488. end;
  1489. procedure TProjectFrame.BeforeChangeView(APageIndex: Integer);
  1490. begin
  1491. if G_IsCloud then
  1492. begin
  1493. tobtnShowChecker.Visible := ProjectData.PhaseIndex > 0;
  1494. tobtnShowChecker.Enabled := (APageIndex = xbiBillsMeasure.Tag);
  1495. ButtonControl_NewPhase;
  1496. if APageIndex = xbiBillsCompile.Tag then
  1497. begin
  1498. if tobtnShowChecker.Down then
  1499. begin
  1500. tobtnShowChecker.Down := False;
  1501. tobtnShowChecker.Click;
  1502. tobtnStandardBills.Down := True;
  1503. tobtnStandardBills.Click;
  1504. tobtnStandardBills.Down := False;
  1505. tobtnStandardBills.Click;
  1506. end;
  1507. end;
  1508. end;
  1509. // 记录台账分解、计量台账等的右侧展开情况
  1510. if jpsAssistant.Visible then
  1511. jpsMain.ActivePage.Tag := jpsAssistant.ActivePageIndex
  1512. else
  1513. jpsMain.ActivePage.Tag := -1;
  1514. end;
  1515. procedure TProjectFrame.LocateZJJL(ABillsID: Integer);
  1516. var
  1517. Rec: TsdDataRecord;
  1518. begin
  1519. if not tobtnZJJL.Down then
  1520. begin
  1521. tobtnZJJL.Down := True;
  1522. tobtnZJJL.Click;
  1523. end;
  1524. Rec := FProjectData.PhaseData.ZJJLData.FindZJJLRecord(ABillsID);
  1525. FProjectData.PhaseData.ZJJLData.sdvZJJL.LocateInControl(Rec);
  1526. end;
  1527. procedure TProjectFrame.LocateCompileBills(AID: Integer);
  1528. var
  1529. vNode: TsdIDTreeNode;
  1530. begin
  1531. dxsbViewControl.SelectedItem := dxsbViewControl.Groups[0].Items[xbiBillsCompile.Tag];
  1532. ChangeView(xbiBillsCompile.Tag);
  1533. with FProjectData.BillsCompileData do
  1534. begin
  1535. vNode := BillsCompileTree.FindNode(AID);
  1536. if Assigned(vNode) then
  1537. sdvBillsCompile.LocateInControl(vNode.Rec);
  1538. end;
  1539. end;
  1540. end.