PriceMarginBillsDm.pas 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402
  1. unit PriceMarginBillsDm;
  2. interface
  3. uses
  4. SysUtils, Classes, sdDB, sdProvider, BillsTree, mDataRecord,
  5. GclBillsGatherModel, DB, CalcDecimal;
  6. type
  7. TPriceMarginBillsData = class(TDataModule)
  8. sdmpGclBills: TsdMemoryProvider;
  9. sddGclBills: TsdDataSet;
  10. sdmpDetailGclBills: TsdMemoryProvider;
  11. sddDetailGclBills: TsdDataSet;
  12. sdvGclBills: TsdDataView;
  13. sdvDetailGclBills: TsdDataView;
  14. sdvDetailGL: TsdDataView;
  15. procedure sdvGclBillsCurrentChanged(ARecord: TsdDataRecord);
  16. procedure sdvDetailGclBillsFilterRecord(ARecord: TsdDataRecord;
  17. var Allow: Boolean);
  18. procedure sdvDetailGLFilterRecord(ARecord: TsdDataRecord;
  19. var Allow: Boolean);
  20. procedure sdvDetailGclBillsCurrentChanged(ARecord: TsdDataRecord);
  21. procedure sdvDetailGLAfterValueChanged(AValue: TsdValue);
  22. procedure sdvDetailGclBillsGetText(var Text: String;
  23. ARecord: TsdDataRecord; AValue: TsdValue; AColumn: TsdViewColumn;
  24. DisplayText: Boolean);
  25. procedure sdvDetailGLAfterDeleteRecord(ARecord: TsdDataRecord);
  26. procedure sdvGclBillsGetText(var Text: String; ARecord: TsdDataRecord;
  27. AValue: TsdValue; AColumn: TsdViewColumn; DisplayText: Boolean);
  28. procedure sdvDetailGLSetText(var Text: String; ARecord: TsdDataRecord;
  29. AValue: TsdValue; AColumn: TsdViewColumn; var Allow: Boolean);
  30. private
  31. FProjectData: TObject;
  32. procedure WriteGclBillsData(AGcls, AXmjs: TList);
  33. function GetMainBillsTree: TBillsIDTree;
  34. function GetDecimal: TCalcDecimal;
  35. public
  36. constructor Create(AProjectData: TObject);
  37. destructor Destroy; override;
  38. procedure RefreshBills;
  39. procedure AddDetailGLs(AGls: TList);
  40. procedure RefreshDetailBills(ABillsID: Integer);
  41. procedure RefreshAllDetailBills;
  42. property ProjectData: TObject read FProjectData;
  43. property MainBillsTree: TBillsIDTree read GetMainBillsTree;
  44. property Decimal: TCalcDecimal read GetDecimal;
  45. end;
  46. implementation
  47. uses
  48. ZhAPI, ProjectData, UtilMethods;
  49. {$R *.dfm}
  50. { TPriceMarginBillsData }
  51. constructor TPriceMarginBillsData.Create(AProjectData: TObject);
  52. begin
  53. inherited Create(nil);
  54. FProjectData := AProjectData;
  55. sddGclBills.Open;
  56. if not Assigned(sddGclBills.FindIndex('idxIndexCode')) then
  57. sddGclBills.AddIndex('idxIndexCode', 'IndexCode');
  58. sdvGclBills.Open;
  59. sdvGclBills.IndexName := 'idxIndexCode';
  60. sddDetailGclBills.Open;
  61. if not Assigned(sddDetailGclBills.FindIndex('idxSerialNo')) then
  62. sddDetailGclBills.AddIndex('idxSerialNo', 'BillsID;TreeSerialNo');
  63. if not Assigned(sddDetailGclBills.FindIndex('idxRelaBills')) then
  64. sddDetailGclBills.AddIndex('idxRelaBills', 'RelaBillsID');
  65. sdvDetailGclBills.Open;
  66. sdvDetailGclBills.IndexName := 'idxSerialNo';
  67. sdvDetailGL.DataSet := TProjectData(FProjectData).DetailGLData.sddDetailGL;
  68. sdvDetailGL.IndexName := 'idxView';
  69. sdvDetailGL.Columns.FindColumn('Name').LookupDataSet := TProjectData(FProjectData).ProjectGLData.sddProjectGL;
  70. sdvDetailGL.Columns.FindColumn('Units').LookupDataSet := TProjectData(FProjectData).ProjectGLData.sddProjectGL;
  71. end;
  72. destructor TPriceMarginBillsData.Destroy;
  73. begin
  74. inherited;
  75. end;
  76. procedure TPriceMarginBillsData.RefreshBills;
  77. var
  78. vGather: TGclGatherModel;
  79. begin
  80. vGather := TGclGatherModel.Create(FProjectData);
  81. try
  82. vGather.WriteGatherData := WriteGclBillsData;
  83. vGather.Execute;
  84. finally
  85. vGather.Free;
  86. end;
  87. end;
  88. procedure TPriceMarginBillsData.WriteGclBillsData(AGcls, AXmjs: TList);
  89. procedure BeforeWrite;
  90. begin
  91. sdvDetailGclBills.Filtered := False;
  92. sdvDetailGL.Filtered := False;
  93. sddGclBills.DisableControls;
  94. sddGclBills.BeginUpdate;
  95. sddGclBills.DeleteAll;
  96. sddDetailGclBills.DisableControls;
  97. sddDetailGclBills.BeginUpdate;
  98. sddDetailGclBills.DeleteAll;
  99. end;
  100. procedure AfterWrite;
  101. var
  102. idx: TsdIndex;
  103. begin
  104. sddDetailGclBills.EndUpdate;
  105. sddDetailGclBills.EnableControls;
  106. sddGclBills.EndUpdate;
  107. sddGclBills.EnableControls;
  108. if not sdvDetailGL.Active then
  109. sdvDetailGL.Open;
  110. idx := sddGclBills.FindIndex('idxIndexCode');
  111. sdvGclBills.LocateInControl(sdvGclBills.Records[0]);
  112. sdvDetailGclBills.Filtered := True;
  113. sdvDetailGclBills.LocateInControl(sdvDetailGclBills.Records[0]);
  114. sdvDetailGL.Filtered := True;
  115. sdvDetailGclBills.LocateInControl(sdvDetailGclBills.Records[0]);
  116. end;
  117. procedure WriteDetailGclNode(AGclNode: TGclNode);
  118. var
  119. iDetailGcl: Integer;
  120. vDetailGcl: TDetailGclNode;
  121. Rec: TsdDataRecord;
  122. begin
  123. for iDetailGcl := 0 to AGclNode.DetailGclCount -1 do
  124. begin
  125. vDetailGcl := AGclNode.DetailGcl[iDetailGcl];
  126. Rec := sddDetailGclBills.Add;
  127. Rec.ValueByName('ID').AsInteger := vDetailGcl.ID;
  128. Rec.ValueByName('BillsID').AsInteger := AGclNode.ID;
  129. Rec.ValueByName('TreeSerialNo').AsInteger := vDetailGcl.TreeSerialNo;
  130. Rec.ValueByName('RelaBillsID').AsInteger := vDetailGcl.BillsID;
  131. if Assigned(vDetailGcl.LeafXmj) then
  132. begin
  133. Rec.ValueByName('LeafXmjID').AsInteger := vDetailGcl.LeafXmj.ID;
  134. Rec.ValueByName('XmjCode').AsString := vDetailGcl.LeafXmj.XmjCode;
  135. Rec.ValueByName('XmjName').AsString := vDetailGcl.LeafXmj.XmjName;
  136. Rec.ValueByName('XmjUnits').AsString := vDetailGcl.LeafXmj.XmjUnits;
  137. Rec.ValueByName('NameDanWei').AsString := vDetailGcl.LeafXmj.NameDanWei;
  138. Rec.ValueByName('NameFenXiang').AsString := vDetailGcl.LeafXmj.NameFenXiang;
  139. Rec.ValueByName('NameFenBu').AsString := vDetailGcl.LeafXmj.NameFenBu;
  140. Rec.ValueByName('NameUnit').AsString := vDetailGcl.LeafXmj.NameUnit;
  141. Rec.ValueByName('Peg').AsString := vDetailGcl.LeafXmj.Peg;
  142. Rec.ValueByName('Position').AsString := vDetailGcl.LeafXmj.Position;
  143. Rec.ValueByName('DrawingCode').AsString := vDetailGcl.LeafXmj.DrawingCode;
  144. end;
  145. Rec.ValueByName('CurDealQuantity').AsFloat := vDetailGcl.CurDealQuantity;
  146. Rec.ValueByName('CurQcQuantity').AsFloat := vDetailGcl.CurQcQuantity;
  147. Rec.ValueByName('CurGatherQuantity').AsFloat := vDetailGcl.CurGatherQuantity;
  148. Rec.ValueByName('PM_PreTotalPrice').AsFloat := vDetailGcl.PM_PreTotalPrice;
  149. Rec.ValueByName('PM_TotalPrice').AsFloat := vDetailGcl.PM_TotalPrice;
  150. end;
  151. end;
  152. procedure WriteGclNode(AGclNode: TGclNode);
  153. var
  154. Rec: TsdDataRecord;
  155. begin
  156. Rec := sddGclBills.Add;
  157. Rec.ValueByName('ID').AsInteger := AGclNode.ID;
  158. Rec.ValueByName('B_Code').AsString := AGclNode.B_Code;
  159. Rec.ValueByName('IndexCode').AsString := AGclNode.IndexCode;
  160. Rec.ValueByName('Name').AsString := AGclNode.Name;
  161. Rec.ValueByName('Units').AsString := AGclNode.Units;
  162. Rec.ValueByName('Price').AsFloat := AGclNode.Price;
  163. Rec.ValueByName('CurDealQuantity').AsFloat := AGclNode.CurDealQuantity;
  164. Rec.ValueByName('CurQcQuantity').AsFloat := AGclNode.CurQcQuantity;
  165. Rec.ValueByName('CurGatherQuantity').AsFloat := AGclNode.CurGatherQuantity;
  166. WriteDetailGclNode(AGclNode);
  167. end;
  168. var
  169. iGcl: Integer;
  170. vGclNode: TGclNode;
  171. begin
  172. BeforeWrite;
  173. try
  174. for iGcl := 0 to AGcls.Count - 1 do
  175. begin
  176. vGclNode := TGclNode(AGcls.Items[iGcl]);
  177. WriteGclNode(vGclNode);
  178. end;
  179. finally
  180. AfterWrite;
  181. end;
  182. end;
  183. procedure TPriceMarginBillsData.sdvGclBillsCurrentChanged(
  184. ARecord: TsdDataRecord);
  185. begin
  186. sdvDetailGclBills.RefreshFilter;
  187. sdvDetailGclBills.LocateInControl(sdvDetailGclBills.Records[0]);
  188. end;
  189. procedure TPriceMarginBillsData.sdvDetailGclBillsFilterRecord(
  190. ARecord: TsdDataRecord; var Allow: Boolean);
  191. begin
  192. if Assigned(sdvGclBills.Current) and Assigned(ARecord) then
  193. Allow := ARecord.ValueByName('BillsID').AsInteger = sdvGclBills.Current.ValueByName('ID').AsInteger
  194. else
  195. Allow := False;
  196. end;
  197. procedure TPriceMarginBillsData.sdvDetailGLFilterRecord(
  198. ARecord: TsdDataRecord; var Allow: Boolean);
  199. begin
  200. if Assigned(sdvDetailGclBills.Current) and Assigned(ARecord) then
  201. Allow := ARecord.ValueByName('BillsID').AsInteger = sdvDetailGclBills.Current.ValueByName('RelaBillsID').AsInteger
  202. else
  203. Allow := False;
  204. end;
  205. function TPriceMarginBillsData.GetMainBillsTree: TBillsIDTree;
  206. begin
  207. Result := TProjectData(FProjectData).BillsMeasureData.BillsMeasureTree;
  208. end;
  209. procedure TPriceMarginBillsData.AddDetailGLs(AGls: TList);
  210. begin
  211. TProjectData(FProjectData).DetailGLData.AddDetailGLs(
  212. sdvDetailGclBills.Current.ValueByName('RelaBillsID').AsInteger, AGls);
  213. sdvDetailGL.RefreshFilter;
  214. end;
  215. procedure TPriceMarginBillsData.sdvDetailGclBillsCurrentChanged(
  216. ARecord: TsdDataRecord);
  217. begin
  218. sdvDetailGL.RefreshFilter;
  219. end;
  220. procedure TPriceMarginBillsData.RefreshDetailBills(ABillsID: Integer);
  221. var
  222. Rec: TsdDataRecord;
  223. StageRec: TStageRecord;
  224. begin
  225. Rec := sddDetailGclBills.FindKey('idxRelaBills', ABillsID);
  226. if not Assigned(Rec) then Exit;
  227. StageRec := TProjectData(FProjectData).PhaseData.StageData.StageRecord(ABillsID);
  228. if Assigned(StageRec) then
  229. Rec.ValueByName('PM_TotalPrice').AsFloat := StageRec.PM_TotalPrice.AsFloat
  230. else
  231. Rec.ValueByName('PM_TotalPrice').AsFloat := 0;
  232. end;
  233. procedure TPriceMarginBillsData.sdvDetailGLAfterValueChanged(
  234. AValue: TsdValue);
  235. var
  236. ARec: TDetailGLRecord;
  237. begin
  238. if SameText(AValue.FieldName, 'Quantity') then
  239. begin
  240. ARec := TDetailGLRecord(AValue.Owner);
  241. // 更新调差工料--本期价差
  242. with TProjectData(FProjectData).ProjectGLData do
  243. CalculateGL_PM(ARec.GLID.AsInteger);
  244. // 更新清单调差数据,材料调差节点数据
  245. with TProjectData(FProjectData).PhaseData.StageData do
  246. begin
  247. CalculatePriceMargin(ARec.BillsID.AsInteger);
  248. //CalculatePriceMarginNode;
  249. end;
  250. // 更新价差清单内存表信息
  251. with TProjectData(FProjectData).PriceMarginBillsData do
  252. RefreshDetailBills(ARec.BillsID.AsInteger);
  253. // 更新合同支付
  254. //TProjectData(FProjectData).PhaseData.PhasePayData.CalculateAll;
  255. // 更新合计值
  256. TProjectData(FProjectData).ProjectGLData.RefreshGatherData;
  257. end;
  258. end;
  259. procedure TPriceMarginBillsData.sdvDetailGclBillsGetText(var Text: String;
  260. ARecord: TsdDataRecord; AValue: TsdValue; AColumn: TsdViewColumn;
  261. DisplayText: Boolean);
  262. procedure GetDisplayText;
  263. begin
  264. if ((Pos('Price', AColumn.FieldName) > 0) or
  265. (Pos('Quantity', AColumn.FieldName) > 0)) then
  266. begin
  267. if AValue.AsFloat = 0 then
  268. Text := '';
  269. end;
  270. end;
  271. begin
  272. if DisplayText then
  273. GetDisplayText;
  274. end;
  275. procedure TPriceMarginBillsData.sdvDetailGLAfterDeleteRecord(
  276. ARecord: TsdDataRecord);
  277. var
  278. ARec: TDetailGLRecord;
  279. begin
  280. if ARecord.ValueByName('Quantity').AsFloat <> 0 then
  281. begin
  282. ARec := TDetailGLRecord(ARecord);
  283. // 更新调差工料--本期价差
  284. with TProjectData(FProjectData).ProjectGLData do
  285. CalculateGL_PM(ARec.GLID.AsInteger);
  286. // 更新清单调差数据,材料调差节点数据
  287. with TProjectData(FProjectData).PhaseData.StageData do
  288. begin
  289. CalculatePriceMargin(ARec.BillsID.AsInteger);
  290. //CalculatePriceMarginNode;
  291. end;
  292. // 更新价差清单内存表信息
  293. with TProjectData(FProjectData).PriceMarginBillsData do
  294. RefreshDetailBills(ARec.BillsID.AsInteger);
  295. // 更新合同支付
  296. //TProjectData(FProjectData).PhaseData.PhasePayData.CalculateAll;
  297. // 更新合计值
  298. TProjectData(FProjectData).ProjectGLData.RefreshGatherData;
  299. end;
  300. end;
  301. procedure TPriceMarginBillsData.sdvGclBillsGetText(var Text: String;
  302. ARecord: TsdDataRecord; AValue: TsdValue; AColumn: TsdViewColumn;
  303. DisplayText: Boolean);
  304. procedure GetDisplayText;
  305. begin
  306. if ((Pos('Price', AColumn.FieldName) > 0) or
  307. (Pos('Quantity', AColumn.FieldName) > 0)) then
  308. begin
  309. if AValue.AsFloat = 0 then
  310. Text := '';
  311. end;
  312. end;
  313. begin
  314. if DisplayText then
  315. GetDisplayText;
  316. end;
  317. procedure TPriceMarginBillsData.RefreshAllDetailBills;
  318. var
  319. i: Integer;
  320. Rec: TsdDataRecord;
  321. StageRec: TStageRecord;
  322. begin
  323. for i := 0 to sddDetailGclBills.RecordCount - 1 do
  324. begin
  325. Rec := sddDetailGclBills.Records[i];
  326. with TProjectData(FProjectData).PhaseData.StageData do
  327. StageRec := StageRecord(Rec.ValueByName('RelaBillsID').AsInteger);
  328. if Assigned(StageRec) then
  329. Rec.ValueByName('PM_TotalPrice').AsFloat := StageRec.PM_TotalPrice.AsFloat
  330. else
  331. Rec. ValueByName('PM_TotalPrice').AsFloat := 0;
  332. end;
  333. end;
  334. procedure TPriceMarginBillsData.sdvDetailGLSetText(var Text: String;
  335. ARecord: TsdDataRecord; AValue: TsdValue; AColumn: TsdViewColumn;
  336. var Allow: Boolean);
  337. begin
  338. if AValue.DataType in [ftInteger, ftFloat] then
  339. if not CheckNumeric(Text) then
  340. Text := '';
  341. if SameText(AValue.FieldName, 'Quantity') then
  342. Text := Decimal.Quantity.StrRoundTo(Text);
  343. end;
  344. function TPriceMarginBillsData.GetDecimal: TCalcDecimal;
  345. begin
  346. Result := TProjectData(FProjectData).ProjProperties.DecimalManager.PriceMargin;
  347. end;
  348. end.