private string Create_Controller_Code_Get(string template) { StringBuilder sb = new StringBuilder(); sb.AppendLine(" /// <summary>"); sb.AppendLine(" /// Get " + entity_name + " list"); sb.AppendLine(" /// </summary>"); sb.AppendLine(" /// <param name=\"model\"></param>"); sb.AppendLine(" /// <returns></returns>"); sb.AppendLine(" [Route(\"api/" + entity_sub_namespace + "/Get\")]"); sb.AppendLine(" [PermissionVerify(new CommonEnum.Operations[] { CommonEnum.Operations.Read, Operations.Detail })]"); sb.AppendLine(" [HttpGet]"); sb.AppendLine(" public IHttpActionResult Get([FromUri]" + NameHelper.Get_ViewModel_Query_ListParameter_Name(entity_name) + " model)"); sb.AppendLine(" {"); sb.AppendLine(" if (model == null)"); sb.AppendLine(" {"); sb.AppendLine(" model = new " + NameHelper.Get_ViewModel_Query_ListParameter_Name(entity_name) + "();"); sb.AppendLine(" }"); //sb.AppendLine(""); sb.AppendLine(" var userInfo = WebData.GetSimpleLoginedUserInfo(LoginUser);"); sb.AppendLine(" if (userInfo == null) { return Json(new ApiActionResult() { Success = false, Message = \"登录信息失效,请重新登录\" }); }"); sb.AppendLine(""); sb.AppendLine(" model.organization_id = userInfo.OrganizationId;"); //sb.AppendLine(""); sb.AppendLine(" var queryResult = QueryService." + NameHelper.Get_MethodName_QueryService_GetList_Name(entity_name) + "(model);"); sb.AppendLine(" return Json(queryResult);"); sb.Append(" }"); template = template.Replace("{{Get-Actions}}", sb.ToString()); return(template); }
/// <summary> /// 创建代码 /// </summary> public void Create_Code() { #region folders string template_folder = context.Server.MapPath(settings.folder_templates + settings.template_folder_data_access_query_interface); string template_file = template_folder + "I{{entity_sub_namespace}}QueryDataAccessor.cs"; string target_folder = template_folder.Replace(context.Server.MapPath(settings.folder_templates), context.Server.MapPath(settings.folder_result)); string target_file = template_file.Replace(context.Server.MapPath(settings.folder_templates), context.Server.MapPath(settings.folder_result)); target_folder = target_folder.Replace("{{namespace}}", settings.code_namespace); target_folder = target_folder.Replace("{{entity_sub_namespace}}", entity_sub_namespace); target_file = target_file.Replace("{{namespace}}", settings.code_namespace); target_file = target_file.Replace("{{entity_sub_namespace}}", entity_sub_namespace); #endregion string template = FileHelper.ReadAll(template_file); template = template.Replace("{{namespace}}", settings.code_namespace); template = template.Replace("{{entity_name}}", entity_name); template = template.Replace("{{entity_sub_namespace}}", entity_sub_namespace); template = template.Replace("{{domain_model_name}}", NameHelper.Get_Domain_Model_Name(entity_name)); template = template.Replace("{{domain_model_id_name}}", NameHelper.Get_Identities_Name(entity_name)); template = template.Replace("{{get_details_method_name}}", NameHelper.Get_MethodName_QueryService_GetDetails_Name(entity_name)); template = template.Replace("{{list_method_name}}", NameHelper.Get_MethodName_QueryService_GetList_Name(entity_name)); template = template.Replace("{{list_parameters_model_name}}", NameHelper.Get_ViewModel_Query_ListParameter_Name(entity_name)); FileHelper.CheckAndCreateFolder(target_folder); FileHelper.WriteAll(target_file, template); }
/// <summary> /// 创建代码 /// </summary> public void Create_Code() { #region folders string template_folder = context.Server.MapPath(settings.folder_templates + settings.template_folder_query_parameters); string template_file = template_folder + "{{entity_sub_namespace}}ListParameter.cs"; string target_folder = template_folder.Replace(context.Server.MapPath(settings.folder_templates), context.Server.MapPath(settings.folder_result)); string target_file = template_file.Replace(context.Server.MapPath(settings.folder_templates), context.Server.MapPath(settings.folder_result)); target_folder = target_folder.Replace("{{namespace}}", settings.code_namespace); target_folder = target_folder.Replace("{{entity_sub_namespace}}", entity_sub_namespace); target_file = target_file.Replace("{{namespace}}", settings.code_namespace); target_file = target_file.Replace("{{entity_sub_namespace}}", entity_sub_namespace); #endregion string template = FileHelper.ReadAll(template_file); template = template.Replace("{{namespace}}", settings.code_namespace); template = template.Replace("{{entity_name}}", entity_name); template = template.Replace("{{entity_sub_namespace}}", entity_sub_namespace); template = template.Replace("{{query-list-parameter-name}}", NameHelper.Get_ViewModel_Query_ListParameter_Name(entity_name)); #region Parameters StringBuilder sb = new StringBuilder(); foreach (var p in entity_properties) { sb.AppendLine(" public " + NameHelper.GetListParameterTypeString(p) + " " + NameHelper.Get_Property_Name_For_ListParameter(p.Name) + " { get; set; }"); } sb.AppendLine(" public bool? is_order_asc { get; set; }"); sb.Append(" public string order_property { get; set; }"); template = template.Replace("{{Parameters}}", sb.ToString()); #endregion #region Parameter-Properties-Convertor sb = new StringBuilder(); foreach (var p in entity_properties) { sb.AppendLine(" " + NameHelper.Get_Property_Name_For_ListParameter(p.Name) + " = source." + NameHelper.Get_Property_Name_For_ListParameter(p.Name) + ";"); } //for (int i = 0; i < entity_properties.Count; i++) //{ // if (i == entity_properties.Count - 1) // { // sb.Append(" " + NameHelper.Get_Property_Name_For_ListParameter(entity_properties[i].Name) + " = source." + NameHelper.Get_Property_Name_For_ListParameter(entity_properties[i].Name) + ";"); // } // else // { // sb.AppendLine(" " + NameHelper.Get_Property_Name_For_ListParameter(entity_properties[i].Name) + " = source." + NameHelper.Get_Property_Name_For_ListParameter(entity_properties[i].Name) + ";"); // } //} sb.AppendLine(" order_property = source.order_property;"); sb.Append(" is_order_asc = source.is_order_asc;"); template = template.Replace("{{Parameter-Properties-Convertor}}", sb.ToString()); #endregion FileHelper.CheckAndCreateFolder(target_folder); FileHelper.WriteAll(target_file, template); }
private string Create_List_Code(string template) { StringBuilder sb = new StringBuilder(); sb.AppendLine(" public PagingRecords<ListModel> " + NameHelper.Get_MethodName_DataAccess_Query_GetList_Name(entity_name) + "(" + NameHelper.Get_ViewModel_Query_ListParameter_Name(entity_name) + " parameter)"); sb.AppendLine(" {"); //sb.AppendLine(""); sb.AppendLine(" var query = GetQuery<" + entity_name + ">();"); //sb.AppendLine(""); sb.AppendLine(" #region Where"); //sb.AppendLine(""); sb.AppendLine(" var predicate = PredicateBuilder.New<" + entity_name + ">();"); foreach (var p in entity_properties) { //sb.AppendLine(""); if (p.PropertyType == typeof(System.String)) { sb.AppendLine(" if (!string.IsNullOrWhiteSpace(parameter." + NameHelper.Get_Property_Name_For_ListParameter(p.Name) + "))"); sb.AppendLine(" {"); sb.AppendLine(" predicate = predicate.And(x => x." + p.Name + ".Contains(parameter." + NameHelper.Get_Property_Name_For_ListParameter(p.Name) + "));"); sb.AppendLine(" }"); } else if (p.PropertyType.IsValueType) { sb.AppendLine(" if (parameter." + NameHelper.Get_Property_Name_For_ListParameter(p.Name) + ".HasValue)"); sb.AppendLine(" {"); sb.AppendLine(" predicate = predicate.And(x => x." + p.Name + " == parameter." + NameHelper.Get_Property_Name_For_ListParameter(p.Name) + ".Value); "); sb.AppendLine(" }"); } else if (p.PropertyType.IsEnum) { sb.AppendLine(" if (parameter." + NameHelper.Get_Property_Name_For_ListParameter(p.Name) + ".HasValue)"); sb.AppendLine(" {"); sb.AppendLine(" var v = (int)parameter." + NameHelper.Get_Property_Name_For_ListParameter(p.Name) + ".Value"); sb.AppendLine(" predicate = predicate.And(x => x." + p.Name + " == v "); sb.AppendLine(" }"); } } //sb.AppendLine(""); sb.AppendLine(" #endregion"); //sb.AppendLine(""); sb.AppendLine(" #region Built SQL"); //sb.AppendLine(""); sb.AppendLine(" IQueryable<" + entity_name + "> queryResult = query;"); //sb.AppendLine(""); sb.AppendLine(" if (predicate.IsStarted)"); sb.AppendLine(" {"); sb.AppendLine(" queryResult = queryResult.Where(predicate);"); sb.AppendLine(" }"); //sb.AppendLine(""); sb.AppendLine(" queryResult = queryResult.OrderByDescending(r => r." + entity_id_properties.Name + ");"); //sb.AppendLine(""); sb.AppendLine(" #endregion"); //sb.AppendLine(""); //sb.AppendLine(" List<" + entity_name + "> result = queryResult.GetPagingRecords<" + entity_name + ">(parameter.page, parameter.page_size).ToList();"); sb.AppendLine(" List<" + entity_name + "> result = queryResult.GetPagingRecords(parameter.page, parameter.page_size).ToList();"); //sb.AppendLine(""); sb.AppendLine(" var pageList = result.Select(r =>"); sb.AppendLine(" {"); //sb.AppendLine(""); sb.AppendLine(" return new ListModel()"); sb.AppendLine(" {"); foreach (var p in entity_properties) { //sb.AppendLine(""); sb.AppendLine(" " + NameHelper.Get_Property_Name_For_Query_ListModel(p.Name) + " = r." + p.Name + ","); } sb.AppendLine(" };"); //sb.AppendLine(""); sb.AppendLine(" });"); //sb.AppendLine(""); sb.AppendLine(" return new PagingRecords<ListModel>(pageList, queryResult.Count(), parameter.page, parameter.page_size);"); //sb.AppendLine(""); sb.AppendLine(" }"); template = template.Replace("{{Get-List-Method}}", sb.ToString()); return(template); }