ZJJLDm.pas 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871
  1. unit ZJJLDm;
  2. interface
  3. uses
  4. ZjGrid, MeasureGatherZJJL,
  5. SysUtils, Classes, DB, DBClient, ADODB, sdIDTree, sdDB, Provider,
  6. Windows, BillsTree, sdProvider, Variants;
  7. type
  8. TZJJLType = (ztFx, ztGcl, ztGclGather);
  9. TZJJLNode = class
  10. private
  11. FBillsID: Integer;
  12. FCode: string;
  13. FCertificateCode: string;
  14. FBillsCode: string;
  15. FFormulaMemo: string;
  16. FRelaFile: string;
  17. FType: Integer;
  18. end;
  19. TZJJLInfoRec = Record
  20. FBFXName: string;
  21. PegName: string;
  22. BeginPeg: string;
  23. EndPeg: string;
  24. BGLCode: string;
  25. DrawingCode: string;
  26. UnitName: string;
  27. end;
  28. TZJJLData = class(TDataModule)
  29. sdpZJJL: TsdADOProvider;
  30. sddZJJL: TsdDataSet;
  31. sdvZJJL: TsdDataView;
  32. sdpHistory: TsdADOProvider;
  33. sddHistory: TsdDataSet;
  34. sdpZJJLDetail: TsdADOProvider;
  35. sddZJJLDetail: TsdDataSet;
  36. procedure sdvZJJLBeforeValueChange(AValue: TsdValue;
  37. const NewValue: Variant; var Allow: Boolean);
  38. procedure sdvZJJLAfterDeleteRecord(ARecord: TsdDataRecord);
  39. private
  40. FPhaseData: TObject;
  41. FCanModified: Boolean;
  42. FNewID: Integer;
  43. FOrgDataList: TList;
  44. function GetNewCode(ANewID: Integer): string;
  45. procedure GenerateZJJLNode(ANode: TsdIDTreeNode; AType: Integer);
  46. function CheckLastXmj(AID: Integer): Boolean;
  47. function CheckBGExist(ANode: TsdIDTreeNode): Boolean;
  48. function CheckMeasureExist(ANode: TsdIDTreeNode): Boolean;
  49. procedure GenerateLastXmj(ANode: TsdIDTreeNode);
  50. procedure GenerateNode(ANode: TsdIDTreeNode);
  51. function CheckLeafNodeMeasureExist(AID: Integer): Boolean;
  52. procedure GenerateLeafNode(ANode: TsdIDTreeNode);
  53. procedure GenerateNodeByB_Code(ANode: TsdIDTreeNode);
  54. procedure DeleteAll;
  55. procedure RestoreOrgData;
  56. procedure DeleteHistory(ABillsID, AType: Integer);
  57. procedure DetailGridCellCanEdit(Sender: TObject; const ACoord: TPoint;
  58. var Allow: Boolean);
  59. procedure DetailGridCellTextChanged(Sender: TObject; Col, Row: Integer);
  60. function GetFieldStrDef(ANode: TsdIDTreeNode; const AFieldName, ADef: string): string;
  61. function GetPegNode(ANode: TsdIDTreeNode): TsdIDTreeNode;
  62. function GetBGLCode(ANode: TsdIDTreeNode): string;
  63. // 取树结构的第ALevel层节点的名称(level从0开始)
  64. function GetNameByLevel(ANode: TsdIDTreeNode; ALevel: Integer): string;
  65. function GetFBFXName(ANode, APegNode: TsdIDTreeNode): string;
  66. function GetPegName(ANode: TsdIDTreeNode): string;
  67. function GetInfoRecByCode_2(ABillsID: Integer): TZJJLInfoRec;
  68. function GetInfoRecByB_Code_2(ABillsID: Integer): TZJJLInfoRec;
  69. function GetInfoRec_2(ABillsID, AType: Integer): TZJJLInfoRec;
  70. function GetNewHistoryID: Integer;
  71. procedure SetHistory(const AFieldName, AValue: string; AZJJL_Rec: TsdDataRecord);
  72. // 向父项检测,直至提取到图册号为止
  73. function GetDrawingCode(ANode: TsdIDTreeNode): string;
  74. procedure CheckZjjlVerison;
  75. function GetMainBillsTree: TsdIDTree;
  76. public
  77. constructor Create(APhaseData: TObject);
  78. destructor Destroy; override;
  79. procedure Open(AConnection: TADOConnection);
  80. procedure Save;
  81. procedure GenerateAll;
  82. procedure GenerateAllByB_Code;
  83. procedure GenerateAllByB_CodeGather;
  84. procedure AssignedCurData(ARec: TsdDataRecord; ADetailGrid: TZJGrid);
  85. function GetInfoRecByCode(ABillsID: Integer): TZJJLInfoRec;
  86. function GetInfoRecByB_Code(ABillsID: Integer): TZJJLInfoRec;
  87. function GetInfoRec(ABillsID, AType: Integer): TZJJLInfoRec;
  88. procedure LocateBills;
  89. property PhaseData: TObject read FPhaseData;
  90. property MainBillsTree: TsdIDTree read GetMainBillsTree;
  91. property CanModified: Boolean read FCanModified write FCanModified;
  92. end;
  93. implementation
  94. uses
  95. PhaseData, ProjectData, BillsDm, UtilMethods, ProjectProperty, ZhAPI,
  96. BillsCompileDm, BillsMeasureDm, mPegFilter;
  97. {$R *.dfm}
  98. { TZJJLData }
  99. constructor TZJJLData.Create(APhaseData: TObject);
  100. begin
  101. inherited Create(nil);
  102. FPhaseData := APhaseData;
  103. FOrgDataList := TList.Create;
  104. end;
  105. destructor TZJJLData.Destroy;
  106. begin
  107. ClearObjects(FOrgDataList);
  108. FOrgDataList.Free;
  109. inherited;
  110. end;
  111. function TZJJLData.GetMainBillsTree: TsdIDTree;
  112. begin
  113. with TProjectData(TPhaseData(FPhaseData).ProjectData) do
  114. Result := BillsMeasureData.BillsMeasureTree;
  115. end;
  116. procedure TZJJLData.Open(AConnection: TADOConnection);
  117. begin
  118. sdpZJJL.Connection := AConnection;
  119. sddZJJL.Open;
  120. sddZJJL.AddIndex('idxID', 'ID');
  121. sddZJJL.AddIndex('idxBillsID', 'BillsID');
  122. sdvZJJL.Open;
  123. sdpHistory.Connection := AConnection;
  124. sddHistory.Open;
  125. sddHistory.AddIndex('idxID', 'ID');
  126. sddHistory.AddIndex('idxHistory', 'BillsID;Type;FieldName');
  127. sddHistory.AddIndex('idxGatherHistory', 'BillsID;Type;B_Code;Name;Units;Price;FieldName');
  128. sdpZJJLDetail.Connection := AConnection;
  129. sddZJJLDetail.Open;
  130. CheckZjjlVerison;
  131. end;
  132. procedure TZJJLData.Save;
  133. begin
  134. sddZJJL.Save;
  135. sddHistory.Save;
  136. end;
  137. function TZJJLData.CheckLastXmj(AID: Integer): Boolean;
  138. var
  139. stnNode, stnChild: TsdIDTreeNode;
  140. begin
  141. stnNode := MainBillsTree.FindNode(AID);
  142. Result := stnNode.Rec.ValueByName('Code').AsString <> '';
  143. if not stnNode.HasChildren or not Result then Exit;
  144. stnChild := stnNode.FirstChild;
  145. Result := stnChild.Rec.ValueByName('B_Code').AsString <> '';
  146. end;
  147. procedure TZJJLData.AssignedCurData(ARec: TsdDataRecord; ADetailGrid: TZJGrid);
  148. var
  149. iRowIndex: Integer;
  150. begin
  151. ADetailGrid.OnCellTextChanged := nil;
  152. ADetailGrid.FixedRowCount := 0;
  153. ADetailGrid.FixedColCount := 0;
  154. ADetailGrid.ColCount := 1;
  155. ADetailGrid.RowCount := 11;
  156. ADetailGrid.DefaultColWidth := 300;
  157. for iRowIndex := 0 to ADetailGrid.RowCount - 1 do
  158. ADetailGrid[0, iRowIndex].Align := gaTopLeft;
  159. if not Assigned(ARec) then Exit;
  160. ADetailGrid.Cells[0, 0].Text := '变更令号:' + ARec.ValueByName('BGLCode').AsString;
  161. ADetailGrid.Cells[0, 1].Text := '部位:' + ARec.ValueByName('PegName').AsString;
  162. ADetailGrid.Cells[0, 2].Text := '起始桩号:' + ARec.ValueByName('BeginPeg').AsString;
  163. ADetailGrid.Cells[0, 3].Text := '终止桩号:' + ARec.ValueByName('EndPeg').AsString;
  164. ADetailGrid.Cells[0, 4].Text := '分部分项工程:' + ARec.ValueByName('FBFXName').AsString;
  165. ADetailGrid.Cells[0, 5].Text := '计量单元:' + ARec.ValueByName('UnitName').AsString;
  166. ADetailGrid.Cells[0, 6].Text := '图号:' + ARec.ValueByName('DrawingCode').AsString;
  167. ADetailGrid.Cells[0, 7].Text := '计算式说明:';
  168. ADetailGrid.Cells[0, 8].Text := ARec.ValueByName('FormulaMemo').AsString;
  169. ADetailGrid.Cells[0, 8].Align := gaTopLeft;
  170. ADetailGrid.RowHeights[8] := 57;
  171. ADetailGrid.Cells[0, 9].Text := '计算草图几何尺寸:';
  172. ADetailGrid.Cells[0, 10].Text := ARec.ValueByName('RelaFile').AsString;
  173. ADetailGrid.Cells[0, 10].Align := gaTopLeft;
  174. ADetailGrid.RowHeights[10] := 57;
  175. ADetailGrid.OnCellTextChanged := DetailGridCellTextChanged;
  176. end;
  177. procedure TZJJLData.GenerateAll;
  178. begin
  179. RestoreOrgData;
  180. FNewID := 1;
  181. DeleteAll;
  182. GenerateNode(MainBillsTree.FirstNode);
  183. TPhaseData(FPhaseData).PhaseProperty.ZjjlVersion := 1;
  184. end;
  185. procedure TZJJLData.GenerateNode(ANode: TsdIDTreeNode);
  186. begin
  187. if not Assigned(ANode) then Exit;
  188. if CheckLastXmj(ANode.ID) then
  189. GenerateLastXmj(ANode)
  190. else
  191. GenerateNode(ANode.FirstChild);
  192. GenerateNode(ANode.NextSibling);
  193. end;
  194. procedure TZJJLData.GenerateLastXmj(ANode: TsdIDTreeNode);
  195. begin
  196. if CheckMeasureExist(ANode) then
  197. GenerateZJJLNode(ANode, 0);
  198. end;
  199. function TZJJLData.CheckBGExist(ANode: TsdIDTreeNode): Boolean;
  200. function CheckBGLExist(AID: Integer): Boolean;
  201. var
  202. StageRec: TsdDataRecord;
  203. begin
  204. StageRec := TPhaseData(FPhaseData).StageData.StageRecord(AID);
  205. Result := Assigned(StageRec) and
  206. ((StageRec.ValueByName('QcBGLCode').AsString <> '')
  207. or (StageRec.ValueByName('PcBGLCode').AsString <> ''));
  208. end;
  209. var
  210. iChild: Integer;
  211. begin
  212. Result := False;
  213. if not Assigned(ANode) then Exit;
  214. if ANode.HasChildren then
  215. begin
  216. for iChild := 0 to ANode.ChildCount - 1 do
  217. begin
  218. Result := Result or CheckBGExist(ANode.ChildNodes[iChild]);
  219. if Result then Break;
  220. end;
  221. end
  222. else
  223. Result := CheckBGLExist(ANode.ID);
  224. end;
  225. procedure TZJJLData.DeleteAll;
  226. begin
  227. sddZJJL.DeleteAll;
  228. sddZJJLDetail.DeleteAll;
  229. end;
  230. procedure TZJJLData.RestoreOrgData;
  231. function CreateNodeData(ARec: TsdDataRecord): TZJJLNode;
  232. begin
  233. Result := TZJJLNode.Create;
  234. Result.FBillsID := ARec.ValueByName('BillsID').AsInteger;
  235. Result.FCode := ARec.ValueByName('Code').AsString;
  236. Result.FCertificateCode := ARec.ValueByName('CertificateCode').AsString;
  237. Result.FBillsCode := ARec.ValueByName('BillsCode').AsString;
  238. Result.FFormulaMemo := ARec.ValueByName('FormulaMemo').AsString;
  239. Result.FRelaFile := ARec.ValueByName('RelaFile').AsString;
  240. Result.FType := ARec.ValueByName('Type').AsInteger;
  241. end;
  242. var
  243. i: Integer;
  244. vRec: TsdDataRecord;
  245. begin
  246. FOrgDataList.Clear;
  247. for i := 0 to sddZJJL.RecordCount - 1 do
  248. begin
  249. vRec := sddZJJL.Records[i];
  250. FOrgDataList.Add(CreateNodeData(vRec));
  251. end;
  252. end;
  253. function TZJJLData.CheckMeasureExist(ANode: TsdIDTreeNode): Boolean;
  254. function CheckStageCompleteData(AID: Integer): Boolean;
  255. var
  256. StageRec: TsdDataRecord;
  257. begin
  258. StageRec := TPhaseData(FPhaseData).StageData.StageRecord(AID);
  259. Result := Assigned(StageRec) and
  260. ((StageRec.ValueByName('GatherQuantity').AsFloat <> 0)
  261. or (StageRec.ValueByName('GatherTotalPrice').AsFloat <> 0));
  262. end;
  263. var
  264. iChild: Integer;
  265. begin
  266. Result := False;
  267. if not Assigned(ANode) then Exit;
  268. if ANode.HasChildren then
  269. begin
  270. for iChild := 0 to ANode.ChildCount - 1 do
  271. begin
  272. Result := Result or CheckMeasureExist(ANode.ChildNodes[iChild]);
  273. if Result then Break;
  274. end;
  275. end
  276. else
  277. Result := CheckStageCompleteData(ANode.ID);
  278. end;
  279. procedure TZJJLData.DetailGridCellCanEdit(Sender: TObject;
  280. const ACoord: TPoint; var Allow: Boolean);
  281. begin
  282. Allow := ((ACoord.Y = 6) or (ACoord.Y = 8)) and
  283. not TPhaseData(FPhaseData).StageDataReadOnly;
  284. end;
  285. function TZJJLData.GetInfoRecByCode(ABillsID: Integer): TZJJLInfoRec;
  286. var
  287. vPeg, vNode: TsdIDTreeNode;
  288. begin
  289. vNode := MainBillsTree.FindNode(ABillsID);
  290. vPeg := GetPegNode(vNode);
  291. Result.BGLCode := GetBGLCode(vNode);
  292. Result.PegName := GetFieldStrDef(vPeg, 'Name', '');
  293. Result.FBFXName := GetFBFXName(vNode, vPeg);
  294. Result.UnitName := GetFieldStrDef(vNode, 'Name', '');
  295. Result.DrawingCode := GetDrawingCode(vNode);
  296. end;
  297. procedure TZJJLData.DetailGridCellTextChanged(Sender: TObject; Col,
  298. Row: Integer);
  299. var
  300. Rec: TsdDataRecord;
  301. begin
  302. Rec := sdvZJJL.Current;
  303. if not Assigned(Rec) then Exit;
  304. if (Row = 8) then
  305. Rec.ValueByName('FormulaMemo').AsString := TZJGrid(Sender).Cells[Col, Row].Text
  306. else if (Row = 10) then
  307. Rec.ValueByName('RelaFile').AsString := TZJGrid(Sender).Cells[Col, Row].Text;
  308. end;
  309. procedure TZJJLData.GenerateAllByB_Code;
  310. begin
  311. RestoreOrgData;
  312. FNewID := 1;
  313. DeleteAll;
  314. GenerateNodeByB_Code(MainBillsTree.FirstNode);
  315. TPhaseData(FPhaseData).PhaseProperty.ZjjlVersion := 1;
  316. end;
  317. procedure TZJJLData.GenerateNodeByB_Code(ANode: TsdIDTreeNode);
  318. begin
  319. if not Assigned(ANode) then Exit;
  320. if ANode.HasChildren then
  321. GenerateNodeByB_Code(ANode.FirstChild)
  322. else
  323. GenerateLeafNode(ANode);
  324. GenerateNodeByB_Code(ANode.NextSibling);
  325. end;
  326. procedure TZJJLData.GenerateLeafNode(ANode: TsdIDTreeNode);
  327. begin
  328. if (ANode.Rec.ValueByName('B_Code').AsString <> '') and
  329. CheckLeafNodeMeasureExist(ANode.ID) then
  330. GenerateZJJLNode(ANode, 1);
  331. end;
  332. procedure TZJJLData.GenerateZJJLNode(ANode: TsdIDTreeNode;
  333. AType: Integer);
  334. function GetOrgZJJLNode(ABillsID: Integer): TZJJLNode;
  335. var
  336. iIndex: Integer;
  337. begin
  338. Result := nil;
  339. for iIndex := 0 to FOrgDataList.Count - 1 do
  340. // 7/30新增了一个“总量控制”模式,Type字段控制。真的是要疯掉了。
  341. if (TZJJLNode(FOrgDataList.Items[iIndex]).FBillsID = ABillsID)
  342. and (TZJJLNode(FOrgDataList.Items[iIndex]).FType = AType) then
  343. begin
  344. Result := TZJJLNode(FOrgDataList.Items[iIndex]);
  345. Break;
  346. end;
  347. end;
  348. function GetFieldValue(const AFieldName, ADefaultValue: string): string;
  349. var
  350. HistoryRec: TsdDataRecord;
  351. begin
  352. HistoryRec := sddHistory.FindKey('idxHistory', VarArrayOf([ANode.ID, AType, AFieldName]));
  353. if Assigned(HistoryRec) then
  354. Result := HistoryRec.ValueByName('FieldValue').AsString
  355. else
  356. Result := ADefaultValue;
  357. end;
  358. var
  359. ZJJLNode: TZJJLNode;
  360. vInfoRec: TZJJLInfoRec;
  361. Rec: TsdDataRecord;
  362. begin
  363. Rec := sddZJJL.Add;
  364. Rec.ValueByName('ID').AsInteger := FNewID;
  365. Rec.ValueByName('BillsID').AsInteger := ANode.ID;
  366. Rec.ValueByName('Type').AsInteger := AType;
  367. if AType = Ord(ztFx) then
  368. Rec.ValueByName('BillsCode').AsString := ANode.Rec.ValueByName('Code').AsString
  369. else if AType = Ord(ztGcl) then
  370. Rec.ValueByName('BillsCode').AsString := ANode.Rec.ValueByName('B_Code').AsString;
  371. Rec.ValueByName('Code').AsString := GetFieldValue('Code', GetNewCode(FNewID));
  372. Rec.ValueByName('CertificateCode').AsString := GetFieldValue('CertificateCode', '');
  373. Rec.ValueByName('FormulaMemo').AsString := GetFieldValue('FormulaMemo', '');
  374. Rec.ValueByName('RelaFile').AsString := GetFieldValue('RelaFile', '');
  375. vInfoRec := GetInfoRec_2(ANode.ID, AType);
  376. Rec.ValueByName('BGLCode').AsString := GetFieldValue('BGLCode', vInfoRec.BGLCode);
  377. Rec.ValueByName('PegName').AsString := GetFieldValue('PegName', vInfoRec.PegName);
  378. Rec.ValueByName('BeginPeg').AsString := GetFieldValue('BeginPeg', vInfoRec.BeginPeg);
  379. Rec.ValueByName('EndPeg').AsString := GetFieldValue('EndPeg', vInfoRec.EndPeg);
  380. Rec.ValueByName('FBFXName').AsString := GetFieldValue('FBFXName', vInfoRec.FBFXName);
  381. Rec.ValueByName('UnitName').AsString := GetFieldValue('UnitName', vInfoRec.UnitName);
  382. Rec.ValueByName('DrawingCode').AsString := GetFieldValue('DrawingCode', vInfoRec.DrawingCode);
  383. Inc(FNewID);
  384. end;
  385. function TZJJLData.GetInfoRecByB_Code(ABillsID: Integer): TZJJLInfoRec;
  386. var
  387. vNode: TsdIDTreeNode;
  388. begin
  389. vNode := MainBillsTree.FindNode(ABillsID);
  390. Result.BGLCode := GetBGLCode(vNode);
  391. if Assigned(vNode.Parent) then
  392. Result.PegName := vNode.Parent.Rec.ValueByName('Name').AsString;
  393. Result.FBFXName := '';
  394. Result.UnitName := vNode.Rec.ValueByName('Name').AsString;
  395. Result.DrawingCode := GetDrawingCode(vNode);
  396. end;
  397. function TZJJLData.GetInfoRec(ABillsID, AType: Integer): TZJJLInfoRec;
  398. begin
  399. if AType = 0 then
  400. Result := GetInfoRecByCode(ABillsID)
  401. else if AType = 1 then
  402. Result := GetInfoRecByB_Code(ABillsID);
  403. end;
  404. procedure TZJJLData.LocateBills;
  405. var
  406. Rec: TsdDataRecord;
  407. begin
  408. with TProjectData(TPhaseData(FPhaseData).ProjectData) do
  409. begin
  410. Rec := BillsData.sddBills.FindKey('idxID', sdvZJJL.Current.ValueByName('BillsID').AsInteger);
  411. BillsMeasureData.sdvBillsMeasure.LocateInControl(Rec);
  412. end;
  413. end;
  414. function TZJJLData.GetDrawingCode(ANode: TsdIDTreeNode): string;
  415. var
  416. vNode: TBillsIDTreeNode;
  417. begin
  418. Result := '';
  419. vNode := TBillsIDTreeNode(ANode);
  420. while (Result = '') and Assigned(vNode) do
  421. begin
  422. if Assigned(vNode.Rec) then
  423. Result := vNode.Rec.DrawingCode.AsString;
  424. vNode := TBillsIDTreeNode(vNode.Parent);
  425. end;
  426. end;
  427. procedure TZJJLData.CheckZjjlVerison;
  428. procedure LoadVersion0Info;
  429. var
  430. i: Integer;
  431. Rec: TsdDataRecord;
  432. ZJJLInfoRec: TZJJLInfoRec;
  433. begin
  434. for i := 0 to sddZJJL.RecordCount - 1 do
  435. begin
  436. Rec := sddZJJL.Records[i];
  437. ZJJLInfoRec := GetInfoRec(Rec.ValueByName('BillsID').AsInteger, Rec.ValueByName('Type').AsInteger);
  438. Rec.ValueByName('BGLCode').AsString := ZJJLInfoRec.BGLCode;
  439. Rec.ValueByName('PegName').AsString := ZJJLInfoRec.PegName;
  440. Rec.ValueByName('FBFXName').AsString := ZJJLInfoRec.FBFXName;
  441. Rec.ValueByName('UnitName').AsString := ZJJLInfoRec.UnitName;
  442. Rec.ValueByName('DrawingCode').AsString := ZJJLInfoRec.DrawingCode;
  443. end;
  444. end;
  445. procedure LoadVersion0History;
  446. var
  447. i, j, iNewID: Integer;
  448. Rec: TsdDataRecord;
  449. begin
  450. for i := 0 to sddZJJL.RecordCount - 1 do
  451. begin
  452. Rec := sddZJJL.Records[i];
  453. SetHistory('CertificateCode', Rec.ValueByName('CertificateCode').AsString, Rec);
  454. SetHistory('FormulaMemo', Rec.ValueByName('FormulaMemo').AsString, Rec);
  455. SetHistory('RelaFile', Rec.ValueByName('RelaFile').AsString, Rec);
  456. end;
  457. end;
  458. begin
  459. if TPhaseData(PhaseData).PhaseProperty.ZjjlVersion = 0 then
  460. begin
  461. TPhaseData(PhaseData).PhaseProperty.ZJJLPreText := TProjectData(TPhaseData(PhaseData).ProjectData).ProjProperties.ZJJLPreText;
  462. LoadVersion0Info;
  463. LoadVersion0History;
  464. end;
  465. end;
  466. function TZJJLData.GetInfoRec_2(ABillsID, AType: Integer): TZJJLInfoRec;
  467. begin
  468. if AType = 0 then
  469. Result := GetInfoRecByCode_2(ABillsID)
  470. else if AType = 1 then
  471. Result := GetInfoRecByB_Code_2(ABillsID);
  472. end;
  473. function TZJJLData.GetInfoRecByB_Code_2(ABillsID: Integer): TZJJLInfoRec;
  474. var
  475. vNode: TsdIDTreeNode;
  476. sPeg: string;
  477. vPegFilter: TPegStrFilter;
  478. begin
  479. vNode := MainBillsTree.FindNode(ABillsID);
  480. sPeg := GetPegName(vNode);
  481. Result.BGLCode := GetBGLCode(vNode);
  482. if Assigned(vNode.Parent) then
  483. Result.PegName := vNode.Parent.Rec.ValueByName('Name').AsString;
  484. if sPeg <> '' then
  485. begin
  486. vPegFilter := TPegStrFilter.Create;
  487. vPegFilter.PegStr := sPeg;
  488. Result.BeginPeg := vPegFilter.BeginPeg;
  489. Result.EndPeg := vPegFilter.EndPeg;
  490. vPegFilter.Free;
  491. end;
  492. Result.UnitName := vNode.Rec.ValueByName('Name').AsString;
  493. Result.DrawingCode := GetDrawingCode(vNode);
  494. end;
  495. function TZJJLData.GetInfoRecByCode_2(ABillsID: Integer): TZJJLInfoRec;
  496. var
  497. vPeg, vNode: TsdIDTreeNode;
  498. vPegFilter: TPegStrFilter;
  499. begin
  500. vNode := MainBillsTree.FindNode(ABillsID);
  501. vPeg := GetPegNode(vNode);
  502. Result.BGLCode := GetBGLCode(vNode);
  503. Result.PegName := GetFieldStrDef(vPeg, 'Name', '');
  504. if Result.PegName <> '' then
  505. begin
  506. vPegFilter := TPegStrFilter.Create;
  507. vPegFilter.PegStr := Result.PegName;
  508. Result.BeginPeg := vPegFilter.BeginPeg;
  509. Result.EndPeg := vPegFilter.EndPeg;
  510. vPegFilter.Free;
  511. end;
  512. Result.FBFXName := GetFBFXName(vNode, vPeg);
  513. Result.UnitName := GetFieldStrDef(vNode, 'Name', '');
  514. Result.DrawingCode := GetDrawingCode(vNode);
  515. end;
  516. function TZJJLData.GetBGLCode(ANode: TsdIDTreeNode): string;
  517. begin
  518. with TProjectData(TPhaseData(FPhaseData).ProjectData) do
  519. Result := BillsMeasureData.GatherRelaBGL(ANode);
  520. end;
  521. function TZJJLData.GetPegName(ANode: TsdIDTreeNode): string;
  522. var
  523. vPeg: TsdIDTreeNode;
  524. begin
  525. vPeg := GetPegNode(ANode);
  526. Result := GetFieldStrDef(vPeg, 'Name', '');
  527. end;
  528. function TZJJLData.GetFieldStrDef(ANode: TsdIDTreeNode; const AFieldName,
  529. ADef: string): string;
  530. begin
  531. if Assigned(ANode) then
  532. Result := ANode.Rec.ValueByName(AFieldName).AsString
  533. else
  534. Result := '';
  535. end;
  536. function TZJJLData.GetPegNode(ANode: TsdIDTreeNode): TsdIDTreeNode;
  537. begin
  538. Result := nil;
  539. if not Assigned(ANode) then Exit;
  540. if CheckPeg(ANode.Rec.ValueByName('Name').AsString) then
  541. Result := ANode
  542. else
  543. Result := GetPegNode(ANode.Parent);
  544. end;
  545. function TZJJLData.GetFBFXName(ANode, APegNode: TsdIDTreeNode): string;
  546. var
  547. vCurNode: TsdIDTreeNode;
  548. begin
  549. Result := '';
  550. if not Assigned(ANode) then Exit;
  551. // 如果计量单元节点的名称为桩号(转化为判断计量单元节点与桩号节点为同一个)
  552. if not Assigned(APegNode) or (ANode.ID = APegNode.ID) then
  553. begin
  554. // 取树结构的第三、四层节点的名称
  555. Result := GetNameByLevel(ANode, 2);
  556. if (Result <> '') and (GetNameByLevel(ANode, 3) <> '') then
  557. Result := Result + ',';
  558. Result := Result + GetNameByLevel(ANode, 3);
  559. end
  560. // 否则,合并[桩号节点的子节点]至[计量单元节点的父节点]的名称
  561. else
  562. begin
  563. vCurNode := ANode.Parent;
  564. // 转化为判断层次,层次大于[桩号节点的子节点]的层次
  565. while vCurNode.Level > APegNode.Level do
  566. begin
  567. Result := vCurNode.Rec.ValueByName('Name').AsString + ',' + Result;
  568. vCurNode := vCurNode.Parent;
  569. end;
  570. end;
  571. end;
  572. function TZJJLData.GetNameByLevel(ANode: TsdIDTreeNode;
  573. ALevel: Integer): string;
  574. begin
  575. Result := '';
  576. if not Assigned(ANode) then Exit;
  577. if ANode.Level = ALevel then
  578. Result := ANode.Rec.ValueByName('Name').AsString
  579. else if ANode.Level > ALevel then
  580. Result := GetNameByLevel(ANode.Parent, ALevel);
  581. end;
  582. procedure TZJJLData.SetHistory(const AFieldName, AValue: string;
  583. AZJJL_Rec: TsdDataRecord);
  584. var
  585. HistoryRec: TsdDataRecord;
  586. begin
  587. HistoryRec := sddHistory.FindKey('idxHistory', VarArrayOf([AZJJL_Rec.ValueByName('BillsID').AsInteger,
  588. AZJJL_Rec.ValueByName('Type').AsInteger, AFieldName]));
  589. if not Assigned(HistoryRec) then
  590. begin
  591. HistoryRec := sddHistory.Add;
  592. HistoryRec.ValueByName('ID').AsInteger := GetNewHistoryID;
  593. HistoryRec.ValueByName('BillsID').AsInteger := AZJJL_Rec.ValueByName('BillsID').AsInteger;
  594. HistoryRec.ValueByName('Type').AsInteger := AZJJL_Rec.ValueByName('Type').AsInteger;
  595. HistoryRec.ValueByName('FieldName').AsString := AFieldName;
  596. HistoryRec.ValueByName('B_Code').AsString := AZJJL_Rec.ValueByName('B_Code').AsString;
  597. HistoryRec.ValueByName('Name').AsString := AZJJL_Rec.ValueByName('Name').AsString;
  598. HistoryRec.ValueByName('Units').AsString := AZJJL_Rec.ValueByName('Units').AsString;
  599. HistoryRec.ValueByName('Price').AsFloat := AZJJL_Rec.ValueByName('Price').AsFloat;
  600. end;
  601. HistoryRec.ValueByName('FieldValue').AsString := AValue;
  602. end;
  603. function TZJJLData.GetNewHistoryID: Integer;
  604. var
  605. idx: TsdIndex;
  606. begin
  607. idx := sddHistory.FindIndex('idxID');
  608. if idx.RecordCount = 0 then
  609. Result := 1
  610. else
  611. Result := idx.Records[idx.RecordCount - 1].ValueByName('ID').AsInteger + 1;
  612. end;
  613. procedure TZJJLData.sdvZJJLBeforeValueChange(AValue: TsdValue;
  614. const NewValue: Variant; var Allow: Boolean);
  615. function CheckFieldNeedHistory(const AFieldName: string): Boolean;
  616. begin
  617. Result := SameText(AFieldName, 'Code') or
  618. SameText(AFieldName, 'CertificateCode') or
  619. SameText(AFieldName, 'BGLCode') or
  620. SameText(AFieldName, 'PegName') or
  621. SameText(AFieldName, 'BeginPeg') or
  622. SameText(AFieldName, 'EndPeg') or
  623. SameText(AFieldName, 'FBFXName') or
  624. SameText(AFieldName, 'UnitName') or
  625. SameText(AFieldName, 'DrawingCode') or
  626. SameText(AFieldName, 'FormulaMemo') or
  627. SameText(AFieldName, 'RelaFile');
  628. end;
  629. var
  630. sNewValue: string;
  631. begin
  632. if CheckFieldNeedHistory(AValue.FieldName) then
  633. begin
  634. sNewValue := VarToStrDef(NewValue, '');
  635. if sNewValue <> AValue.AsString then
  636. SetHistory(AValue.FieldName, sNewValue, AValue.Owner);
  637. end;
  638. end;
  639. procedure TZJJLData.sdvZJJLAfterDeleteRecord(ARecord: TsdDataRecord);
  640. begin
  641. DeleteHistory(ARecord.ValueByName('BillsID').AsInteger, ARecord.ValueByName('Type').AsInteger);
  642. end;
  643. procedure TZJJLData.DeleteHistory(ABillsID, AType: Integer);
  644. var
  645. i: Integer;
  646. Rec: TsdDataRecord;
  647. begin
  648. i := 0;
  649. while (i < sddHistory.RecordCount) do
  650. begin
  651. Rec := sddHistory.Records[i];
  652. if (ABillsID = Rec.ValueByName('BillsID').AsInteger) and
  653. (AType = Rec.ValueByName('Type').AsInteger) then
  654. sddHistory.Remove(Rec)
  655. else
  656. Inc(i);
  657. end;
  658. end;
  659. procedure TZJJLData.GenerateAllByB_CodeGather;
  660. procedure GenerateZJJLGather(AManager: TmgZJJLManager; ANode: TBillsIDTreeNode);
  661. var
  662. iChild: Integer;
  663. vChild: TBillsIDTreeNode;
  664. begin
  665. if ANode.HasChildren then
  666. begin
  667. iChild := 0;
  668. vChild := TBillsIDTreeNode(ANode.NextNode);
  669. while iChild < ANode.PosterityCount do
  670. begin
  671. if not vChild.HasChildren and CheckLeafNodeMeasureExist(vChild.ID) then
  672. AManager.AddZJJLAndDetail(vChild, ANode);
  673. vChild := TBillsIDTreeNode(vChild.NextNode);
  674. Inc(iChild);
  675. end;
  676. end
  677. else if CheckLeafNodeMeasureExist(ANode.ID) then
  678. AManager.AddZJJLAndDetail(ANode, ANode);
  679. end;
  680. procedure GenerateZJJLGatherByNode(AManager: TmgZJJLManager; ANode: TsdIDTreeNode);
  681. begin
  682. if not Assigned(ANode) then Exit;
  683. if ANode.HasChildren and not TBillsIDTreeNode(ANode).Rec.IsGatherZJJL.AsBoolean then
  684. GenerateZJJLGatherByNode(AManager, ANode.FirstChild)
  685. else
  686. GenerateZJJLGather(AManager, TBillsIDTreeNode(ANode));
  687. GenerateZJJLGatherByNode(AManager, ANode.NextSibling);
  688. end;
  689. function GetFieldValue(AZJJL: TmgZJJL; const AFieldName, ADefaultValue: string): string;
  690. var
  691. HistoryRec: TsdDataRecord;
  692. begin
  693. HistoryRec := sddHistory.FindKey('idxGatherHistory', VarArrayOf([AZJJL.GatherNode.ID, Integer(ztGclGather), AZJJL.B_Code, AZJJL.Name, AZJJL.Units, AZJJL.Price, AFieldName]));
  694. if Assigned(HistoryRec) then
  695. Result := HistoryRec.ValueByName('FieldValue').AsString
  696. else
  697. Result := ADefaultValue;
  698. end;
  699. procedure SaveGatherData(AManager: TmgZJJLManager);
  700. var
  701. i, j: Integer;
  702. vZJJL: TmgZJJL;
  703. Rec: TsdDataRecord;
  704. begin
  705. for i := 0 to AManager.ZJJLCount - 1 do
  706. begin
  707. vZJJL := AManager.ZJJL[i];
  708. Rec := sddZJJL.Add;
  709. Rec.ValueByName('ID').AsInteger := i + 1;
  710. Rec.ValueByName('BillsID').AsInteger := vZJJL.Detail[0].RelaNode.ID;
  711. Rec.ValueByName('GatherBillsID').AsInteger := vZJJL.GatherNode.ID;
  712. Rec.ValueByName('BillsCode').AsString := vZJJL.B_Code;
  713. Rec.ValueByName('B_Code').AsString := vZJJL.B_Code;
  714. Rec.ValueByName('Name').AsString := vZJJL.Name;
  715. Rec.ValueByName('Units').AsString := vZJJL.Units;
  716. Rec.ValueByName('Price').AsFloat := vZJJL.Price;
  717. Rec.ValueByName('Code').AsString := GetFieldValue(vZJJL, 'Code', GetNewCode(i+1));
  718. Rec.ValueByName('CertificateCode').AsString := GetFieldValue(vZJJL, 'CertificateCode', '');
  719. Rec.ValueByName('FormulaMemo').AsString := GetFieldValue(vZJJL, 'FormulaMemo', '');
  720. Rec.ValueByName('RelaFile').AsString := GetFieldValue(vZJJL, 'RelaFile', '');
  721. Rec.ValueByName('BGLCode').AsString := GetFieldValue(vZJJL, 'BGLCode', vZJJL.BGLCode);
  722. Rec.ValueByName('PegName').AsString := GetFieldValue(vZJJL, 'PegName', '');
  723. Rec.ValueByName('BeginPeg').AsString := GetFieldValue(vZJJL, 'BeginPeg', vZJJL.BeginPeg);
  724. Rec.ValueByName('EndPeg').AsString := GetFieldValue(vZJJL, 'EndPeg', vZJJL.EndPeg);
  725. Rec.ValueByName('FBFXName').AsString := GetFieldValue(vZJJL, 'FBFXName', vZJJL.GatherNode.Rec.Name.AsString);
  726. Rec.ValueByName('UnitName').AsString := GetFieldValue(vZJJL, 'UnitName', '');
  727. Rec.ValueByName('DrawingCode').AsString := GetFieldValue(vZJJL, 'DrawingCode', vZJJL.DrawingCode);
  728. for j := 0 to vZJJL.DetailCount - 1 do
  729. begin
  730. Rec := sddZJJLDetail.Add;
  731. Rec.ValueByName('ID').AsInteger := i + 1;
  732. Rec.ValueByName('BillsID').AsInteger := vZJJL.Detail[j].RelaNode.ID;
  733. end;
  734. end;
  735. end;
  736. var
  737. vManager: TmgZJJLManager;
  738. begin
  739. vManager := TmgZJJLManager.Create;
  740. try
  741. DeleteAll;
  742. GenerateZJJLGatherByNode(vManager, MainBillsTree.FirstNode);
  743. SaveGatherData(vManager);
  744. TPhaseData(FPhaseData).PhaseProperty.ZjjlVersion := Integer(ztGclGather);
  745. finally
  746. vManager.Free;
  747. end;
  748. end;
  749. function TZJJLData.CheckLeafNodeMeasureExist(AID: Integer): Boolean;
  750. var
  751. StageRec: TsdDataRecord;
  752. begin
  753. StageRec := TPhaseData(FPhaseData).StageData.StageRecord(AID);
  754. Result := Assigned(StageRec) and
  755. ((StageRec.ValueByName('GatherQuantity').AsFloat <> 0)
  756. or (StageRec.ValueByName('GatherTotalPrice').AsFloat <> 0));
  757. end;
  758. function TZJJLData.GetNewCode(ANewID: Integer): string;
  759. begin
  760. with TProjectData(TPhaseData(FPhaseData).ProjectData) do
  761. begin
  762. Result := ProjProperties.ZJJLPreText;
  763. if (Result <> '') and (Result[Length(Result)] <> '-') then
  764. Result := Result + '-';
  765. Result := Result + Format('%d-%d', [PhaseIndex, ANewID]);
  766. end;
  767. end;
  768. end.