完善代码生成功能
This commit is contained in:
parent
f550310b1e
commit
47bc6d5ed9
@ -12,8 +12,8 @@ using Infrastructure.Enums;
|
|||||||
using Infrastructure.Model;
|
using Infrastructure.Model;
|
||||||
using Mapster;
|
using Mapster;
|
||||||
using ZR.Admin.WebApi.Extensions;
|
using ZR.Admin.WebApi.Extensions;
|
||||||
using ZR.Model.Dto;
|
using {ModelsNamespace}.Dto;
|
||||||
using ZR.Model.Models;
|
using {ModelsNamespace}.Models;
|
||||||
|
|
||||||
namespace ZRAdmin.Controllers
|
namespace ZRAdmin.Controllers
|
||||||
{
|
{
|
||||||
@ -108,6 +108,7 @@ namespace ZRAdmin.Controllers
|
|||||||
var response = _<#=ServiceName#>.Update(w => w.{primaryKey} == updateModel.{primaryKey}, it => new <#=ModelName#>()
|
var response = _<#=ServiceName#>.Update(w => w.{primaryKey} == updateModel.{primaryKey}, it => new <#=ModelName#>()
|
||||||
{
|
{
|
||||||
//TODO 字段映射
|
//TODO 字段映射
|
||||||
|
{updateColumn}
|
||||||
});
|
});
|
||||||
|
|
||||||
return SUCCESS(response);
|
return SUCCESS(response);
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
using System;
|
using System;
|
||||||
using ZR.Model.Models;
|
using {ModelsNamespace}.Models;
|
||||||
|
|
||||||
namespace {IServicsNamespace}.Business
|
namespace {IServicsNamespace}.Business
|
||||||
{
|
{
|
||||||
|
|||||||
@ -1,6 +1,7 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using {ModelsNamespace}.Dto;
|
using {ModelsNamespace}.Dto;
|
||||||
|
using {ModelsNamespace}.Models;
|
||||||
|
|
||||||
namespace {DtosNamespace}.Dto
|
namespace {DtosNamespace}.Dto
|
||||||
{
|
{
|
||||||
|
|||||||
@ -7,9 +7,9 @@ using System.Collections.Generic;
|
|||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using ZR.Common;
|
using ZR.Common;
|
||||||
using ZR.Model.Models;
|
using {ModelsNamespace}.Models;
|
||||||
using ZR.Repository;
|
using {IRepositoriesNamespace};
|
||||||
using ZR.Service.IService;
|
using {ServicesNamespace}.IService;
|
||||||
|
|
||||||
namespace {ServicesNamespace}.Business
|
namespace {ServicesNamespace}.Business
|
||||||
{
|
{
|
||||||
|
|||||||
@ -65,7 +65,7 @@
|
|||||||
<!-- 添加或修改菜单对话框 -->
|
<!-- 添加或修改菜单对话框 -->
|
||||||
<el-dialog :title="title" :visible.sync="open" append-to-body>
|
<el-dialog :title="title" :visible.sync="open" append-to-body>
|
||||||
<el-form ref="form" :model="form" :rules="rules" label-width="100px">
|
<el-form ref="form" :model="form" :rules="rules" label-width="100px">
|
||||||
{VueViewFromContent}
|
{VueViewFormContent}
|
||||||
</el-form>
|
</el-form>
|
||||||
<div slot="footer" class="dialog-footer" v-if="btnSubmitVisible">
|
<div slot="footer" class="dialog-footer" v-if="btnSubmitVisible">
|
||||||
<el-button type="primary" @click="submitForm">确 定</el-button>
|
<el-button type="primary" @click="submitForm">确 定</el-button>
|
||||||
@ -119,7 +119,7 @@ export default {
|
|||||||
btnSubmitVisible: true,
|
btnSubmitVisible: true,
|
||||||
// 表单校验
|
// 表单校验
|
||||||
rules: {
|
rules: {
|
||||||
{VueViewEditFromRuleContent}
|
{VueViewEditFormRuleContent}
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
@ -150,7 +150,7 @@ export default {
|
|||||||
// 重置数据表单
|
// 重置数据表单
|
||||||
reset() {
|
reset() {
|
||||||
this.form = {
|
this.form = {
|
||||||
{VueViewEditFromContent}
|
{VueViewEditFormContent}
|
||||||
//需个性化处理内容
|
//需个性化处理内容
|
||||||
};
|
};
|
||||||
this.resetForm("form");
|
this.resetForm("form");
|
||||||
@ -184,7 +184,7 @@ export default {
|
|||||||
},
|
},
|
||||||
/** 删除按钮操作 */
|
/** 删除按钮操作 */
|
||||||
handleDelete(row) {
|
handleDelete(row) {
|
||||||
del{ModelTypeName}().then((res) => {
|
del{ModelTypeName}(row.{primaryKey}).then((res) => {
|
||||||
this.msgSuccess("删除成功");
|
this.msgSuccess("删除成功");
|
||||||
this.handleQuery();
|
this.handleQuery();
|
||||||
});
|
});
|
||||||
@ -207,7 +207,7 @@ export default {
|
|||||||
if (valid) {
|
if (valid) {
|
||||||
console.log(JSON.stringify(this.form));
|
console.log(JSON.stringify(this.form));
|
||||||
|
|
||||||
if (this.form.{primaryKey} != undefined) {
|
if (this.form.{primaryKey} != undefined || this.title === '修改数据') {
|
||||||
update{ModelTypeName}(this.form).then((res) => {
|
update{ModelTypeName}(this.form).then((res) => {
|
||||||
this.msgSuccess("修改成功");
|
this.msgSuccess("修改成功");
|
||||||
this.open = false;
|
this.open = false;
|
||||||
|
|||||||
@ -41,6 +41,7 @@ namespace ZR.CodeGenerator
|
|||||||
_option.DtosNamespace = "ZR.Model";
|
_option.DtosNamespace = "ZR.Model";
|
||||||
_option.ModelsNamespace = "ZR.Model";
|
_option.ModelsNamespace = "ZR.Model";
|
||||||
_option.RepositoriesNamespace = "ZR.Repository";
|
_option.RepositoriesNamespace = "ZR.Repository";
|
||||||
|
_option.IRepositoriesNamespace = "ZR.Repository";
|
||||||
_option.IServicsNamespace = "ZR.Service";
|
_option.IServicsNamespace = "ZR.Service";
|
||||||
_option.ServicesNamespace = "ZR.Service";
|
_option.ServicesNamespace = "ZR.Service";
|
||||||
_option.ApiControllerNamespace = "ZR.Admin.WebApi";
|
_option.ApiControllerNamespace = "ZR.Admin.WebApi";
|
||||||
@ -64,7 +65,7 @@ namespace ZR.CodeGenerator
|
|||||||
public static void GenerateSingle(List<DbColumnInfo> listField, DbTableInfo tableInfo, GenerateDto dto)
|
public static void GenerateSingle(List<DbColumnInfo> listField, DbTableInfo tableInfo, GenerateDto dto)
|
||||||
{
|
{
|
||||||
bool ifExsitedCovered = dto.coverd;
|
bool ifExsitedCovered = dto.coverd;
|
||||||
var modelTypeName = GetModelName(tableInfo.Name);
|
var modelTypeName = GetModelClassName(tableInfo.Name);//表名对应C# 实体类名
|
||||||
var modelTypeDesc = tableInfo.Description;//表描述
|
var modelTypeDesc = tableInfo.Description;//表描述
|
||||||
var primaryKey = "id";//主键
|
var primaryKey = "id";//主键
|
||||||
|
|
||||||
@ -72,6 +73,7 @@ namespace ZR.CodeGenerator
|
|||||||
string modelContent = "";//数据库模型字段
|
string modelContent = "";//数据库模型字段
|
||||||
string InputDtoContent = "";//输入模型
|
string InputDtoContent = "";//输入模型
|
||||||
string outputDtoContent = "";//输出模型
|
string outputDtoContent = "";//输出模型
|
||||||
|
string updateColumn = "";//修改数据映射字段
|
||||||
string vueViewListContent = string.Empty;//Vue列表输出内容
|
string vueViewListContent = string.Empty;//Vue列表输出内容
|
||||||
string vueViewFormContent = string.Empty;//Vue表单输出内容
|
string vueViewFormContent = string.Empty;//Vue表单输出内容
|
||||||
string vueViewEditFromContent = string.Empty;//Vue变量输出内容
|
string vueViewEditFromContent = string.Empty;//Vue变量输出内容
|
||||||
@ -86,24 +88,32 @@ namespace ZR.CodeGenerator
|
|||||||
if (dbFieldInfo.DataType == "bool" || dbFieldInfo.DataType == "tinyint")
|
if (dbFieldInfo.DataType == "bool" || dbFieldInfo.DataType == "tinyint")
|
||||||
{
|
{
|
||||||
vueViewEditFromContent += $" {columnName}: 'true',\n";
|
vueViewEditFromContent += $" {columnName}: 'true',\n";
|
||||||
vueViewEditFromBindContent += $" this.form.{columnName} = res.data.{0}+''\n";
|
//vueViewEditFromBindContent += $" this.form.{columnName} = res.data.{0}+''\n";
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
vueViewEditFromContent += $" {columnName}: undefined,\n";
|
vueViewEditFromContent += $" {columnName}: undefined,\n";
|
||||||
vueViewEditFromBindContent += $" {columnName}: row.{columnName},\n";
|
//vueViewEditFromBindContent += $" {columnName}: row.{columnName},\n";
|
||||||
}
|
}
|
||||||
//vueViewSaveBindContent += string.Format(" '{0}':this.editFrom.{0},\n", columnName);
|
//vueViewSaveBindContent += string.Format(" '{0}':this.editFrom.{0},\n", columnName);
|
||||||
|
//主键
|
||||||
if (dbFieldInfo.IsIdentity || dbFieldInfo.IsPrimarykey)
|
if (dbFieldInfo.IsIdentity || dbFieldInfo.IsPrimarykey)
|
||||||
{
|
{
|
||||||
primaryKey = columnName;
|
primaryKey = columnName.Substring(0, 1).ToUpper() + columnName[1..];
|
||||||
keyTypeName = dbFieldInfo.DataType;
|
keyTypeName = dbFieldInfo.DataType;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
var tempColumnName = columnName.Substring(0, 1).ToUpper() + columnName[1..];
|
||||||
|
updateColumn += $" {tempColumnName} = parm.{tempColumnName},\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
dbFieldInfo.DbColumnName = columnName;
|
||||||
modelContent += GetModelTemplate(dbFieldInfo);
|
modelContent += GetModelTemplate(dbFieldInfo);
|
||||||
vueViewFormContent += GetVueViewFormContent(dbFieldInfo, columnName);
|
vueViewFormContent += GetVueViewFormContent(dbFieldInfo);
|
||||||
vueViewListContent += GetTableColumn(dbFieldInfo, columnName);
|
vueViewListContent += GetTableColumn(dbFieldInfo);
|
||||||
vueViewEditFromRuleContent += GetFormRules(dbFieldInfo, columnName);
|
vueViewEditFromRuleContent += GetFormRules(dbFieldInfo);
|
||||||
InputDtoContent += GetDtoContent(dbFieldInfo, columnName);
|
InputDtoContent += GetDtoContent(dbFieldInfo);
|
||||||
}
|
}
|
||||||
if (dto.genFiles.Contains(1))
|
if (dto.genFiles.Contains(1))
|
||||||
{
|
{
|
||||||
@ -124,7 +134,7 @@ namespace ZR.CodeGenerator
|
|||||||
}
|
}
|
||||||
if (dto.genFiles.Contains(5))
|
if (dto.genFiles.Contains(5))
|
||||||
{
|
{
|
||||||
GenerateControllers(modelTypeName, primaryKey, modelTypeDesc, keyTypeName, ifExsitedCovered);
|
GenerateControllers(modelTypeName, primaryKey, modelTypeDesc, keyTypeName, updateColumn, ifExsitedCovered);
|
||||||
}
|
}
|
||||||
if (dto.genFiles.Contains(6))
|
if (dto.genFiles.Contains(6))
|
||||||
{
|
{
|
||||||
@ -137,13 +147,13 @@ namespace ZR.CodeGenerator
|
|||||||
#region Template
|
#region Template
|
||||||
|
|
||||||
//rules
|
//rules
|
||||||
private static string GetFormRules(DbColumnInfo dbFieldInfo, string columnName)
|
private static string GetFormRules(DbColumnInfo dbFieldInfo)
|
||||||
{
|
{
|
||||||
string vueViewEditFromRuleContent = "";
|
string vueViewEditFromRuleContent = "";
|
||||||
//Rule 规则验证
|
//Rule 规则验证
|
||||||
if (!dbFieldInfo.IsNullable && !dbFieldInfo.IsIdentity)
|
if (!dbFieldInfo.IsNullable && !dbFieldInfo.IsIdentity)
|
||||||
{
|
{
|
||||||
vueViewEditFromRuleContent += $" {columnName}: [\n";
|
vueViewEditFromRuleContent += $" {dbFieldInfo.DbColumnName}: [\n";
|
||||||
vueViewEditFromRuleContent += $" {{ required: true, message:\"请输入{dbFieldInfo.ColumnDescription}\", trigger: \"blur\"}},\n";
|
vueViewEditFromRuleContent += $" {{ required: true, message:\"请输入{dbFieldInfo.ColumnDescription}\", trigger: \"blur\"}},\n";
|
||||||
//vueViewEditFromRuleContent += " { min: 2, max: 50, message: \"长度在 2 到 50 个字符\", trigger:\"blur\" }\n";
|
//vueViewEditFromRuleContent += " { min: 2, max: 50, message: \"长度在 2 到 50 个字符\", trigger:\"blur\" }\n";
|
||||||
vueViewEditFromRuleContent += " ],\n";
|
vueViewEditFromRuleContent += " ],\n";
|
||||||
@ -155,7 +165,7 @@ namespace ZR.CodeGenerator
|
|||||||
//model 属性
|
//model 属性
|
||||||
private static string GetModelTemplate(DbColumnInfo dbFieldInfo)
|
private static string GetModelTemplate(DbColumnInfo dbFieldInfo)
|
||||||
{
|
{
|
||||||
string columnName = dbFieldInfo.DbColumnName.Substring(0, 1).ToUpper() + dbFieldInfo.DbColumnName.Substring(1);
|
string columnName = dbFieldInfo.DbColumnName.Substring(0, 1).ToUpper() + dbFieldInfo.DbColumnName[1..];
|
||||||
var modelcontent = "";
|
var modelcontent = "";
|
||||||
modelcontent += " /// <summary>\n";
|
modelcontent += " /// <summary>\n";
|
||||||
modelcontent += $" /// 描述 :{dbFieldInfo.ColumnDescription}\n";
|
modelcontent += $" /// 描述 :{dbFieldInfo.ColumnDescription}\n";
|
||||||
@ -170,26 +180,22 @@ namespace ZR.CodeGenerator
|
|||||||
return modelcontent;
|
return modelcontent;
|
||||||
}
|
}
|
||||||
//DTO model
|
//DTO model
|
||||||
private static string GetDtoContent(DbColumnInfo dbFieldInfo, string columnName)
|
private static string GetDtoContent(DbColumnInfo dbFieldInfo)
|
||||||
{
|
{
|
||||||
|
string columnName = dbFieldInfo.DbColumnName.Substring(0, 1).ToUpper() + dbFieldInfo.DbColumnName[1..];
|
||||||
string InputDtoContent = "";
|
string InputDtoContent = "";
|
||||||
if (!inputDtoNoField.Any(x => x.ToLower().Contains(columnName)) || !dbFieldInfo.IsIdentity)
|
|
||||||
{
|
|
||||||
InputDtoContent += " /// <summary>\n";
|
|
||||||
InputDtoContent += $" /// 设置或获取{dbFieldInfo.ColumnDescription}\n";
|
|
||||||
InputDtoContent += " /// </summary>\n";
|
|
||||||
InputDtoContent += $" public {TableMappingHelper.GetPropertyDatatype(dbFieldInfo.DataType)} {columnName} {{ get; set; }}\n\r";
|
InputDtoContent += $" public {TableMappingHelper.GetPropertyDatatype(dbFieldInfo.DataType)} {columnName} {{ get; set; }}\n\r";
|
||||||
}
|
|
||||||
|
|
||||||
return InputDtoContent;
|
return InputDtoContent;
|
||||||
}
|
}
|
||||||
|
|
||||||
//form-item
|
//form-item
|
||||||
private static string GetVueViewFormContent(DbColumnInfo dbFieldInfo, string columnName)
|
private static string GetVueViewFormContent(DbColumnInfo dbFieldInfo)
|
||||||
{
|
{
|
||||||
columnName = FirstLowerCase(columnName);
|
string columnName = FirstLowerCase(dbFieldInfo.DbColumnName);
|
||||||
string labelName = GetLabelName(dbFieldInfo.ColumnDescription, columnName);
|
string labelName = GetLabelName(dbFieldInfo.ColumnDescription, columnName);
|
||||||
string vueViewFromContent = "";
|
string vueViewFromContent = "";
|
||||||
|
string labelDisabled = dbFieldInfo.IsIdentity ? ":disabled=\"true\"" : "";
|
||||||
if (dbFieldInfo.DataType == "datetime")
|
if (dbFieldInfo.DataType == "datetime")
|
||||||
{
|
{
|
||||||
vueViewFromContent += "";
|
vueViewFromContent += "";
|
||||||
@ -198,7 +204,7 @@ namespace ZR.CodeGenerator
|
|||||||
{
|
{
|
||||||
//TODO 图片
|
//TODO 图片
|
||||||
}
|
}
|
||||||
else if (radioFiled.Any(f => columnName.Contains(f)) && (dbFieldInfo.DataType == "bool" || dbFieldInfo.DataType == "tinyint"))
|
else if (radioFiled.Any(f => columnName.Contains(f)) && (dbFieldInfo.DataType == "bool" || dbFieldInfo.DataType == "tinyint" || dbFieldInfo.DataType == "int"))
|
||||||
{
|
{
|
||||||
vueViewFromContent += $" <el-col :span=\"12\">\n";
|
vueViewFromContent += $" <el-col :span=\"12\">\n";
|
||||||
vueViewFromContent += $" <el-form-item label=\"{labelName}\" :label-width=\"labelWidth\" prop=\"{columnName}\">";
|
vueViewFromContent += $" <el-form-item label=\"{labelName}\" :label-width=\"labelWidth\" prop=\"{columnName}\">";
|
||||||
@ -212,7 +218,7 @@ namespace ZR.CodeGenerator
|
|||||||
{
|
{
|
||||||
vueViewFromContent += $" <el-col :span=\"12\">\n";
|
vueViewFromContent += $" <el-col :span=\"12\">\n";
|
||||||
vueViewFromContent += $" <el-form-item label=\"{ GetLabelName(dbFieldInfo.ColumnDescription, columnName)}\" :label-width=\"labelWidth\" prop=\"{FirstLowerCase(columnName)}\">\n";
|
vueViewFromContent += $" <el-form-item label=\"{ GetLabelName(dbFieldInfo.ColumnDescription, columnName)}\" :label-width=\"labelWidth\" prop=\"{FirstLowerCase(columnName)}\">\n";
|
||||||
vueViewFromContent += $" <el-input v-model=\"form.{FirstLowerCase(columnName)}\" placeholder=\"请输入{GetLabelName(dbFieldInfo.ColumnDescription, columnName)}\" />\n";
|
vueViewFromContent += $" <el-input v-model=\"form.{FirstLowerCase(columnName)}\" placeholder=\"请输入{GetLabelName(dbFieldInfo.ColumnDescription, columnName)}\" {labelDisabled}/>\n";
|
||||||
vueViewFromContent += " </el-form-item>\n";
|
vueViewFromContent += " </el-form-item>\n";
|
||||||
vueViewFromContent += " </el-col>\n";
|
vueViewFromContent += " </el-col>\n";
|
||||||
}
|
}
|
||||||
@ -221,9 +227,9 @@ namespace ZR.CodeGenerator
|
|||||||
}
|
}
|
||||||
|
|
||||||
//table-column
|
//table-column
|
||||||
private static string GetTableColumn(DbColumnInfo dbFieldInfo, string columnName)
|
private static string GetTableColumn(DbColumnInfo dbFieldInfo)
|
||||||
{
|
{
|
||||||
columnName = FirstLowerCase(columnName);
|
string columnName = FirstLowerCase(dbFieldInfo.DbColumnName);
|
||||||
string label = GetLabelName(dbFieldInfo.ColumnDescription, columnName);
|
string label = GetLabelName(dbFieldInfo.ColumnDescription, columnName);
|
||||||
string vueViewListContent = "";
|
string vueViewListContent = "";
|
||||||
string showToolTip = dbFieldInfo.DataType.Contains("varchar") ? ":show-overflow-tooltip=\"true\"" : "";
|
string showToolTip = dbFieldInfo.DataType.Contains("varchar") ? ":show-overflow-tooltip=\"true\"" : "";
|
||||||
@ -384,9 +390,10 @@ namespace ZR.CodeGenerator
|
|||||||
return;
|
return;
|
||||||
var content = ReadTemplate("IServiceTemplate.txt");
|
var content = ReadTemplate("IServiceTemplate.txt");
|
||||||
content = content.Replace("{ModelsNamespace}", modelsNamespace)
|
content = content.Replace("{ModelsNamespace}", modelsNamespace)
|
||||||
.Replace("{DtosNamespace}", _option.DtosNamespace)
|
|
||||||
.Replace("{TableNameDesc}", modelTypeDesc)
|
.Replace("{TableNameDesc}", modelTypeDesc)
|
||||||
|
.Replace("{DtosNamespace}", _option.DtosNamespace)
|
||||||
.Replace("{IServicsNamespace}", _option.IServicsNamespace)
|
.Replace("{IServicsNamespace}", _option.IServicsNamespace)
|
||||||
|
.Replace("{RepositoriesNamespace}", _option.RepositoriesNamespace)
|
||||||
.Replace("{ModelTypeName}", modelTypeName)
|
.Replace("{ModelTypeName}", modelTypeName)
|
||||||
.Replace("{KeyTypeName}", keyTypeName);
|
.Replace("{KeyTypeName}", keyTypeName);
|
||||||
WriteAndSave(fullPath, content);
|
WriteAndSave(fullPath, content);
|
||||||
@ -436,7 +443,7 @@ namespace ZR.CodeGenerator
|
|||||||
/// <param name="modelTypeDesc">实体描述</param>
|
/// <param name="modelTypeDesc">实体描述</param>
|
||||||
/// <param name="keyTypeName"></param>
|
/// <param name="keyTypeName"></param>
|
||||||
/// <param name="ifExsitedCovered">如果目标文件存在,是否覆盖。默认为false</param>
|
/// <param name="ifExsitedCovered">如果目标文件存在,是否覆盖。默认为false</param>
|
||||||
private static void GenerateControllers(string modelTypeName, string primaryKey, string modelTypeDesc, string keyTypeName, bool ifExsitedCovered = false)
|
private static void GenerateControllers(string modelTypeName, string primaryKey, string modelTypeDesc, string keyTypeName, string updateColumn, bool ifExsitedCovered = false)
|
||||||
{
|
{
|
||||||
var parentPath = "..";
|
var parentPath = "..";
|
||||||
var servicesPath = parentPath + "\\" + _option.ApiControllerNamespace + "\\Controllers\\business\\";
|
var servicesPath = parentPath + "\\" + _option.ApiControllerNamespace + "\\Controllers\\business\\";
|
||||||
@ -452,12 +459,13 @@ namespace ZR.CodeGenerator
|
|||||||
content = content
|
content = content
|
||||||
//.Replace("{DtosNamespace}", _option.DtosNamespace)
|
//.Replace("{DtosNamespace}", _option.DtosNamespace)
|
||||||
.Replace("<#=ControllerName#>", modelTypeName)
|
.Replace("<#=ControllerName#>", modelTypeName)
|
||||||
//.Replace("{ModelsNamespace}", _option.ModelsNamespace)
|
.Replace("{ModelsNamespace}", _option.ModelsNamespace)
|
||||||
.Replace("<#=FileName#>", modelTypeDesc)
|
.Replace("<#=FileName#>", modelTypeDesc)
|
||||||
.Replace("<#=ServiceName#>", modelTypeName + "Service")
|
.Replace("<#=ServiceName#>", modelTypeName + "Service")
|
||||||
.Replace("<#=ModelName#>", modelTypeName)
|
.Replace("<#=ModelName#>", modelTypeName)
|
||||||
.Replace("<#=Permission#>", modelTypeName.ToLower())
|
.Replace("<#=Permission#>", modelTypeName.ToLower())
|
||||||
.Replace("{primaryKey}", primaryKey)
|
.Replace("{primaryKey}", primaryKey)
|
||||||
|
.Replace("{updateColumn}", updateColumn)
|
||||||
.Replace("{KeyTypeName}", keyTypeName);
|
.Replace("{KeyTypeName}", keyTypeName);
|
||||||
WriteAndSave(fullPath, content);
|
WriteAndSave(fullPath, content);
|
||||||
}
|
}
|
||||||
@ -478,7 +486,8 @@ namespace ZR.CodeGenerator
|
|||||||
/// <param name="ifExsitedCovered">如果目标文件存在,是否覆盖。默认为false</param>
|
/// <param name="ifExsitedCovered">如果目标文件存在,是否覆盖。默认为false</param>
|
||||||
private static void GenerateVueViews(string modelTypeName, string primaryKey, string modelTypeDesc, string vueViewListContent, string vueViewFromContent, string vueViewEditFromContent, string vueViewEditFromBindContent, string vueViewSaveBindContent, string vueViewEditFromRuleContent, bool ifExsitedCovered = false)
|
private static void GenerateVueViews(string modelTypeName, string primaryKey, string modelTypeDesc, string vueViewListContent, string vueViewFromContent, string vueViewEditFromContent, string vueViewEditFromBindContent, string vueViewSaveBindContent, string vueViewEditFromRuleContent, bool ifExsitedCovered = false)
|
||||||
{
|
{
|
||||||
var parentPath = "..\\CodeGenerate";//若要生成到项目中将路径改成 “..\\ZR.Vue\\src”
|
//var parentPath = "..\\CodeGenerate";//若要生成到项目中将路径改成 “..\\ZR.Vue\\src”
|
||||||
|
var parentPath = "..\\ZR.Vue\\src";
|
||||||
var servicesPath = parentPath + "\\views\\" + FirstLowerCase(modelTypeName);
|
var servicesPath = parentPath + "\\views\\" + FirstLowerCase(modelTypeName);
|
||||||
if (!Directory.Exists(servicesPath))
|
if (!Directory.Exists(servicesPath))
|
||||||
{
|
{
|
||||||
@ -491,15 +500,15 @@ namespace ZR.CodeGenerator
|
|||||||
var content = ReadTemplate("VueTemplate.txt");
|
var content = ReadTemplate("VueTemplate.txt");
|
||||||
content = content
|
content = content
|
||||||
.Replace("{fileClassName}", FirstLowerCase(modelTypeName))
|
.Replace("{fileClassName}", FirstLowerCase(modelTypeName))
|
||||||
.Replace("{VueViewListContent}", vueViewListContent)
|
.Replace("{VueViewListContent}", vueViewListContent)//查询 table列
|
||||||
.Replace("{VueViewFromContent}", vueViewFromContent)
|
.Replace("{VueViewFormContent}", vueViewFromContent)//添加、修改表单
|
||||||
.Replace("{ModelTypeName}", modelTypeName)
|
.Replace("{ModelTypeName}", modelTypeName)
|
||||||
.Replace("{Permission}", modelTypeName.ToLower())
|
.Replace("{Permission}", modelTypeName.ToLower())
|
||||||
.Replace("{VueViewEditFromContent}", vueViewEditFromContent)
|
.Replace("{VueViewEditFormContent}", vueViewEditFromContent)//重置表单
|
||||||
.Replace("{VueViewEditFromBindContent}", vueViewEditFromBindContent)
|
//.Replace("{VueViewEditFromBindContent}", vueViewEditFromBindContent)
|
||||||
.Replace("{VueViewSaveBindContent}", vueViewSaveBindContent)
|
//.Replace("{VueViewSaveBindContent}", vueViewSaveBindContent)
|
||||||
.Replace("{primaryKey}", primaryKey)
|
.Replace("{primaryKey}", FirstLowerCase(primaryKey))
|
||||||
.Replace("{VueViewEditFromRuleContent}", vueViewEditFromRuleContent);
|
.Replace("{VueViewEditFormRuleContent}", vueViewEditFromRuleContent);//添加、修改表单验证规则
|
||||||
WriteAndSave(fullPath, content);
|
WriteAndSave(fullPath, content);
|
||||||
|
|
||||||
//api js
|
//api js
|
||||||
@ -512,7 +521,6 @@ namespace ZR.CodeGenerator
|
|||||||
content = ReadTemplate("VueJsTemplate.txt");
|
content = ReadTemplate("VueJsTemplate.txt");
|
||||||
content = content
|
content = content
|
||||||
.Replace("{ModelTypeName}", modelTypeName)
|
.Replace("{ModelTypeName}", modelTypeName)
|
||||||
.Replace("{ModelName}", GetModelName(modelTypeName))
|
|
||||||
.Replace("{ModelTypeDesc}", modelTypeDesc);
|
.Replace("{ModelTypeDesc}", modelTypeDesc);
|
||||||
//.Replace("{fileClassName}", fileClassName)
|
//.Replace("{fileClassName}", fileClassName)
|
||||||
WriteAndSave(fullPath, content);
|
WriteAndSave(fullPath, content);
|
||||||
@ -528,7 +536,7 @@ namespace ZR.CodeGenerator
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="modelTypeName"></param>
|
/// <param name="modelTypeName"></param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
private static string GetModelName(string modelTypeName)
|
private static string GetModelClassName(string modelTypeName)
|
||||||
{
|
{
|
||||||
if (!string.IsNullOrEmpty(_option.ReplaceTableNameStr))
|
if (!string.IsNullOrEmpty(_option.ReplaceTableNameStr))
|
||||||
{
|
{
|
||||||
|
|||||||
@ -44,7 +44,7 @@ export const constantRoutes = [
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
path: '/demo',
|
path: '/demo',
|
||||||
component: (resolve) => require(['@/views/userInfo/index'], resolve),
|
component: (resolve) => require(['@/views/gendemo/index'], resolve),
|
||||||
hidden: true
|
hidden: true
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|||||||
41
ZRAdmin.xml
41
ZRAdmin.xml
@ -920,46 +920,5 @@
|
|||||||
</summary>
|
</summary>
|
||||||
<param name="services"></param>
|
<param name="services"></param>
|
||||||
</member>
|
</member>
|
||||||
<member name="T:ZRAdmin.Controllers.UserInfoController">
|
|
||||||
<summary>
|
|
||||||
代码自动生成
|
|
||||||
</summary>
|
|
||||||
</member>
|
|
||||||
<member name="F:ZRAdmin.Controllers.UserInfoController._UserInfoService">
|
|
||||||
<summary>
|
|
||||||
接口
|
|
||||||
</summary>
|
|
||||||
</member>
|
|
||||||
<member name="M:ZRAdmin.Controllers.UserInfoController.Query(ZR.Model.Dto.UserInfoQueryDto)">
|
|
||||||
<summary>
|
|
||||||
查询列表
|
|
||||||
</summary>
|
|
||||||
<returns></returns>
|
|
||||||
</member>
|
|
||||||
<member name="M:ZRAdmin.Controllers.UserInfoController.Get(System.Int32)">
|
|
||||||
<summary>
|
|
||||||
查询详情
|
|
||||||
</summary>
|
|
||||||
<param name="luid"></param>
|
|
||||||
<returns></returns>
|
|
||||||
</member>
|
|
||||||
<member name="M:ZRAdmin.Controllers.UserInfoController.Create(ZR.Model.Dto.UserInfoDto)">
|
|
||||||
<summary>
|
|
||||||
添加
|
|
||||||
</summary>
|
|
||||||
<returns></returns>
|
|
||||||
</member>
|
|
||||||
<member name="M:ZRAdmin.Controllers.UserInfoController.Update(ZR.Model.Dto.UserInfoDto)">
|
|
||||||
<summary>
|
|
||||||
更新
|
|
||||||
</summary>
|
|
||||||
<returns></returns>
|
|
||||||
</member>
|
|
||||||
<member name="M:ZRAdmin.Controllers.UserInfoController.Delete(System.Int32)">
|
|
||||||
<summary>
|
|
||||||
删除
|
|
||||||
</summary>
|
|
||||||
<returns></returns>
|
|
||||||
</member>
|
|
||||||
</members>
|
</members>
|
||||||
</doc>
|
</doc>
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user