BillsDm.pas 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583
  1. unit BillsDm;
  2. interface
  3. uses
  4. StandardBillsFme,
  5. ZhAPI, StandardLib, StageDm, BillsTree, mDataRecord,
  6. SysUtils, Classes, sdDB, sdProvider, ADODB, sdIDTree, Math;
  7. const
  8. DealIndex = 0;
  9. AddDealIndex = 1;
  10. AddQcIndex = 2;
  11. AddPcIndex = 3;
  12. AddGatherIndex = 4;
  13. type
  14. TRecChangeEvent = procedure (ARec: TsdDataRecord) of object;
  15. TBillsData = class(TDataModule)
  16. sdpBills: TsdADOProvider;
  17. sddBills: TsdDataSet;
  18. procedure sddBillsAfterAddRecord(ARecord: TsdDataRecord);
  19. procedure sddBillsBeforeDeleteRecord(ARecord: TsdDataRecord;
  20. var Allow: Boolean);
  21. procedure sddBillsBeforeValueChange(AValue: TsdValue;
  22. const NewValue: Variant; var Allow: Boolean);
  23. procedure sddBillsGetRecordClass(var ARecordClass: TsdRecordClass);
  24. private
  25. FProjectData: TObject;
  26. FCurPhaseIndex: Integer;
  27. FBeforeChangeTotalPrice: Double;
  28. FBeforeChangeParentID: Integer;
  29. //procedure RecursiveCalculate(ABillsID: Integer);
  30. function GetStageData: TStageData;
  31. function GetBuildLoadInterest(AIndex: Integer): Double;
  32. function GetFirstPart(AIndex: Integer): Double;
  33. function GetOtherFee(AIndex: Integer): Double;
  34. function GetOtherProjectFee(AIndex: Integer): Double;
  35. function GetRecyclingFee(AIndex: Integer): Double;
  36. function GetReservedFee(AIndex: Integer): Double;
  37. function GetSecondPart(AIndex: Integer): Double;
  38. function GetStageSettlement(AIndex: Integer): Double;
  39. function GetThirdPart(AIndex: Integer): Double;
  40. public
  41. constructor Create(AProjectData: TObject);
  42. destructor Destroy; override;
  43. procedure Open(AConnection: TADOConnection);
  44. procedure Close;
  45. procedure Save;
  46. procedure InitBills;
  47. // 计算 -- 均采用增量汇总方式计算父项
  48. {procedure Calculate(ABillsID: Integer);
  49. procedure CalculateDeal(ABillsID: Integer); // 合同计量
  50. procedure CalculateQuantityChange(ABillsID: Integer); // 数量变更计量
  51. procedure CalculatePriceChange(ABillsID: Integer); // 单价变更计量}
  52. // 上报审核批复过程 -- 锁定数据
  53. procedure LockedBaseData;
  54. // 解锁数据
  55. procedure UnLockedBaseData;
  56. procedure DisableEvents;
  57. procedure EnableEvents;
  58. function GetMaxBillsID: Integer;
  59. function GetGatherTotalPrice(ABillsID, AIndex: Integer): Double;
  60. property ProjectData: TObject read FProjectData;
  61. property StageData: TStageData read GetStageData;
  62. {累计完成 可查数据}
  63. // AIndex表示不同类型,取值如下:
  64. // 0: 0号台账合同 1: 累计合同计量 2: 累计数量变更计量 3: 累计单价变更计量 4: 累计完成计量
  65. // 第一部分
  66. property FirstPart[AIndex: Integer]: Double read GetFirstPart;
  67. // 第二部分
  68. property SecondPart[AIndex: Integer]: Double read GetSecondPart;
  69. // 第三部分
  70. property ThirdPart[AIndex: Integer]: Double read GetThirdPart;
  71. // 预留费用
  72. property ReservedFee[AIndex: Integer]: Double read GetReservedFee;
  73. // 其他费用项目
  74. property OtherFee[AIndex: Integer]: Double read GetOtherFee;
  75. // 建设期贷款利息
  76. property BuildLoadInterest[AIndex: Integer]: Double read GetBuildLoadInterest;
  77. // 回收金额
  78. property RecyclingFee[AIndex: Integer]: Double read GetRecyclingFee;
  79. // 公路工程以外的工程费用
  80. property OtherProjectFee[AIndex: Integer]: Double read GetOtherProjectFee;
  81. // 结算价
  82. property Settlement[AIndex: Integer]: Double read GetStageSettlement;
  83. end;
  84. implementation
  85. uses
  86. Variants, UtilMethods, Globals, ProjectData, ExcelImport, BillsCommand,
  87. PhaseData, BillsCompileDm, ConditionalDefines, FormulaCalc;
  88. {$R *.dfm}
  89. { TBillsData }
  90. procedure TBillsData.Close;
  91. begin
  92. sddBills.Close;
  93. end;
  94. constructor TBillsData.Create(AProjectData: TObject);
  95. begin
  96. inherited Create(nil);
  97. FProjectData := AProjectData;
  98. end;
  99. destructor TBillsData.Destroy;
  100. begin
  101. inherited;
  102. end;
  103. procedure TBillsData.Open(AConnection: TADOConnection);
  104. begin
  105. sdpBills.Connection := AConnection;
  106. sddBills.Open;
  107. if not Assigned(sddBills.IndexList.FindByName('idxID')) then
  108. sddBills.AddIndex('idxID', 'ID');
  109. sddBills.FieldByName('OrgQuantity').ValidChars := sddBills.FieldByName('Quantity').ValidChars + ArithmeticCharSet;
  110. sddBills.FieldByName('MisQuantity').ValidChars := sddBills.FieldByName('Quantity').ValidChars + ArithmeticCharSet;
  111. sddBills.FieldByName('OthQuantity').ValidChars := sddBills.FieldByName('Quantity').ValidChars + ArithmeticCharSet;
  112. end;
  113. procedure TBillsData.Save;
  114. procedure ResolveCode(ARec: TsdDataRecord);
  115. var
  116. sgs: TStrings;
  117. i: Integer;
  118. sXiangCode, sMuCode, sJieCode, sXiMuCode: string;
  119. begin
  120. sgs := TStringList.Create;
  121. try
  122. sgs.Delimiter := '-';
  123. sgs.DelimitedText := ARec.ValueByName('Code').AsString;
  124. case sgs.Count of
  125. 1: sXiangCode := '';
  126. 2: sXiangCode := ChinessNum(StrToIntDef(sgs[1], 0));
  127. 3: sMuCode := sgs[2];
  128. 4: sJieCode := sgs[3];
  129. else
  130. begin
  131. for i := 4 to sgs.Count - 1 do
  132. if sXiMuCode = '' then
  133. sXiMuCode := sgs[i]
  134. else
  135. sXiMuCode := sXiMuCode + '-' + sgs[i];
  136. end;
  137. end;
  138. finally
  139. if (ARec.ValueByName('XiangCode').AsString <> sXiangCode) then
  140. ARec.ValueByName('XiangCode').AsString := sXiangCode;
  141. if (ARec.ValueByName('MuCode').AsString <> sMuCode) then
  142. ARec.ValueByName('MuCode').AsString := sMuCode;
  143. if (ARec.ValueByName('JieCode').AsString <> sJieCode) then
  144. ARec.ValueByName('JieCode').AsString := sJieCode;
  145. if (ARec.ValueByName('XiMuCode').AsString <> sXiMuCode) then
  146. ARec.ValueByName('XiMuCode').AsString := sXiMuCode;
  147. sgs.Free;
  148. end;
  149. end;
  150. procedure SaveReportsRela;
  151. var
  152. iIndex: Integer;
  153. stnNode: TsdIDTreeNode;
  154. iLeafXmjParentID: Integer;
  155. sIndexCode: string;
  156. begin
  157. sddBills.BeginUpdate;
  158. try
  159. with TProjectData(FProjectData).BillsCompileData do
  160. for iIndex := 0 to BillsCompileTree.Count - 1 do
  161. begin
  162. stnNode := BillsCompileTree.Items[iIndex];
  163. // 分项清单排序
  164. if (stnNode.Rec.ValueByName('SerialNo').AsString = '') or
  165. (stnNode.MajorIndex <> stnNode.Rec.ValueByName('SerialNo').AsInteger) then
  166. stnNode.Rec.ValueByName('SerialNo').AsInteger := stnNode.MajorIndex;
  167. // 叶子节点
  168. if (stnNode.Rec.ValueByName('IsLeaf').asBoolean <> not stnNode.HasChildren) then
  169. stnNode.Rec.ValueByName('IsLeaf').AsBoolean := not stnNode.HasChildren;
  170. // 最底项目节父节点ID
  171. if (stnNode.Rec.ValueByName('B_Code').AsString <> '') then
  172. iLeafXmjParentID := GetLeafXmjParentID(stnNode.ID)
  173. else
  174. iLeafXmjParentID := -1;
  175. if (stnNode.Rec.ValueByName('LeafXmjParentID').AsInteger <> iLeafXmjParentID) then
  176. stnNode.Rec.ValueByName('LeafXmjParentID').AsInteger := iLeafXmjParentID;
  177. // 分解项目节编号为项、目、节、细目
  178. if stnNode.Rec.ValueByName('Code').AsString <> '' then
  179. ResolveCode(stnNode.Rec);
  180. // 工程量清单排序Code
  181. if (stnNode.Rec.ValueByName('B_Code').AsString <> '') then
  182. begin
  183. sIndexCode := B_CodeToIndexCode(stnNode.Rec.ValueByName('B_Code').AsString);
  184. if (stnNode.Rec.ValueByName('IndexCode').AsString <> sIndexCode) then
  185. stnNode.Rec.ValueByName('IndexCode').AsString := sIndexCode;
  186. end;
  187. end;
  188. finally
  189. sddBills.EndUpdate;
  190. end;
  191. end;
  192. begin
  193. if TProjectData(FProjectData).BillsCompileData.Active then
  194. SaveReportsRela; // 保存 SerialNo, IsLeaf, LeafXmjParentID, 分解Code
  195. sddBills.Save;
  196. end;
  197. {procedure TBillsData.Calculate(ABillsID: Integer);
  198. var
  199. stnNode: TsdIDTreeNode;
  200. iChild: Integer;
  201. begin
  202. stnNode := FBillsTree.FindNode(ABillsID);
  203. if stnNode.HasChildren then
  204. begin
  205. for iChild := 0 to stnNode.ChildCount - 1 do
  206. Calculate(stnNode.ChildNodes[iChild].ID);
  207. end
  208. else
  209. begin
  210. CalculateOrg(ABillsID);
  211. CalculateDeal(ABillsID);
  212. CalculateQuantityChange(ABillsID);
  213. CalculatePriceChange(ABillsID);
  214. end;
  215. end;
  216. procedure TBillsData.CalculateDeal(ABillsID: Integer);
  217. var
  218. iIndex: Integer;
  219. fQuantity, fTotalPrice: Double;
  220. Rec: TsdDataRecord;
  221. begin
  222. fQuantity := 0;
  223. fTotalPrice := 0;
  224. with TProjectData(FProjectData) do
  225. for iIndex := 0 to PhaseCount - 1 do
  226. begin
  227. Rec := PhaseData[iIndex].PhaseRecord(ABillsID);
  228. if not Assigned(Rec) then Continue;
  229. fQuantity := fQuantity + Rec.ValueByName('DealQuantity').AsFloat;
  230. fTotalPrice := fTotalPrice + Rec.ValueByName('DealTotalPrice').AsFloat;
  231. end;
  232. with FBillsTree.FindNode(ABillsID).Rec do
  233. UpdateRecordDeal(ABillsID, fQuantity - ValueByName('AddDealQuantity').AsFloat,
  234. fTotalPrice - ValueByName('AddDealTotalPrice').AsFloat);
  235. end;
  236. procedure TBillsData.CalculatePriceChange(ABillsID: Integer);
  237. var
  238. iIndex: Integer;
  239. fQuantity, fTotalPrice: Double;
  240. Rec: TsdDataRecord;
  241. begin
  242. fQuantity := 0;
  243. fTotalPrice := 0;
  244. with TProjectData(FProjectData) do
  245. for iIndex := 0 to PhaseCount - 1 do
  246. begin
  247. Rec := PhaseData[iIndex].PhaseRecord(ABillsID);
  248. if not Assigned(Rec) then Continue;
  249. fQuantity := fQuantity + Rec.ValueByName('PcQuantity').AsFloat;
  250. fTotalPrice := fTotalPrice + Rec.ValueByName('PcTotalPrice').AsFloat;
  251. end;
  252. with FBillsTree.FindNode(ABillsID).Rec do
  253. UpdateRecordPc(ABillsID, fQuantity - ValueByName('AddPcQuantity').AsFloat,
  254. fTotalPrice - ValueByName('AddPcTotalPrice').AsFloat);
  255. end;
  256. procedure TBillsData.CalculateQuantityChange(ABillsID: Integer);
  257. var
  258. iIndex: Integer;
  259. fQuantity, fTotalPrice: Double;
  260. Rec: TsdDataRecord;
  261. begin
  262. fQuantity := 0;
  263. fTotalPrice := 0;
  264. with TProjectData(FProjectData) do
  265. for iIndex := 0 to PhaseCount - 1 do
  266. begin
  267. Rec := PhaseData[iIndex].PhaseRecord(ABillsID);
  268. if not Assigned(Rec) then Continue;
  269. fQuantity := fQuantity + Rec.ValueByName('QcQuantity').AsFloat;
  270. fTotalPrice := fTotalPrice + Rec.ValueByName('QcTotalPrice').AsFloat;
  271. end;
  272. with FBillsTree.FindNode(ABillsID).Rec do
  273. UpdateRecordQc(ABillsID, fQuantity - ValueByName('AddQcQuantity').AsFloat,
  274. fTotalPrice - ValueByName('AddQcTotalPrice').AsFloat);
  275. end; }
  276. {
  277. procedure TBillsData.RecursiveCalculate(ABillsID: Integer);
  278. procedure GatherChildValue(ANode: TsdIDTreeNode);
  279. var
  280. CacheRecord: TCacheRecord;
  281. iChild: Integer;
  282. begin
  283. CacheRecord := TCacheRecord.Create;
  284. try
  285. for iChild := 0 to ANode.ChildCount - 1 do
  286. with ANode.ChildNodes[iChild].Rec do
  287. begin
  288. CacheRecord.FTotalPrice := CacheRecord.FTotalPrice + ValueByName('TotalPrice').AsFloat;
  289. CacheRecord.FDealQuantity := CacheRecord.FDealQuantity + ValueByName('AddDealQuantity').AsFloat;
  290. CacheRecord.FDealTotalPrice := CacheRecord.FDealTotalPrice + ValueByName('AddDealTotalPrice').AsFloat;
  291. CacheRecord.FQcQuantity := CacheRecord.FQcQuantity + ValueByName('AddQcQuantity').AsFloat;
  292. CacheRecord.FQcTotalPrice := CacheRecord.FQcTotalPrice + ValueByName('AddQcTotalPrice').AsFloat;
  293. CacheRecord.FPcQuantity := CacheRecord.FPcQuantity + ValueByName('AddPcQuantity').AsFloat;
  294. CacheRecord.FPcTotalPrice := CacheRecord.FPcTotalPrice + ValueByName('AddPcTotalPrice').AsFloat;
  295. end;
  296. finally
  297. CacheRecord.SetBillsRecord(ANode);
  298. CacheRecord.Free;
  299. end;
  300. end;
  301. procedure CalculateLeafNode(ANode: TsdIDTreeNode; ACacheRecord: TCacheRecord);
  302. begin
  303. with ANode.Rec do
  304. begin
  305. if ValueByName('QtyFlag').AsInteger = 1 then
  306. ValueByName('Quantity').AsFloat := EvaluateExprs(ValueByName('QtyFormula').AsString);
  307. if ValueByName('QtyFlag').AsInteger < 2 then
  308. ACacheRecord.FTotalPrice := ValueByName('Quantity').AsFloat * ValueByName('Price').AsFloat
  309. else
  310. begin
  311. FFormulaCalc.SetRecordText(ValueByName('QtyFormula').AsString);
  312. ACacheRecord.FTotalPrice := FFormulaCalc.Value;
  313. end;
  314. end;
  315. end;
  316. procedure GatherPhaseValue(ANode: TsdIDTreeNode);
  317. var
  318. CacheRecord: TCacheRecord;
  319. iIndex: Integer;
  320. Rec: TsdDataRecord;
  321. begin
  322. CacheRecord := TCacheRecord.Create;
  323. try
  324. CalculateLeafNode(ANode, CacheRecord);
  325. {with TProjectData(FProjectData) do
  326. for iIndex := 0 to PhaseCount - 1 do
  327. begin
  328. PhaseData[iIndex].ReCalculate(ANode.ID);
  329. Rec := PhaseData[iIndex].PhaseRecord(ANode.ID);
  330. if not Assigned(Rec) then Continue;
  331. CacheRecord.FDealQuantity := CacheRecord.FDealQuantity + Rec.ValueByName('DealQuantity').AsFloat;
  332. CacheRecord.FDealTotalPrice := CacheRecord.FDealTotalPrice + Rec.ValueByName('DealTotalPrice').AsFloat;
  333. CacheRecord.FQcQuantity := CacheRecord.FQcQuantity + Rec.ValueByName('QcQuantity').AsFloat;
  334. CacheRecord.FQcTotalPrice := CacheRecord.FQcTotalPrice + Rec.ValueByName('QcTotalPrice').AsFloat;
  335. CacheRecord.FPcQuantity := CacheRecord.FPcQuantity + Rec.ValueByName('PcQuantity').AsFloat;
  336. CacheRecord.FPcTotalPrice := CacheRecord.FPcTotalPrice + Rec.ValueByName('PcTotalPrice').AsFloat;
  337. end;}
  338. { finally
  339. CacheRecord.SetBillsRecord(ANode);
  340. CacheRecord.Free;
  341. end;
  342. end;
  343. procedure CalculateCurNode(ANode: TsdIDTreeNode);
  344. begin
  345. if ANode.HasChildren then
  346. GatherChildValue(ANode)
  347. else
  348. GatherPhaseValue(ANode);
  349. end;
  350. procedure CalculateAllChildren(ANode: TsdIDTreeNode);
  351. var
  352. iChild: Integer;
  353. begin
  354. if ANode.HasChildren then
  355. for iChild := 0 to ANode.ChildCount - 1 do
  356. RecursiveCalculate(ANode.ChildNodes[iChild].ID);
  357. end;
  358. var
  359. stnNode: TsdIDTreeNode;
  360. begin
  361. stnNode := FBillsTree.FindNode(ABillsID);
  362. CalculateAllChildren(stnNode);
  363. CalculateCurNode(stnNode);
  364. end; }
  365. procedure TBillsData.InitBills;
  366. var
  367. Import: TBillsExcelImport;
  368. begin
  369. Import := TBillsExcelImport.Create(TProjectData(ProjectData));
  370. try
  371. Import.ImportFile(GetTemplateBillsFileName);
  372. finally
  373. Import.Free;
  374. end;
  375. end;
  376. function TBillsData.GetStageData: TStageData;
  377. begin
  378. Result := TProjectData(FProjectData).PhaseData.StageData;
  379. end;
  380. procedure TBillsData.LockedBaseData;
  381. var
  382. iIndex: Integer;
  383. begin
  384. sddBills.BeginUpdate;
  385. for iIndex := 0 to sddBills.RecordCount - 1 do
  386. begin
  387. if not sddBills.Records[iIndex].ValueByName('LockedLevel').AsBoolean then
  388. sddBills.Records[iIndex].ValueByName('LockedLevel').AsBoolean := True;
  389. if not sddBills.Records[iIndex].ValueByName('LockedInfo').AsBoolean then
  390. sddBills.Records[iIndex].ValueByName('LockedInfo').AsBoolean := True;
  391. if sddBills.Records[iIndex].ValueByName('NewPrice').AsFloat <> 0 then
  392. sddBills.Records[iIndex].ValueByName('LockedNewPrice').AsBoolean := True;
  393. end;
  394. sddBills.EndUpdate;
  395. end;
  396. procedure TBillsData.sddBillsAfterAddRecord(ARecord: TsdDataRecord);
  397. begin
  398. ARecord.ValueByName('CreatePhaseID').AsInteger := TProjectData(FProjectData).PhaseIndex;
  399. end;
  400. function TBillsData.GetBuildLoadInterest(AIndex: Integer): Double;
  401. begin
  402. Result := GetGatherTotalPrice(34, AIndex);
  403. end;
  404. function TBillsData.GetFirstPart(AIndex: Integer): Double;
  405. begin
  406. Result := GetGatherTotalPrice(1, AIndex);
  407. end;
  408. function TBillsData.GetOtherFee(AIndex: Integer): Double;
  409. begin
  410. Result := GetGatherTotalPrice(15, AIndex);
  411. end;
  412. function TBillsData.GetOtherProjectFee(AIndex: Integer): Double;
  413. begin
  414. Result := GetGatherTotalPrice(9, AIndex);
  415. end;
  416. function TBillsData.GetRecyclingFee(AIndex: Integer): Double;
  417. begin
  418. Result := GetGatherTotalPrice(16, AIndex);
  419. end;
  420. function TBillsData.GetReservedFee(AIndex: Integer): Double;
  421. begin
  422. Result := GetGatherTotalPrice(7, AIndex);
  423. end;
  424. function TBillsData.GetSecondPart(AIndex: Integer): Double;
  425. begin
  426. Result := GetGatherTotalPrice(2, AIndex);
  427. end;
  428. function TBillsData.GetStageSettlement(AIndex: Integer): Double;
  429. begin
  430. // 全国
  431. // 第一部分+第二部分+第三部分+预备费+新增加费用项目(其他费用_广东)-回收金额
  432. Result := FirstPart[AIndex] + SecondPart[AIndex] + ThirdPart[AIndex]
  433. + ReservedFee[AIndex] + OtherFee[AIndex] - RecyclingFee[AIndex];
  434. // 广东
  435. // 全国的基础上+建设期贷款利息+公路功能以外的项目
  436. if _IsGuangDong then
  437. Result := Result + BuildLoadInterest[AIndex] + OtherProjectFee[AIndex];
  438. end;
  439. function TBillsData.GetThirdPart(AIndex: Integer): Double;
  440. begin
  441. Result := GetGatherTotalPrice(3, AIndex);
  442. end;
  443. function TBillsData.GetGatherTotalPrice(ABillsID, AIndex: Integer): Double;
  444. var
  445. Rec: TsdDataRecord;
  446. begin
  447. Result := 0;
  448. Rec := sddBills.FindKey('idxID', ABillsID);
  449. if Assigned(Rec) then
  450. begin
  451. case AIndex of
  452. 0: Result := Rec.ValueByName('TotalPrice').AsFloat;
  453. 1: Result := Rec.ValueByName('AddDealTotalPrice').AsFloat;
  454. 2: Result := Rec.ValueByName('AddQcTotalPrice').AsFloat;
  455. 3: Result := Rec.ValueByName('AddPcTotalPrice').AsFloat;
  456. 4: Result := Rec.ValueByName('AddGatherTotalPrice').AsFloat;
  457. end;
  458. end;
  459. end;
  460. procedure TBillsData.DisableEvents;
  461. begin
  462. sddBills.BeforeValueChange := nil;
  463. sddBills.AfterValueChanged := nil;
  464. end;
  465. procedure TBillsData.EnableEvents;
  466. begin
  467. {sddBills.BeforeValueChange := sddBillsBeforeValueChange;
  468. sddBills.AfterValueChanged := sddBillsAfterValueChanged;}
  469. end;
  470. procedure TBillsData.UnLockedBaseData;
  471. var
  472. iIndex: Integer;
  473. begin
  474. for iIndex := 0 to sddBills.RecordCount - 1 do
  475. sddBills.Records[iIndex].ValueByName('LockedInfo').AsBoolean := False;
  476. end;
  477. procedure TBillsData.sddBillsBeforeDeleteRecord(ARecord: TsdDataRecord;
  478. var Allow: Boolean);
  479. begin
  480. with TProjectData(FProjectData) do
  481. begin
  482. if ProjProperties.PhaseCount > 0 then
  483. PhaseData.StageData.DeletePhaseRecord(ARecord.ValueByName('ID').AsInteger);
  484. end;
  485. end;
  486. procedure TBillsData.sddBillsBeforeValueChange(AValue: TsdValue;
  487. const NewValue: Variant; var Allow: Boolean);
  488. begin
  489. if (Pos('DgnQuantity', AValue.FieldName) > 0) and
  490. not (VarIsNull(NewValue) or (NewValue = 0)) then
  491. begin
  492. if AValue.Owner.ValueByName('B_Code').AsString <> '' then
  493. begin
  494. ErrorMessage('仅项目节可以输入设计数量!');
  495. Allow := False;
  496. end;
  497. end;
  498. end;
  499. function TBillsData.GetMaxBillsID: Integer;
  500. var
  501. Rec: TsdDataRecord;
  502. i: Integer;
  503. begin
  504. Result := 100;
  505. for i := 0 to sddBills.RecordCount - 1 do
  506. begin
  507. Rec := sddBills.Records[i];
  508. if Rec.ValueByName('ID').AsInteger > Result then
  509. Result := Rec.ValueByName('ID').AsInteger;
  510. end;
  511. end;
  512. procedure TBillsData.sddBillsGetRecordClass(
  513. var ARecordClass: TsdRecordClass);
  514. begin
  515. ARecordClass := TBillsRecord;
  516. end;
  517. end.