Input.cs.vm 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. // Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
  2. //
  3. // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
  4. //
  5. // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
  6. using Admin.NET.Core;
  7. using System.ComponentModel.DataAnnotations;
  8. namespace @(Model.NameSpace);
  9. /// <summary>
  10. /// @(Model.BusName)基础输入参数
  11. /// </summary>
  12. public class @(Model.ClassName)BaseInput
  13. {
  14. @foreach (var column in Model.PrimaryKeyFieldList.Concat(Model.AddUpdateFieldList)){
  15. @:/// <summary>
  16. @:/// @column.ColumnComment
  17. @:/// </summary>
  18. if (column.EffectType is "EnumSelector" or "DictSelector") {
  19. @:[Dict(@(column.EffectType == "EnumSelector" ? $"nameof({column.DictTypeCode})" : $"\"{column.DictTypeCode}\""), AllowNullValue=true)]
  20. }
  21. if (column.WhetherRequired == "Y") {
  22. @:[Required(ErrorMessage = "@(column.ColumnComment)不能为空")]
  23. }
  24. @:public virtual @Model.GetNullableNetType(column.NetType) @column.PropertyName { get; set; }
  25. @:
  26. }
  27. }
  28. /// <summary>
  29. /// @(Model.BusName)分页查询输入参数
  30. /// </summary>
  31. public class Page@(Model.ClassName)Input : BasePageInput
  32. {
  33. @foreach (var column in Model.TableField.Where(u => u.WhetherQuery == "Y")){
  34. if(column.NetType?.TrimEnd('?') == "DateTime" && column.QueryType == "~"){
  35. @:/// <summary>
  36. @:/// @(column.ColumnComment)范围
  37. @:/// </summary>
  38. @: public DateTime?[] @(column.PropertyName)Range { get; set; }
  39. } else {
  40. @:/// <summary>
  41. @:/// @column.ColumnComment
  42. @:/// </summary>
  43. if (column.EffectType is "EnumSelector" or "DictSelector") {
  44. @:[Dict(@(column.EffectType == "EnumSelector" ? $"nameof({column.DictTypeCode})" : $"\"{column.DictTypeCode}\""), AllowNullValue=true)]
  45. }
  46. @:public @Model.GetNullableNetType(column.NetType) @column.PropertyName { get; set; }
  47. }
  48. @:
  49. }
  50. }
  51. /// <summary>
  52. /// @(Model.BusName)增加输入参数
  53. /// </summary>
  54. public class Add@(Model.ClassName)Input
  55. {
  56. @foreach (var column in Model.AddUpdateFieldList){
  57. @:/// <summary>
  58. @:/// @column.ColumnComment
  59. @:/// </summary>
  60. if (column.EffectType is "EnumSelector" or "DictSelector") {
  61. @:[Dict(@(column.EffectType == "EnumSelector" ? $"nameof({column.DictTypeCode})" : $"\"{column.DictTypeCode}\""), AllowNullValue=true)]
  62. }
  63. if (column.WhetherRequired == "Y") {
  64. @:[Required(ErrorMessage = "@(column.ColumnComment)不能为空")]
  65. }
  66. if (column.NetType.TrimEnd('?').EndsWith("string") && column.ColumnLength > 0){
  67. @:[MaxLength(@column.ColumnLength, ErrorMessage = "@(column.ColumnComment)字符长度不能超过@(column.ColumnLength)")]
  68. }
  69. @:public @Model.GetNullableNetType(column.NetType) @column.PropertyName { get; set; }
  70. @:
  71. }
  72. }
  73. /// <summary>
  74. /// @(Model.BusName)删除输入参数
  75. /// </summary>
  76. public class Delete@(Model.ClassName)Input
  77. {
  78. @foreach (var column in Model.PrimaryKeyFieldList) {
  79. @:/// <summary>
  80. @:/// @column.ColumnComment
  81. @:/// </summary>
  82. @:[Required(ErrorMessage = "@(column.ColumnComment)不能为空")]
  83. @:public @Model.GetNullableNetType(column.NetType) @column.PropertyName { get; set; }
  84. @:
  85. }
  86. }
  87. /// <summary>
  88. /// @(Model.BusName)更新输入参数
  89. /// </summary>
  90. public class Update@(Model.ClassName)Input
  91. {
  92. @foreach (var column in Model.PrimaryKeyFieldList.Concat(Model.AddUpdateFieldList)){
  93. @:/// <summary>
  94. @:/// @column.ColumnComment
  95. @:/// </summary>
  96. if (column.EffectType is "EnumSelector" or "DictSelector") {
  97. @:[Dict(@(column.EffectType == "EnumSelector" ? $"nameof({column.DictTypeCode})" : $"\"{column.DictTypeCode}\""), AllowNullValue=true)]
  98. }
  99. if (column.WhetherRequired == "Y" || column.ColumnKey == "True") {
  100. @:[Required(ErrorMessage = "@(column.ColumnComment)不能为空")]
  101. }
  102. if (column.NetType.TrimEnd('?').EndsWith("string") && column.ColumnLength > 0){
  103. @:[MaxLength(@column.ColumnLength, ErrorMessage = "@(column.ColumnComment)字符长度不能超过@(column.ColumnLength)")]
  104. }
  105. @:public @Model.GetNullableNetType(column.NetType) @column.PropertyName { get; set; }
  106. @:
  107. }
  108. }
  109. /// <summary>
  110. /// @(Model.BusName)主键查询输入参数
  111. /// </summary>
  112. public class QueryById@(Model.ClassName)Input : Delete@(Model.ClassName)Input
  113. {
  114. }
  115. @if (Model.DropdownFieldList.Count > 0) {
  116. @:/// <summary>
  117. @:/// 下拉数据输入参数
  118. @:/// </summary>
  119. @:public class DropdownData@(Model.ClassName)Input
  120. @:{
  121. @:/// <summary>
  122. @:/// 是否用于分页查询
  123. @:/// </summary>
  124. @:public bool FromPage { get; set; }
  125. @:}
  126. @:
  127. }
  128. @if (Model.HasSetStatus) {
  129. @:/// <summary>
  130. @:/// 设置状态输入参数
  131. @:/// </summary>
  132. @:public class Set@(Model.ClassName)StatusInput : BaseStatusInput
  133. @:{
  134. @foreach (var column in Model.PrimaryKeyFieldList.Where(u => u.PropertyName != "Id")) {
  135. @:/// <summary>
  136. @:/// @column.ColumnComment
  137. @:/// </summary>
  138. @:[Required(ErrorMessage = "@(column.ColumnComment)不能为空")]
  139. @:public @Model.GetNullableNetType(column.NetType) @column.PropertyName { get; set; }
  140. @:
  141. }
  142. @:}
  143. @:
  144. }
  145. @if (Model.ImportFieldList.Count > 0){
  146. @:/// <summary>
  147. @:/// @(Model.BusName)数据导入实体
  148. @:/// </summary>
  149. @:[ExcelImporter(SheetIndex = 1, IsOnlyErrorRows = true)]
  150. @:public class Import@(Model.ClassName)Input : BaseImportInput
  151. @:{
  152. foreach (var column in Model.ImportFieldList){
  153. var headerName = (column.WhetherRequired == "Y" ? "*" : "") + column.ColumnComment;
  154. if(column.EffectType == "ForeignKey" || column.EffectType == "ApiTreeSelector" || column.EffectType == "DictSelector") {
  155. @:/// <summary>
  156. @:/// @column.ColumnComment 关联值
  157. @:/// </summary>
  158. @:[ImporterHeader(IsIgnore = true)]
  159. @:[ExporterHeader(IsIgnore = true)]
  160. @:public @Model.GetNullableNetType(column.NetType) @column.PropertyName { get; set; }
  161. @:
  162. @:/// <summary>
  163. @:/// @column.ColumnComment 文本
  164. @:/// </summary>
  165. @:[ImporterHeader(Name = "@(headerName)")]
  166. @:[ExporterHeader("@(headerName)", Format = "@", Width = 25, IsBold = true)]
  167. @:public string @column.ExtendedPropertyName { get; set; }
  168. } else {
  169. @:/// <summary>
  170. @:/// @column.ColumnComment
  171. @:/// </summary>
  172. @:[ImporterHeader(Name = "@(headerName)")]
  173. @:[ExporterHeader("@(headerName)", Format = "@", Width = 25, IsBold = true)]
  174. @:public @Model.GetNullableNetType(column.NetType) @column.PropertyName { get; set; }
  175. }
  176. @:
  177. }
  178. @:}
  179. }