Ejemplo n.º 1
0
        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);
        }
Ejemplo n.º 2
0
        /// <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);
        }
Ejemplo n.º 3
0
        /// <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);
        }
Ejemplo n.º 4
0
        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);
        }