QueryWizardForm.cs 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369
  1. using System;
  2. using System.Drawing;
  3. using System.Windows.Forms;
  4. using FastReport.Utils;
  5. using FastReport.Data;
  6. using FastReport.Design;
  7. using System.Linq;
  8. using System.Collections.Generic;
  9. using System.Text.RegularExpressions;
  10. namespace FastReport.Forms
  11. {
  12. internal partial class QueryWizardForm : BaseWizardForm
  13. {
  14. private TableDataSource table;
  15. public override int VisiblePanelIndex
  16. {
  17. get { return base.VisiblePanelIndex; }
  18. set
  19. {
  20. if (value == 1 && table.Connection != null)
  21. {
  22. var unavailableName = table.Connection.Tables.Cast<TableDataSource>()
  23. .Where(t => t.TableName.Replace("\"", "") == tbName.Text || (t.TableName == "" && t.Alias == tbName.Text))
  24. .Any();
  25. if (unavailableName && tbName.Text != table.Name && table.Alias != tbName.Text)
  26. {
  27. FRMessageBox.Error(Res.Get("Forms,QueryWizard,DuplicateName"));
  28. value--;
  29. }
  30. }
  31. // disable page 2,3 in case of non-sql datasource
  32. if (table.Connection == null || !table.Connection.IsSqlBased)
  33. {
  34. if (value == 1)
  35. value = 3;
  36. if (value == 2)
  37. value = 0;
  38. }
  39. if (value == 2)
  40. {
  41. List<string> duplicateParamName = new List<string>();
  42. if (tbSql.Text.Length > 0)
  43. {
  44. MatchCollection param = Regex.Matches(tbSql.Text, @"@(\w+)\b");
  45. var distinctParams = param.Cast<Match>().Select(match => match.Groups[1].Value).Distinct();
  46. duplicateParamName = param.Cast<Match>()
  47. .Select(match => match.Groups[1].Value)
  48. .GroupBy(word => word)
  49. .Where(group => group.Count() > 1)
  50. .Select(group => group.Key)
  51. .ToList();
  52. foreach (var match in distinctParams)
  53. {
  54. CommandParameter c = new CommandParameter();
  55. c.Name = match;
  56. c.DataType = table.Connection.GetDefaultParameterType();
  57. if (!table.Parameters.Contains(table.Parameters.FindByName(c.Name)))
  58. table.Parameters.Add(c);
  59. }
  60. }
  61. if (duplicateParamName.Count > 0)
  62. {
  63. string warningMessage = Res.Get("Forms,QueryWizard,DuplicateParamName");
  64. FRMessageBox.Warning(string.Format(warningMessage, string.Join(", ", duplicateParamName)));
  65. }
  66. UpdateParamTree(null);
  67. }
  68. if (value == 3)
  69. {
  70. table.Alias = tbName.Text;
  71. table.SelectCommand = tbSql.Text;
  72. try
  73. {
  74. table.RefreshTable();
  75. UpdateColumnTree(null);
  76. }
  77. catch (Exception e)
  78. {
  79. FRMessageBox.Error(e.Message);
  80. }
  81. }
  82. base.VisiblePanelIndex = value;
  83. }
  84. }
  85. public bool ForParamEdit
  86. {
  87. set
  88. {
  89. if (value)
  90. {
  91. btnNext.Enabled = false;
  92. btnPrevious.Enabled = false;
  93. btnFinish.Enabled = true;
  94. tsParameters.Enabled = false;
  95. }
  96. }
  97. }
  98. private void tbSql_KeyDown(object sender, KeyEventArgs e)
  99. {
  100. if (e.KeyData == (Keys.A | Keys.Control))
  101. tbSql.SelectAll();
  102. }
  103. private void btnQueryBuilder_Click(object sender, EventArgs e)
  104. {
  105. if (table.Connection != null)
  106. using (DataConnectionBase conn = Activator.CreateInstance(table.Connection.GetType()) as DataConnectionBase)
  107. {
  108. conn.Assign(table.Connection);
  109. if (Config.DesignerSettings.ApplicationConnection != null)
  110. conn.ConnectionString = Config.DesignerSettings.ApplicationConnection.ConnectionString;
  111. CustomQueryBuilderEventArgs args = new CustomQueryBuilderEventArgs(conn, tbSql.Text, table.Parameters);
  112. Config.DesignerSettings.OnCustomQueryBuilder(this, args);
  113. tbSql.Text = args.SQL;
  114. }
  115. }
  116. private void btnAddParameter_Click(object sender, EventArgs e)
  117. {
  118. CommandParameter c = new CommandParameter();
  119. c.Name = table.Parameters.CreateUniqueName("Parameter");
  120. c.DataType = table.Connection.GetDefaultParameterType();
  121. table.Parameters.Add(c);
  122. UpdateParamTree(c);
  123. }
  124. private void btnDeleteParameter_Click(object sender, EventArgs e)
  125. {
  126. if (tvParameters.SelectedNode == null)
  127. return;
  128. Base c = tvParameters.SelectedNode.Tag as Base;
  129. if (c == null)
  130. return;
  131. pgParamProperties.SelectedObject = null;
  132. c.Dispose();
  133. UpdateParamTree(null);
  134. }
  135. private void btnParameterUp_Click(object sender, EventArgs e)
  136. {
  137. if (tvParameters.SelectedNode == null)
  138. return;
  139. Base c = tvParameters.SelectedNode.Tag as Base;
  140. if (c == null)
  141. return;
  142. int index = table.Parameters.IndexOf(c);
  143. table.Parameters.RemoveAt(index);
  144. table.Parameters.Insert(index - 1, c);
  145. UpdateParamTree(c);
  146. }
  147. private void btnParameterDown_Click(object sender, EventArgs e)
  148. {
  149. if (tvParameters.SelectedNode == null)
  150. return;
  151. Base c = tvParameters.SelectedNode.Tag as Base;
  152. if (c == null)
  153. return;
  154. int index = table.Parameters.IndexOf(c);
  155. table.Parameters.RemoveAt(index);
  156. table.Parameters.Insert(index + 1, c);
  157. UpdateParamTree(c);
  158. }
  159. private void tvParameters_KeyDown(object sender, KeyEventArgs e)
  160. {
  161. if (e.KeyCode == Keys.Delete)
  162. btnDeleteParameter_Click(this, EventArgs.Empty);
  163. }
  164. private void btnRefreshColumns_Click(object sender, EventArgs e)
  165. {
  166. table.RefreshColumns(true);
  167. UpdateColumnTree(null);
  168. }
  169. private void btnAddColumn_Click(object sender, EventArgs e)
  170. {
  171. Column c = new Column();
  172. c.Name = table.Columns.CreateUniqueName("Column");
  173. c.Alias = table.Columns.CreateUniqueAlias(c.Alias);
  174. c.Calculated = true;
  175. table.Columns.Add(c);
  176. UpdateColumnTree(c);
  177. }
  178. private void btnDeleteColumn_Click(object sender, EventArgs e)
  179. {
  180. if (tvColumns.SelectedNode == null)
  181. return;
  182. Base c = tvColumns.SelectedNode.Tag as Base;
  183. if (c == null)
  184. return;
  185. pgColumnProperties.SelectedObject = null;
  186. c.Dispose();
  187. UpdateColumnTree(null);
  188. }
  189. private void tvColumns_KeyDown(object sender, KeyEventArgs e)
  190. {
  191. if (e.KeyCode == Keys.Delete)
  192. btnDeleteColumn_Click(this, EventArgs.Empty);
  193. }
  194. private void tvParameters_AfterSelect(object sender, TreeViewEventArgs e)
  195. {
  196. UpdateParamSelection();
  197. }
  198. private void UpdateParamSelection()
  199. {
  200. if (tvParameters.SelectedNode == null)
  201. {
  202. pgParamProperties.SelectedObject = null;
  203. btnDeleteParameter.Enabled = false;
  204. btnParameterUp.Enabled = false;
  205. btnParameterDown.Enabled = false;
  206. return;
  207. }
  208. pgParamProperties.SelectedObject = tvParameters.SelectedNode.Tag;
  209. btnDeleteParameter.Enabled = true;
  210. btnParameterUp.Enabled = tvParameters.SelectedNode.Index > 0;
  211. btnParameterDown.Enabled = tvParameters.SelectedNode.Index < tvParameters.Nodes.Count - 1;
  212. }
  213. private void tvColumns_AfterSelect(object sender, TreeViewEventArgs e)
  214. {
  215. pgColumnProperties.SelectedObject = tvColumns.SelectedNode.Tag;
  216. }
  217. private void pgParamProperties_PropertyValueChanged(object s, PropertyValueChangedEventArgs e)
  218. {
  219. if (tvParameters.SelectedNode != null && tvParameters.SelectedNode.Tag is CommandParameter)
  220. tvParameters.SelectedNode.Text = (tvParameters.SelectedNode.Tag as CommandParameter).Name;
  221. }
  222. private void pgColumnProperties_PropertyValueChanged(object s, PropertyValueChangedEventArgs e)
  223. {
  224. if (tvColumns.SelectedNode != null && tvColumns.SelectedNode.Tag is Column)
  225. tvColumns.SelectedNode.Text = (tvColumns.SelectedNode.Tag as Column).Alias;
  226. }
  227. private void UpdateParamTree(Base focusObj)
  228. {
  229. tvParameters.BeginUpdate();
  230. tvParameters.Nodes.Clear();
  231. foreach (CommandParameter c in table.Parameters)
  232. {
  233. TreeNode node = tvParameters.Nodes.Add(c.Name);
  234. node.Tag = c;
  235. node.ImageIndex = 231;
  236. node.SelectedImageIndex = node.ImageIndex;
  237. if (c == focusObj)
  238. tvParameters.SelectedNode = node;
  239. }
  240. if (focusObj == null && tvParameters.Nodes.Count > 0)
  241. tvParameters.SelectedNode = tvParameters.Nodes[0];
  242. tvParameters.EndUpdate();
  243. UpdateParamSelection();
  244. }
  245. private void UpdateColumnTree(Base focusObj)
  246. {
  247. tvColumns.BeginUpdate();
  248. tvColumns.Nodes.Clear();
  249. table.InitSchema();
  250. foreach (Column c in table.Columns)
  251. {
  252. TreeNode node = tvColumns.Nodes.Add(c.Alias);
  253. node.Tag = c;
  254. node.ImageIndex = c.GetImageIndex();
  255. node.SelectedImageIndex = node.ImageIndex;
  256. if (c == focusObj)
  257. tvColumns.SelectedNode = node;
  258. }
  259. if (focusObj == null && tvColumns.Nodes.Count > 0)
  260. tvColumns.SelectedNode = tvColumns.Nodes[0];
  261. tvColumns.EndUpdate();
  262. }
  263. private void Init()
  264. {
  265. VisiblePanelIndex = 0;
  266. tsParameters.Renderer = Config.DesignerSettings.ToolStripRenderer;
  267. tsColumns.Renderer = Config.DesignerSettings.ToolStripRenderer;
  268. tbName.Text = table.Alias;
  269. tbSql.Text = table.SelectCommand;
  270. }
  271. public override void UpdateDpiDependencies()
  272. {
  273. base.UpdateDpiDependencies();
  274. lblSetName.Font = lblWhatData.Font = this.LogicalToDevice(new Font(DrawUtils.DefaultFont, FontStyle.Bold), true);
  275. tsColumns.Height = tsParameters.Height = ts1.Height = ts2.Height = this.LogicalToDevice(27);
  276. btnAddColumn.Size = btnAddParameter.Size = btnDeleteColumn.Size = btnDeleteParameter.Size = btnRefreshColumns.Size = btnParameterUp.Size = btnParameterDown.Size =
  277. this.LogicalToDevice(new Size(22, 22));
  278. tbSql.Font = this.LogicalToDevice(Storage.GetFont("QueryWindow", DrawUtils.FixedFont), true);
  279. tbSql.Height = btnQueryBuilder.Top - tbSql.Top - 12;
  280. picIcon.Image = GetImage("Images.QueryWizard.png");
  281. tvParameters.ImageList = GetImages();
  282. tvColumns.ImageList = GetImages();
  283. btnAddParameter.Image = GetImage(56);
  284. btnDeleteParameter.Image = GetImage(51);
  285. btnParameterUp.Image = GetImage(208);
  286. btnParameterDown.Image = GetImage(209);
  287. btnRefreshColumns.Image = GetImage(232);
  288. btnAddColumn.Image = GetImage(55);
  289. btnDeleteColumn.Image = GetImage(51);
  290. MinimumSize = this.LogicalToDevice(new Size(450, 430));
  291. }
  292. public override void Localize()
  293. {
  294. base.Localize();
  295. MyRes res = new MyRes("Forms,QueryWizard");
  296. Text = res.Get("");
  297. pnName.Text = res.Get("Page1");
  298. pnSql.Text = res.Get("Page2");
  299. pnParameters.Text = res.Get("Page3");
  300. pnColumns.Text = res.Get("Page4");
  301. lblSetName.Text = res.Get("SetName");
  302. lblNameHint.Text = res.Get("NameHint");
  303. lblWhatData.Text = res.Get("WhatData");
  304. lblTypeSql.Text = res.Get("TypeSql");
  305. btnQueryBuilder.Text = res.Get("QueryBuilder");
  306. btnAddParameter.ToolTipText = res.Get("AddParameter");
  307. btnDeleteParameter.ToolTipText = res.Get("Delete");
  308. btnRefreshColumns.ToolTipText = res.Get("Refresh");
  309. btnAddColumn.ToolTipText = res.Get("AddColumn");
  310. btnDeleteColumn.ToolTipText = res.Get("Delete");
  311. }
  312. public QueryWizardForm(TableDataSource table)
  313. {
  314. this.table = table;
  315. CanSaveRestoreState = true;
  316. InitializeComponent();
  317. Localize();
  318. Init();
  319. UIUtils.CheckRTL(this);
  320. UpdateDpiDependencies();
  321. }
  322. }
  323. }