| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203 | unit rpgBillsCalcDm;interfaceuses  SysUtils, Classes, sdDB, sdProvider, ADODB, ProjGatherTree, CalcData;type  TrpgBillsCalcData = class(TDataModule)    sdpBillsCalc: TsdADOProvider;    sddBillsCalc: TsdDataSet;  private    FProjIndex: Integer;    FProjType: Integer;    procedure SaveBillsNodeCalc(ANode: TProjGatherTreeNode; AProjCalc: TProjCalc);    procedure SaveBillsCalc(ATree: TProjGatherTree);    procedure SaveBillsGather(ATree: TProjGatherTree);  public    constructor Create(AConnection: TADOConnection);    procedure SaveSpecialProjDataTo(ATree: TProjGatherTree; AProjType: Integer; const ATableName: string);    procedure SaveProjDataTo(ATree: TProjGatherTree; AProjIndex: Integer; const ATableName: string);    procedure SaveGatherDataTo(ATree: TProjGatherTree; const ATableName: string);  end;implementationuses CacheTree;{$R *.dfm}{ TrpgBillsCalcData }constructor TrpgBillsCalcData.Create(AConnection: TADOConnection);begin  inherited Create(nil);  sdpBillsCalc.Connection := AConnection;end;procedure TrpgBillsCalcData.SaveBillsCalc(ATree: TProjGatherTree);var  iNode: Integer;  vNode: TProjGatherTreeNode;begin  for iNode := 0 to ATree.CacheNodes.Count - 1 do  begin    vNode := TProjGatherTreeNode(ATree.CacheNodes.Items[iNode]);    if FProjType = 0 then      SaveBillsNodeCalc(vNode, vNode.Proj[FProjIndex])    else if FProjType > 0 then      SaveBillsNodeCalc(vNode, vNode.SpecialProj[FProjType-1]);  end;end;procedure TrpgBillsCalcData.SaveBillsGather(ATree: TProjGatherTree);var  iNode: Integer;  vNode: TProjGatherTreeNode;begin  for iNode := 0 to ATree.CacheNodes.Count - 1 do  begin    vNode := TProjGatherTreeNode(ATree.CacheNodes.Items[iNode]);    SaveBillsNodeCalc(vNode, vNode.GatherCalc);  end;end;procedure TrpgBillsCalcData.SaveBillsNodeCalc(ANode: TProjGatherTreeNode;  AProjCalc: TProjCalc);var  Rec: TsdDataRecord;begin  Rec := sddBillsCalc.Add;  Rec.ValueByName('ID').AsInteger := ANode.ID;  Rec.ValueByName('ProjID').AsInteger := FProjIndex;  Rec.ValueByName('ProjType').AsInteger := FProjType;  Rec.ValueByName('OrgQuantity').AsFloat := AProjCalc.Compile.Org.Quantity;  Rec.ValueByName('OrgTotalPrice').AsFloat := AProjCalc.Compile.Org.TotalPrice;  Rec.ValueByName('OrgTotalPrice_Rc').AsFloat := AProjCalc.Compile.Org.TotalPrice_Rc;  Rec.ValueByName('MisQuantity').AsFloat := AProjCalc.Compile.Mis.Quantity;  Rec.ValueByName('MisTotalPrice').AsFloat := AProjCalc.Compile.Mis.TotalPrice;  Rec.ValueByName('MisTotalPrice_Rc').AsFloat := AProjCalc.Compile.Mis.TotalPrice_Rc;  Rec.ValueByName('OthQuantity').AsFloat := AProjCalc.Compile.Oth.Quantity;  Rec.ValueByName('OthTotalPrice').AsFloat := AProjCalc.Compile.Oth.TotalPrice;  Rec.ValueByName('OthTotalPrice_Rc').AsFloat := AProjCalc.Compile.Oth.TotalPrice_Rc;  Rec.ValueByName('Quantity').AsFloat := AProjCalc.Compile.SubTotal.Quantity;  Rec.ValueByName('TotalPrice').AsFloat := AProjCalc.Compile.SubTotal.TotalPrice;  Rec.ValueByName('TotalPrice_Rc').AsFloat := AProjCalc.Compile.SubTotal.TotalPrice_Rc;  Rec.ValueByName('AddDealQuantity').AsFloat := AProjCalc.AddMeasure.Deal.Quantity;  Rec.ValueByName('AddDealTotalPrice').AsFloat := AProjCalc.AddMeasure.Deal.TotalPrice;  Rec.ValueByName('AddDealTotalPrice_Rc').AsFloat := AProjCalc.AddMeasure.Deal.TotalPrice_Rc;  Rec.ValueByName('AddQcQuantity').AsFloat := AProjCalc.AddMeasure.Qc.Quantity;  Rec.ValueByName('AddQcTotalPrice').AsFloat := AProjCalc.AddMeasure.Qc.TotalPrice;  Rec.ValueByName('AddQcTotalPrice_Rc').AsFloat := AProjCalc.AddMeasure.Qc.TotalPrice_Rc;  Rec.ValueByName('AddGatherQuantity').AsFloat := AProjCalc.AddMeasure.Gather.Quantity;  Rec.ValueByName('AddGatherTotalPrice').AsFloat := AProjCalc.AddMeasure.Gather.TotalPrice;  Rec.ValueByName('AddGatherTotalPrice_Rc').AsFloat := AProjCalc.AddMeasure.Gather.TotalPrice_Rc;  Rec.ValueByName('CurDealQuantity').AsFloat := AProjCalc.CurMeasure.Deal.Quantity;  Rec.ValueByName('CurDealTotalPrice').AsFloat := AProjCalc.CurMeasure.Deal.TotalPrice;  Rec.ValueByName('CurDealTotalPrice_Rc').AsFloat := AProjCalc.CurMeasure.Deal.TotalPrice_Rc;  Rec.ValueByName('CurQcQuantity').AsFloat := AProjCalc.CurMeasure.Qc.Quantity;  Rec.ValueByName('CurQcTotalPrice').AsFloat := AProjCalc.CurMeasure.Qc.TotalPrice;  Rec.ValueByName('CurQcTotalPrice_Rc').AsFloat := AProjCalc.CurMeasure.Qc.TotalPrice_Rc;  Rec.ValueByName('CurGatherQuantity').AsFloat := AProjCalc.CurMeasure.Gather.Quantity;  Rec.ValueByName('CurGatherTotalPrice').AsFloat := AProjCalc.CurMeasure.Gather.TotalPrice;  Rec.ValueByName('CurGatherTotalPrice_Rc').AsFloat := AProjCalc.CurMeasure.Gather.TotalPrice_Rc;  Rec.ValueByName('PreDealQuantity').AsFloat := AProjCalc.PreMeasure.Deal.Quantity;  Rec.ValueByName('PreDealTotalPrice').AsFloat := AProjCalc.PreMeasure.Deal.TotalPrice;  Rec.ValueByName('PreDealTotalPrice_Rc').AsFloat := AProjCalc.PreMeasure.Deal.TotalPrice_Rc;  Rec.ValueByName('PreQcQuantity').AsFloat := AProjCalc.PreMeasure.Qc.Quantity;  Rec.ValueByName('PreQcTotalPrice').AsFloat := AProjCalc.PreMeasure.Qc.TotalPrice;  Rec.ValueByName('PreQcTotalPrice_Rc').AsFloat := AProjCalc.PreMeasure.Qc.TotalPrice_Rc;  Rec.ValueByName('PreGatherQuantity').AsFloat := AProjCalc.PreMeasure.Gather.Quantity;  Rec.ValueByName('PreGatherTotalPrice').AsFloat := AProjCalc.PreMeasure.Gather.TotalPrice;  Rec.ValueByName('PreGatherTotalPrice_Rc').AsFloat := AProjCalc.PreMeasure.Gather.TotalPrice_Rc;  Rec.ValueByName('EndDealQuantity').AsFloat := AProjCalc.EndMeasure.Deal.Quantity;  Rec.ValueByName('EndDealTotalPrice').AsFloat := AProjCalc.EndMeasure.Deal.TotalPrice;  Rec.ValueByName('EndDealTotalPrice_Rc').AsFloat := AProjCalc.EndMeasure.Deal.TotalPrice_Rc;  Rec.ValueByName('EndQcQuantity').AsFloat := AProjCalc.EndMeasure.Qc.Quantity;  Rec.ValueByName('EndQcTotalPrice').AsFloat := AProjCalc.EndMeasure.Qc.TotalPrice;  Rec.ValueByName('EndQcTotalPrice_Rc').AsFloat := AProjCalc.EndMeasure.Qc.TotalPrice_Rc;  Rec.ValueByName('EndGatherQuantity').AsFloat := AProjCalc.EndMeasure.Gather.Quantity;  Rec.ValueByName('EndGatherTotalPrice').AsFloat := AProjCalc.EndMeasure.Gather.TotalPrice;  Rec.ValueByName('EndGatherTotalPrice_Rc').AsFloat := AProjCalc.EndMeasure.Gather.TotalPrice_Rc;  Rec.ValueByName('ZoneDealQuantity').AsFloat := AProjCalc.ZoneMeasure.Deal.Quantity;  Rec.ValueByName('ZoneDealTotalPrice').AsFloat := AProjCalc.ZoneMeasure.Deal.TotalPrice;  Rec.ValueByName('ZoneDealTotalPrice_Rc').AsFloat := AProjCalc.ZoneMeasure.Deal.TotalPrice_Rc;  Rec.ValueByName('ZoneQcQuantity').AsFloat := AProjCalc.ZoneMeasure.Qc.Quantity;  Rec.ValueByName('ZoneQcTotalPrice').AsFloat := AProjCalc.ZoneMeasure.Qc.TotalPrice;  Rec.ValueByName('ZoneQcTotalPrice_Rc').AsFloat := AProjCalc.ZoneMeasure.Qc.TotalPrice_Rc;  Rec.ValueByName('ZoneGatherQuantity').AsFloat := AProjCalc.ZoneMeasure.Gather.Quantity;  Rec.ValueByName('ZoneGatherTotalPrice').AsFloat := AProjCalc.ZoneMeasure.Gather.TotalPrice;  Rec.ValueByName('ZoneGatherTotalPrice_Rc').AsFloat := AProjCalc.ZoneMeasure.Gather.TotalPrice_Rc;  Rec.ValueByName('DgnQuantity1').AsFloat := AProjCalc.DgnQuantity1;  Rec.ValueByName('DgnQuantity2').AsFloat := AProjCalc.DgnQuantity2;  Rec.ValueByName('DealDgnQuantity1').AsFloat := AProjCalc.DealDgnQuantity1;  Rec.ValueByName('DealDgnQuantity2').AsFloat := AProjCalc.DealDgnQuantity2;  Rec.ValueByName('CDgnQuantity1').AsFloat := AProjCalc.CDgnQuantity1;  Rec.ValueByName('CDgnQuantity2').AsFloat := AProjCalc.CDgnQuantity2;end;procedure TrpgBillsCalcData.SaveGatherDataTo(ATree: TProjGatherTree;  const ATableName: string);begin  FProjIndex := -2;  FProjType := 0;  sdpBillsCalc.TableName := ATableName;  sddBillsCalc.Open;  sddBillsCalc.BeginUpdate;  try    SaveBillsGather(ATree);    SaveBillsNodeCalc(ATree.GatherNode, ATree.GatherNode.GatherCalc);  finally    sddBillsCalc.EndUpdate;    sddBillsCalc.Save;  end;end;procedure TrpgBillsCalcData.SaveProjDataTo(ATree: TProjGatherTree; AProjIndex: Integer;  const ATableName: string);begin  FProjIndex := AProjIndex;  FProjType := 0;  sdpBillsCalc.TableName := ATableName;  sddBillsCalc.Open;  sddBillsCalc.BeginUpdate;  try    SaveBillsCalc(ATree);    SaveBillsNodeCalc(ATree.GatherNode, ATree.GatherNode.Proj[AProjIndex]);  finally    sddBillsCalc.EndUpdate;    sddBillsCalc.Save;  end;end;procedure TrpgBillsCalcData.SaveSpecialProjDataTo(ATree: TProjGatherTree;  AProjType: Integer; const ATableName: string);begin  FProjIndex := -3;  FProjType := AProjType;  sdpBillsCalc.TableName := ATableName;  sddBillsCalc.Open;  sddBillsCalc.BeginUpdate;  try    SaveBillsCalc(ATree);    SaveBillsNodeCalc(ATree.GatherNode, ATree.GatherNode.SpecialProj[AProjType-1]);  finally    sddBillsCalc.EndUpdate;    sddBillsCalc.Save;  end;end;end.
 |