ComponentsFactory.BaseExt.cs 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379
  1. #if MSCHART
  2. using FastReport.MSChart;
  3. #endif
  4. using FastReport.Map;
  5. using FastReport.Dialog;
  6. namespace FastReport.Import
  7. {
  8. /// <summary>
  9. /// The components factory.
  10. /// </summary>
  11. public static partial class ComponentsFactory
  12. {
  13. #region Objects
  14. /// <summary>
  15. /// Creates a RichObject instance with specified name and parent.
  16. /// </summary>
  17. /// <param name="name">The name of the RichObject instance.</param>
  18. /// <param name="parent">The parent of the RichObject instance.</param>
  19. /// <returns>The RichObject instance.</returns>
  20. public static RichObject CreateRichObject(string name, Base parent)
  21. {
  22. RichObject rich = new RichObject();
  23. rich.Name = name;
  24. rich.Parent = parent;
  25. return rich;
  26. }
  27. /// <summary>
  28. /// Creates a SVGObject instance with specified name and parent.
  29. /// </summary>
  30. /// <param name="name">The name of the SVGObject instance.</param>
  31. /// <param name="parent">The parent of the SVGObject instance.</param>
  32. /// <returns>The SVGObject instance.</returns>
  33. public static SVG.SVGObject CreateSVGObject(string name, Base parent)
  34. {
  35. SVG.SVGObject picture = new SVG.SVGObject();
  36. picture.Name = name;
  37. if ((parent as IParent).CanContain(picture))
  38. picture.Parent = parent;
  39. return picture;
  40. }
  41. /// <summary>
  42. /// Creates a AdvMatrixObject instance with specified name and parent.
  43. /// </summary>
  44. /// <param name="name">The name of the AdvMatrixObject instance.</param>
  45. /// <param name="parent">The parent of the AdvMatrixObject instance.</param>
  46. /// <returns>The AdvMatrixObject instance.</returns>
  47. public static AdvMatrix.AdvMatrixObject CreateAdvMatrixObject(string name, Base parent)
  48. {
  49. AdvMatrix.AdvMatrixObject matrix = new AdvMatrix.AdvMatrixObject();
  50. matrix.Name = name;
  51. if ((parent as IParent).CanContain(matrix))
  52. matrix.Parent = parent;
  53. return matrix;
  54. }
  55. #if MSCHART
  56. /// <summary>
  57. /// Creates a MSChartObject instance with specified name and parent.
  58. /// </summary>
  59. /// <param name="name">The name of the MSChartObject instance.</param>
  60. /// <param name="parent">The parent of the MSChartObject instance.</param>
  61. /// <returns>The MSChartObject instance.</returns>
  62. public static MSChartObject CreateMSChartObject(string name, Base parent)
  63. {
  64. MSChartObject chart = new MSChartObject();
  65. chart.Name = name;
  66. chart.Parent = parent;
  67. return chart;
  68. }
  69. /// <summary>
  70. /// Creates a SparklineObject instance with specified name and parent.
  71. /// </summary>
  72. /// <param name="name">The name of the SparlineObject instance.</param>
  73. /// <param name="parent">The parent of the SparlineObject instance.</param>
  74. /// <returns></returns>
  75. public static SparklineObject CreateSparklineObject(string name, Base parent)
  76. {
  77. SparklineObject sparkline = new SparklineObject();
  78. sparkline.Name = name;
  79. sparkline.Parent = parent;
  80. return sparkline;
  81. }
  82. #endif
  83. /// <summary>
  84. /// Creates a MapObject instance with specified name and parent.
  85. /// </summary>
  86. /// <param name="name">The name of the MapObject instance.</param>
  87. /// <param name="parent">The parent of the MapObject instance.</param>
  88. /// <returns>The MapObject instance.</returns>
  89. public static MapObject CreateMapObject(string name, Base parent)
  90. {
  91. MapObject map = new MapObject();
  92. map.Name = name;
  93. map.Parent = parent;
  94. return map;
  95. }
  96. #endregion // Objects
  97. #if !FRCORE
  98. #region DialogObjects
  99. /// <summary>
  100. /// Creates a DialogPage instance in the specified Report.
  101. /// </summary>
  102. /// <param name="report">The Report instance.</param>
  103. /// <returns>The DialogPage instance.</returns>
  104. public static Dialog.DialogPage CreateDialogPage(Report report)
  105. {
  106. Dialog.DialogPage page = new Dialog.DialogPage();
  107. report.Pages.Add(page);
  108. page.CreateUniqueName();
  109. return page;
  110. }
  111. /// <summary>
  112. /// Creates a TextBoxControl instance with specified name and parent.
  113. /// </summary>
  114. /// <param name="name">The name of the TextBoxControl instance.</param>
  115. /// <param name="parent">The parent of the TextBoxControl instance.</param>
  116. /// <returns>The TextBoxControl instance.</returns>
  117. public static TextBoxControl CreateTextBoxControl(string name, Base parent)
  118. {
  119. TextBoxControl textBox = new TextBoxControl();
  120. textBox.Name = name;
  121. if ((parent as IParent).CanContain(textBox))
  122. textBox.Parent = parent;
  123. return textBox;
  124. }
  125. /// <summary>
  126. /// Creates a LabelControl instance with specified name and parent.
  127. /// </summary>
  128. /// <param name="name">The name of the LabelControl instance.</param>
  129. /// <param name="parent">The parent of the LabelControl instance.</param>
  130. /// <returns>The LabelControl instance.</returns>
  131. public static LabelControl CreateLabelControl(string name, Base parent)
  132. {
  133. LabelControl labelControl = new LabelControl();
  134. labelControl.Name = name;
  135. if ((parent as IParent).CanContain(labelControl))
  136. labelControl.Parent = parent;
  137. return labelControl;
  138. }
  139. /// <summary>
  140. /// Creates a RadioButtonControl instance with specified name and parent.
  141. /// </summary>
  142. /// <param name="name">The name of the RadioButtonControl instance.</param>
  143. /// <param name="parent">The parent of the RadioButtonControl instance.</param>
  144. /// <returns>The RadioButtonControl instance.</returns>
  145. public static RadioButtonControl CreateRadioButtonControl(string name, Base parent)
  146. {
  147. RadioButtonControl radioButtonControl = new RadioButtonControl();
  148. radioButtonControl.Name = name;
  149. if ((parent as IParent).CanContain(radioButtonControl))
  150. radioButtonControl.Parent = parent;
  151. return radioButtonControl;
  152. }
  153. /// <summary>
  154. /// Creates a DateTimePickerControl instance with specified name and parent.
  155. /// </summary>
  156. /// <param name="name">The name of the DateTimePickerControl instance.</param>
  157. /// <param name="parent">The parent of the DateTimePickerControl instance.</param>
  158. /// <returns>The DateTimePickerControl instance.</returns>
  159. public static DateTimePickerControl CreateDateTimePickerControl(string name, Base parent)
  160. {
  161. DateTimePickerControl dateTimePickerControl = new DateTimePickerControl();
  162. dateTimePickerControl.Name = name;
  163. if ((parent as IParent).CanContain(dateTimePickerControl))
  164. dateTimePickerControl.Parent = parent;
  165. return dateTimePickerControl;
  166. }
  167. /// <summary>
  168. /// Creates a GridControl instance with specified name and parent.
  169. /// </summary>
  170. /// <param name="name">The name of the GridControl instance.</param>
  171. /// <param name="parent">The parent of the GridControl instance.</param>
  172. /// <returns>The GridControl instance.</returns>
  173. public static GridControl CreateGridControl(string name, Base parent)
  174. {
  175. GridControl gridControl = new GridControl();
  176. gridControl.Name = name;
  177. if ((parent as IParent).CanContain(gridControl))
  178. gridControl.Parent = parent;
  179. return gridControl;
  180. }
  181. /// <summary>
  182. /// Creates a GroupBoxControl instance with specified name and parent.
  183. /// </summary>
  184. /// <param name="name">The name of the GroupBoxControl instance.</param>
  185. /// <param name="parent">The parent of the GroupBoxControl instance.</param>
  186. /// <returns>The GroupBoxControl instance.</returns>
  187. public static GroupBoxControl CreateGroupBoxControl(string name, Base parent)
  188. {
  189. GroupBoxControl gridControl = new GroupBoxControl();
  190. gridControl.Name = name;
  191. if ((parent as IParent).CanContain(gridControl))
  192. gridControl.Parent = parent;
  193. return gridControl;
  194. }
  195. /// <summary>
  196. /// Creates a ButtonControl instance with specified name and parent.
  197. /// </summary>
  198. /// <param name="name">The name of the ButtonControl instance.</param>
  199. /// <param name="parent">The parent of the ButtonControl instance.</param>
  200. /// <returns>The ButtonControl instance.</returns>
  201. public static ButtonControl CreateButtonControl(string name, Base parent)
  202. {
  203. ButtonControl buttonControl = new ButtonControl();
  204. buttonControl.Name = name;
  205. if ((parent as IParent).CanContain(buttonControl))
  206. buttonControl.Parent = parent;
  207. return buttonControl;
  208. }
  209. /// <summary>
  210. /// Creates a CheckBoxControl instance with specified name and parent.
  211. /// </summary>
  212. /// <param name="name">The name of the CheckBoxControl instance.</param>
  213. /// <param name="parent">The parent of the CheckBoxControl instance.</param>
  214. /// <returns>The CheckBoxControl instance.</returns>
  215. public static CheckBoxControl CreateCheckBoxControl(string name, Base parent)
  216. {
  217. CheckBoxControl checkBoxControl = new CheckBoxControl();
  218. checkBoxControl.Name = name;
  219. if ((parent as IParent).CanContain(checkBoxControl))
  220. checkBoxControl.Parent = parent;
  221. return checkBoxControl;
  222. }
  223. /// <summary>
  224. /// Creates a CheckedListBoxControl instance with specified name and parent.
  225. /// </summary>
  226. /// <param name="name">The name of the CheckedListBoxControl instance.</param>
  227. /// <param name="parent">The parent of the CheckedListBoxControl instance.</param>
  228. /// <returns>The CheckedListBoxControl instance.</returns>
  229. public static CheckedListBoxControl CreateCheckedListBoxControl(string name, Base parent)
  230. {
  231. CheckedListBoxControl checkedListBoxControl = new CheckedListBoxControl();
  232. checkedListBoxControl.Name = name;
  233. if ((parent as IParent).CanContain(checkedListBoxControl))
  234. checkedListBoxControl.Parent = parent;
  235. return checkedListBoxControl;
  236. }
  237. /// <summary>
  238. /// Creates a ListBoxControl instance with specified name and parent.
  239. /// </summary>
  240. /// <param name="name">The name of the ListBoxControl instance.</param>
  241. /// <param name="parent">The parent of the ListBoxControl instance.</param>
  242. /// <returns>The ListBoxControl instance.</returns>
  243. public static ListBoxControl CreateListBoxControl(string name, Base parent)
  244. {
  245. ListBoxControl listBoxControl = new ListBoxControl();
  246. listBoxControl.Name = name;
  247. if ((parent as IParent).CanContain(listBoxControl))
  248. listBoxControl.Parent = parent;
  249. return listBoxControl;
  250. }
  251. /// <summary>
  252. /// Creates a PanelControl instance with specified name and parent.
  253. /// </summary>
  254. /// <param name="name">The name of the PanelControl instance.</param>
  255. /// <param name="parent">The parent of the PanelControl instance.</param>
  256. /// <returns>The PanelControl instance.</returns>
  257. public static PanelControl CreatePanelControl(string name, Base parent)
  258. {
  259. PanelControl panelControl = new PanelControl();
  260. panelControl.Name = name;
  261. if ((parent as IParent).CanContain(panelControl))
  262. panelControl.Parent = parent;
  263. return panelControl;
  264. }
  265. /// <summary>
  266. /// Creates a ComboBoxControl instance with specified name and parent.
  267. /// </summary>
  268. /// <param name="name">The name of the ComboBoxControl instance.</param>
  269. /// <param name="parent">The parent of the ComboBoxControl instance.</param>
  270. /// <returns>The ComboBoxControl instance.</returns>
  271. public static ComboBoxControl CreateComboBoxControl(string name, Base parent)
  272. {
  273. ComboBoxControl comboBoxControl = new ComboBoxControl();
  274. comboBoxControl.Name = name;
  275. if ((parent as IParent).CanContain(comboBoxControl))
  276. comboBoxControl.Parent = parent;
  277. return comboBoxControl;
  278. }
  279. /// <summary>
  280. /// Creates a NumericUpDownControl instance with specified name and parent.
  281. /// </summary>
  282. /// <param name="name">The name of the NumericUpDownControl instance.</param>
  283. /// <param name="parent">The parent of the NumericUpDownControl instance.</param>
  284. /// <returns>The NumericUpDownControl instance.</returns>
  285. public static NumericUpDownControl CreateNumericUpDownControl(string name, Base parent)
  286. {
  287. NumericUpDownControl numericUpDownControl = new NumericUpDownControl();
  288. numericUpDownControl.Name = name;
  289. if ((parent as IParent).CanContain(numericUpDownControl))
  290. numericUpDownControl.Parent = parent;
  291. return numericUpDownControl;
  292. }
  293. /// <summary>
  294. /// Creates a PictureBoxControl instance with specified name and parent.
  295. /// </summary>
  296. /// <param name="name">The name of the PictureBoxControl instance.</param>
  297. /// <param name="parent">The parent of the PictureBoxControl instance.</param>
  298. /// <returns>The PictureBoxControl instance.</returns>
  299. public static PictureBoxControl CreatePictureBoxControl(string name, Base parent)
  300. {
  301. PictureBoxControl pictureBoxControl = new PictureBoxControl();
  302. pictureBoxControl.Name = name;
  303. if ((parent as IParent).CanContain(pictureBoxControl))
  304. pictureBoxControl.Parent = parent;
  305. return pictureBoxControl;
  306. }
  307. /// <summary>
  308. /// Creates a ListViewControl instance with specified name and parent.
  309. /// </summary>
  310. /// <param name="name">The name of the ListViewControl instance.</param>
  311. /// <param name="parent">The parent of the ListViewControl instance.</param>
  312. /// <returns>The ListViewControl instance.</returns>
  313. public static ListViewControl CreateListViewControl(string name, Base parent)
  314. {
  315. ListViewControl listViewControl = new ListViewControl();
  316. listViewControl.Name = name;
  317. if ((parent as IParent).CanContain(listViewControl))
  318. listViewControl.Parent = parent;
  319. return listViewControl;
  320. }
  321. /// <summary>
  322. /// Creates a RichTextBoxControl instance with specified name and parent.
  323. /// </summary>
  324. /// <param name="name">The name of the RichTextBoxControl instance.</param>
  325. /// <param name="parent">The parent of the RichTextBoxControl instance.</param>
  326. /// <returns>The RichTextBoxControl instance.</returns>
  327. public static RichTextBoxControl CreateRichTextBoxControl(string name, Base parent)
  328. {
  329. RichTextBoxControl richTextBoxControl = new RichTextBoxControl();
  330. richTextBoxControl.Name = name;
  331. if ((parent as IParent).CanContain(richTextBoxControl))
  332. richTextBoxControl.Parent = parent;
  333. return richTextBoxControl;
  334. }
  335. /// <summary>
  336. /// Creates a TreeViewControl instance with specified name and parent.
  337. /// </summary>
  338. /// <param name="name">The name of the TreeViewControl instance.</param>
  339. /// <param name="parent">The parent of the TreeViewControl instance.</param>
  340. /// <returns>The TreeViewControl instance.</returns>
  341. public static TreeViewControl CreateTreeViewControl(string name, Base parent)
  342. {
  343. TreeViewControl treeViewControl = new TreeViewControl();
  344. treeViewControl.Name = name;
  345. if ((parent as IParent).CanContain(treeViewControl))
  346. treeViewControl.Parent = parent;
  347. return treeViewControl;
  348. }
  349. #endregion
  350. #endif
  351. }
  352. }