| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181 |
- // Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
- //
- // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
- //
- // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
- namespace Admin.NET.Core.Service;
- /// <summary>
- /// 自定义模板引擎
- /// </summary>
- public class CustomViewEngine : ViewEngineModel
- {
- /// <summary>
- /// 库定位器
- /// </summary>
- public string ConfigId { get; set; } = SqlSugarConst.MainConfigId;
- public string AuthorName { get; set; }
- public string BusName { get; set; }
- public string NameSpace { get; set; }
- public string ClassName { get; set; }
- public string LowerClassName { get; set; }
- public string ProjectLastName { get; set; }
- public string PagePath { get; set; } = "main";
- public string PrintType { get; set; }
- public string PrintName { get; set; }
- public bool HasLikeQuery { get; set; }
- public bool HasJoinTable { get; set; }
- public bool HasEnumField { get; set; }
- public bool HasDictField { get; set; }
- public bool HasConstField { get; set; }
- public bool HasSetStatus => TableField.Any(IsStatus);
- public List<CodeGenConfig> TableField { get; set; }
- public List<CodeGenConfig> ImportFieldList { get; set; }
- public List<CodeGenConfig> UploadFieldList { get; set; }
- public List<CodeGenConfig> QueryWhetherList { get; set; }
- public List<CodeGenConfig> ApiTreeFieldList { get; set; }
- public List<CodeGenConfig> DropdownFieldList { get; set; }
- public List<CodeGenConfig> AddUpdateFieldList { get; set; }
- public List<CodeGenConfig> PrimaryKeyFieldList { get; set; }
- public List<TableUniqueConfigItem> TableUniqueConfigList { get; set; }
- public List<CodeGenConfig> IgnoreUpdateFieldList => TableField.Where(u => u.WhetherAddUpdate == "N" && u.ColumnKey != "True" && u.WhetherCommon != "Y").ToList();
- /// <summary>
- /// 格式化主键查询条件
- /// 例: PrimaryKeysFormat(" || ", "u.{0} == input.{0}")
- /// 单主键返回 u.Id == input.Id
- /// 组合主键返回 u.Id == input.Id || u.FkId == input.FkId
- /// </summary>
- /// <param name="separator">分隔符</param>
- /// <param name="format">模板字符串</param>
- /// <param name="lowerFirstLetter">字段首字母小写</param>
- /// <returns></returns>
- public string PrimaryKeysFormat(string separator, string format, bool lowerFirstLetter = false) => string.Join(separator, PrimaryKeyFieldList.Select(u => string.Format(format, lowerFirstLetter ? u.LowerPropertyName : u.PropertyName)));
- /// <summary>
- /// 注入的服务
- /// </summary>
- /// <returns></returns>
- public Dictionary<string, string> InjectServiceMap
- {
- get
- {
- var injectMap = new Dictionary<string, string>();
- if (UploadFieldList.Count > 0) injectMap.Add(nameof(SysFileService), ToLowerFirstLetter(nameof(SysFileService)));
- if (DropdownFieldList.Count > 0 || ImportFieldList.Count > 0) injectMap.Add(nameof(ISqlSugarClient), ToLowerFirstLetter(nameof(ISqlSugarClient).TrimStart('I')));
- if (ImportFieldList.Any(c => c.EffectType == "DictSelector")) injectMap.Add(nameof(SysDictTypeService), ToLowerFirstLetter(nameof(SysDictTypeService)));
- return injectMap;
- }
- }
- /// <summary>
- /// 服务构造参数
- /// </summary>
- public string InjectServiceArgs => InjectServiceMap.Count > 0 ? ", " + string.Join(", ", InjectServiceMap.Select(kv => $"{kv.Key} {kv.Value}")) : "";
- /// <summary>
- /// 默认值列表
- /// </summary>
- public List<CodeGenConfig> DefaultValueList { get; set; }
- /// <summary>
- /// 判断字段是否为状态字段
- /// </summary>
- /// <param name="column"></param>
- /// <returns></returns>
- public bool IsStatus(CodeGenConfig column) => column.NetType == nameof(StatusEnum);
- /// <summary>
- /// 获取首字母小写字符串
- /// </summary>
- /// <param name="text"></param>
- /// <returns></returns>
- public string ToLowerFirstLetter(string text) => string.IsNullOrWhiteSpace(text) ? text : text[..1].ToLower() + text[1..];
- /// <summary>
- /// 将基本字段类型转为可空类型
- /// </summary>
- /// <param name="netType"></param>
- /// <returns></returns>
- public string GetNullableNetType(string netType) => Regex.IsMatch(netType, "(.*?Enum|bool|char|int|long|double|float|decimal)[?]?") ? netType.TrimEnd('?') + "?" : netType;
- /// <summary>
- /// 获取前端表格列定义的属性
- /// </summary>
- /// <param name="column"></param>
- /// <returns></returns>
- public string GetElTableColumnCustomProperty(CodeGenConfig column)
- {
- var content = $"prop='{column.LowerPropertyName}' label='{column.ColumnComment}'";
- if (IsStatus(column)) content += $" v-auth=\"'{LowerClassName}:setStatus'\"";
- if (column.WhetherSortable == "Y") content += " sortable='custom'";
- return content;
- }
- /// <summary>
- /// 设置默认值
- /// </summary>
- /// <returns></returns>
- public string GetAddDefaultValue()
- {
- var content = "";
- if (DefaultValueList.Count == 0)
- {
- var status = TableField.FirstOrDefault(IsStatus);
- var orderNo = TableField.FirstOrDefault(c => c.NetType.TrimEnd('?') == "int" && c.PropertyName == nameof(SysUser.OrderNo));
- if (status != null) content += $"{status.LowerPropertyName}: {(int)StatusEnum.Enable},";
- if (orderNo != null) content += $"{orderNo.LowerPropertyName}: 100,";
- }
- else
- {
- foreach (var item in DefaultValueList)
- {
- if (!string.IsNullOrWhiteSpace(item.DefaultValue))
- {
- switch (item.EffectType)
- {
- case "InputNumber":
- case "EnumSelector"://枚举和数字框,通过正则提取 数字:如 ('0')
- content += $"{item.LowerPropertyName}: {Regex.Match(item.DefaultValue, @"\d+").Value},";
- break;
- case "Switch":
- content += $"{item.LowerPropertyName}: {(item.DefaultValue == "1" ? true.ToString().ToLower() : false.ToString().ToLower())},";
- break;
- case "DatePicker"://忽略适配日期格式
- break;
- default:
- content += $"{item.LowerPropertyName}: \"{item.DefaultValue}\",";// 如果是字符串 DefaultValue=('男')
- break;
- }
- }
- }
- }
- return content;
- }
- }
|