stgSelectFileFrm.pas 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320
  1. unit stgSelectFileFrm;
  2. interface
  3. uses
  4. stgGatherControl,
  5. Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  6. Dialogs, StdCtrls, ExtCtrls, sdGridDBA, sdGridTreeDBA, ZJGrid, sdIDTree;
  7. type
  8. TstgSelectFileForm = class(TForm)
  9. pnlTop: TPanel;
  10. leSumBaseFile: TLabeledEdit;
  11. btnSelectSbf: TButton;
  12. pnlGatherFiles: TPanel;
  13. pnlSelect: TPanel;
  14. zgTenderSelect: TZJGrid;
  15. pnlSelectTitle: TPanel;
  16. lblTenderList: TLabel;
  17. stdTenderSelect: TsdGridTreeDBA;
  18. pnlDivision: TPanel;
  19. pnlResult: TPanel;
  20. zgResult: TZJGrid;
  21. pnlResultTitle: TPanel;
  22. lblResultList: TLabel;
  23. pnlBottom: TPanel;
  24. btnOk: TButton;
  25. btnCancel: TButton;
  26. procedure zgTenderSelectDrawCellText(ACanvas: TCanvas;
  27. const ARect: TRect; const ACoord: TPoint; AGrid: TZJGrid;
  28. const Text: String; var ADefaultDraw: Boolean);
  29. procedure zgTenderSelectShowHint(var HintStr: String;
  30. var CanShow: Boolean; var HintInfo: THintInfo; const ACoord: TPoint);
  31. procedure zgTenderSelectSetCellText(Sender: TObject;
  32. const ACoord: TPoint; var Value: String; DisplayText: Boolean);
  33. procedure zgTenderSelectGetCellText(Sender: TObject;
  34. const ACoord: TPoint; var Value: String; DisplayText: Boolean);
  35. procedure zgTenderSelectCellTextChanged(Sender: TObject; Col,
  36. Row: Integer);
  37. procedure btnOkClick(Sender: TObject);
  38. procedure btnSelectSbfClick(Sender: TObject);
  39. private
  40. FSelects: TList;
  41. procedure AddRows(ANode: TsdIDTreeNode);
  42. procedure RemoveRows(ANode: TsdIDTreeNode);
  43. procedure InitResultGrid;
  44. procedure AssignResultGrid;
  45. procedure AssignResult;
  46. function GetSelectCount: Integer;
  47. public
  48. constructor Create(AGatherControl: TstgGatherControl);
  49. destructor Destroy; override;
  50. procedure AssignSelect(AGatherControl: TstgGatherControl);
  51. property SelectCount: Integer read GetSelectCount;
  52. end;
  53. function SelectFileForSubTenderGather(AGatherControl: TstgGatherControl): Boolean;
  54. implementation
  55. uses MainFrm, Globals, UtilMethods;
  56. {$R *.dfm}
  57. function SelectFileForSubTenderGather(AGatherControl: TstgGatherControl): Boolean;
  58. var
  59. vSelectFrm: TstgSelectFileForm;
  60. begin
  61. vSelectFrm := TstgSelectFileForm.Create(AGatherControl);
  62. try
  63. Result := vSelectFrm.ShowModal = mrOk;
  64. if Result then
  65. vSelectFrm.AssignSelect(AGatherControl);
  66. finally
  67. vSelectFrm.Free;
  68. end;
  69. end;
  70. procedure TstgSelectFileForm.zgTenderSelectDrawCellText(ACanvas: TCanvas;
  71. const ARect: TRect; const ACoord: TPoint; AGrid: TZJGrid;
  72. const Text: String; var ADefaultDraw: Boolean);
  73. procedure GetBitmap(AImage: TBitmap);
  74. begin
  75. with stdTenderSelect.IDTree.Items[ACoord.Y - 1] do
  76. if Rec.ValueByName('Type').AsInteger = 0 then
  77. if Expanded and HasChildren then
  78. MainForm.Images.GetBitmap(34, AImage)
  79. else
  80. MainForm.Images.GetBitmap(34, AImage)
  81. else
  82. MainForm.Images.GetBitmap(11, AImage);
  83. end;
  84. const
  85. rIconWidth = 16;
  86. rIconHeight = 16;
  87. var
  88. Img: TBitmap;
  89. Cell: TZjCell;
  90. rImg: TRect;
  91. begin
  92. if (ACoord.X = 2) and (ACoord.Y > zgTenderSelect.FixedRowCount - 1) then
  93. begin
  94. Cell := zgTenderSelect.Cells[ACoord.X, ACoord.Y];
  95. Img := TBitmap.Create;
  96. try
  97. GetBitmap(Img);
  98. case Cell.Align of
  99. gaTopLeft, gaTopCenter, gaTopRight:
  100. rImg := Rect(ARect.Left + 2, ARect.Top, ARect.Left + rIconWidth, ARect.Top + rIconHeight);
  101. gaCenterLeft, gaCenterCenter, gaCenterRight:
  102. rImg := Rect(ARect.Left + 2, ARect.Top + (ARect.Bottom - ARect.Top - rIconHeight) div 2, ARect.Left + rIconWidth, ARect.Bottom - (ARect.Bottom - ARect.Top - rIconHeight) div 2);
  103. gaBottomLeft, gaBottomCenter, gaBottomRight:
  104. rImg := Rect(ARect.Left + 2, ARect.Bottom - rIconHeight, ARect.Left + rIconWidth, ARect.Bottom);
  105. end;
  106. ACanvas.StretchDraw(rImg, Img);
  107. WriteText(ACanvas, Rect(ARect.Left + rIconWidth, ARect.Top, ARect.Right, ARect.Bottom)
  108. , 2, 2, Text, Cell.Align, False);
  109. ADefaultDraw := False;
  110. finally
  111. Img.Free;
  112. end;
  113. end;
  114. end;
  115. procedure TstgSelectFileForm.zgTenderSelectShowHint(var HintStr: String;
  116. var CanShow: Boolean; var HintInfo: THintInfo; const ACoord: TPoint);
  117. var
  118. vCell: TZjCell;
  119. vNode: TsdIDTreeNode;
  120. iLevelWidth: Integer;
  121. rText: TRect;
  122. procedure CalcTextRect(var R: TRect);
  123. var
  124. DC: HDC;
  125. iTextHeight: Integer;
  126. begin
  127. DC := CreateCompatibleDC(0);
  128. try
  129. SelectObject(DC, vCell.Font.Handle);
  130. iTextHeight := DrawText(DC, PChar(vCell.Text), Length(vCell.Text), R, DT_SINGLELINE or DT_VCenter
  131. or DT_NOCLIP or DT_CALCRECT);
  132. finally
  133. DeleteDC(DC);
  134. end;
  135. end;
  136. begin
  137. if ACoord.Y < 1 then Exit;
  138. vCell := zgTenderSelect.Cells[ACoord.X, ACoord.Y];
  139. with HintInfo do
  140. begin
  141. vNode := stdTenderSelect.IDTree.Items[ACoord.Y - 1];
  142. if not Assigned(vNode) then Exit;
  143. iLevelWidth := (vNode.Level + 1) * 20 + 16;
  144. rText := CursorRect;
  145. CalcTextRect(rText);
  146. if (rText.Right - rText.Left + iLevelWidth > CursorRect.Right - CursorRect.Left) or
  147. (rText.Right > ClientWidth) then
  148. begin
  149. CanShow := True;
  150. HintStr := vCell.Text;
  151. GetCursorPos(HintPos);
  152. end;
  153. end;
  154. end;
  155. procedure TstgSelectFileForm.zgTenderSelectSetCellText(Sender: TObject;
  156. const ACoord: TPoint; var Value: String; DisplayText: Boolean);
  157. var
  158. stnNode: TsdIDTreeNode;
  159. begin
  160. if ACoord.X = 1 then
  161. begin
  162. stnNode := stdTenderSelect.IDTree.Items[ACoord.Y - 1];
  163. if Value = 'True' then
  164. AddRows(stnNode)
  165. else
  166. RemoveRows(stnNode);
  167. AssignResult;
  168. end;
  169. end;
  170. procedure TstgSelectFileForm.zgTenderSelectGetCellText(Sender: TObject;
  171. const ACoord: TPoint; var Value: String; DisplayText: Boolean);
  172. var
  173. stnNode: TsdIDTreeNode;
  174. begin
  175. if ACoord.X = 1 then
  176. begin
  177. stnNode := stdTenderSelect.IDTree.Items[ACoord.Y - 1];
  178. if Assigned(stnNode) and (FSelects.IndexOf(Pointer(stnNode.ID)) > -1) then
  179. Value := 'True';
  180. end;
  181. end;
  182. procedure TstgSelectFileForm.zgTenderSelectCellTextChanged(Sender: TObject;
  183. Col, Row: Integer);
  184. begin
  185. if (Col = 1) then
  186. zgTenderSelect.InvalidateCol(1);
  187. end;
  188. procedure TstgSelectFileForm.AddRows(ANode: TsdIDTreeNode);
  189. var
  190. iChild: Integer;
  191. begin
  192. if not Assigned(ANode) then Exit;
  193. if FSelects.IndexOf(Pointer(ANode.ID)) = -1 then
  194. FSelects.Add(Pointer(ANode.ID));
  195. if ANode.HasChildren then
  196. for iChild := 0 to ANode.ChildCount - 1 do
  197. AddRows(ANode.ChildNodes[iChild]);
  198. end;
  199. procedure TstgSelectFileForm.RemoveRows(ANode: TsdIDTreeNode);
  200. var
  201. iChild: Integer;
  202. begin
  203. if not Assigned(ANode) then Exit;
  204. if FSelects.IndexOf(Pointer(ANode.ID)) > -1 then
  205. FSelects.Remove(Pointer(ANode.ID));
  206. if ANode.HasChildren then
  207. for iChild := 0 to ANode.ChildCount - 1 do
  208. RemoveRows(ANode.ChildNodes[iChild]);
  209. end;
  210. procedure TstgSelectFileForm.InitResultGrid;
  211. begin
  212. zgResult.ColCount := 2;
  213. zgResult.RowCount := 1;
  214. zgResult.Cells[1, 0].Text := '所选项目';
  215. zgResult.ColWidths[1] := 365;
  216. end;
  217. procedure TstgSelectFileForm.AssignResultGrid;
  218. var
  219. i, iID: Integer;
  220. vNode: TsdIDTreeNode;
  221. begin
  222. for i := 0 to FSelects.Count - 1 do
  223. begin
  224. iID := Integer(FSelects.Items[i]);
  225. vNode := stdTenderSelect.IDTree.FindNode(iID);
  226. if vNode.Rec.ValueByName('Type').AsInteger = 1 then
  227. begin
  228. zgResult.RowCount := zgResult.RowCount + 1;
  229. zgResult.Cells[1, zgResult.RowCount - 1].Text := vNode.Rec.ValueByName('Name').AsString;
  230. zgResult.Cells[1, zgResult.RowCount - 1].Align := gaCenterLeft;
  231. zgResult.Rows[zgResult.RowCount - 1].Data := vNode;
  232. end;
  233. end;
  234. end;
  235. procedure TstgSelectFileForm.AssignSelect(AGatherControl: TstgGatherControl);
  236. begin
  237. AGatherControl.SumBaseFile := leSumBaseFile.Text;
  238. AGatherControl.Projects.Assign(FSelects);
  239. end;
  240. constructor TstgSelectFileForm.Create(AGatherControl: TstgGatherControl);
  241. begin
  242. inherited Create(nil);
  243. stdTenderSelect.DataView := ProjectManager.sdvProjectsSpare;
  244. FSelects := TList.Create;
  245. FSelects.Assign(AGatherControl.Projects);
  246. InitResultGrid;
  247. leSumBaseFile.Text := AGatherControl.SumBaseFile;
  248. end;
  249. destructor TstgSelectFileForm.Destroy;
  250. begin
  251. FSelects.Free;
  252. inherited;
  253. end;
  254. procedure TstgSelectFileForm.AssignResult;
  255. begin
  256. InitResultGrid;
  257. AssignResultGrid;
  258. end;
  259. procedure TstgSelectFileForm.btnOkClick(Sender: TObject);
  260. begin
  261. if (leSumBaseFile.Text = '') then
  262. WarningMessage('请选择总包基准文件。', Handle)
  263. else if not FileExists(leSumBaseFile.Text) then
  264. WarningMessage('当前选择的总包基准文件不存在,请重新选择。', Handle)
  265. else if SelectCount = 0 then
  266. WarningMessage('请选择需要汇总的分包标段。', Handle)
  267. else
  268. ModalResult := mrOk;
  269. end;
  270. function TstgSelectFileForm.GetSelectCount: Integer;
  271. begin
  272. Result := zgResult.RowCount - zgResult.FixedRowCount;
  273. end;
  274. procedure TstgSelectFileForm.btnSelectSbfClick(Sender: TObject);
  275. var
  276. sFileName: string;
  277. begin
  278. sFileName := leSumBaseFile.Text;
  279. if SelectFile(sFileName, '.sbf') then
  280. leSumBaseFile.Text := sFileName;
  281. end;
  282. end.