package ${packageName}.model;
<#if table.tplCategory=="crud" >
    <#--判断主键类型,设置继承实体类 -->
    <#if pkColumn??&&pkColumn.javaType=="String" >
        <#assign Entity = "BaseEntityStr">
    <#elseif pkColumn??&&pkColumn.javaType=="Integer">
        <#assign Entity = "BaseEntityInt">
    <#elseif pkColumn??&&pkColumn.javaType=="Long">
        <#assign Entity = "BaseEntityLong">
    <#else>
        <#assign Entity = "BaseEntityLong">
    </#if>

<#elseif table.tplCategory=="sub" ||table.tplCategory=="subone">
    <#--判断主键类型,设置继承实体类 -->
    <#if pkColumn??&&pkColumn.javaType=="String" >
        <#assign Entity = "BaseEntityStr">
    <#elseif pkColumn??&&pkColumn.javaType=="Integer">
        <#assign Entity = "BaseEntityInt">
    <#elseif pkColumn??&&pkColumn.javaType=="Long">
        <#assign Entity = "BaseEntityLong">
    <#else>
        <#assign Entity = "BaseEntityLong">
    </#if>
<#else>
    <#assign Entity = "BaseEntityLong">
</#if>
<#list importList as import>
import ${import};
</#list>
<#list columns as column>
    <#if column.isSerialize==1>
import com.fasterxml.jackson.annotation.JsonProperty;
     <#break>
    </#if>
</#list>
import java.util.List;
import java.util.ArrayList;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.mortals.framework.annotation.Excel;
import com.mortals.framework.model.${Entity};
import ${packageName}.model.vo.${ClassName}Vo;
<#if table.tplCategory=="sub" ||table.tplCategory=="subone">
import ${subPackageName}.model.${subClassName}Entity;
</#if>
/**
* ${functionName}实体对象
*
* @author ${author}
* @date ${datetime}
*/

public class ${ClassName}Entity extends ${ClassName}Vo {
    private static final long serialVersionUID = 1L;

<#list columns as column>
<#if !column.isSuperColumn(column.javaField)>
    /** ${column.columnComment} */
    <#if column.isExport==1>
        <#assign comment=column.subComment(column.columnComment) />
        <#assign parentheseIndex =column.columnComment?index_of("(")>
        <#if parentheseIndex != -1>
    @Excel(name = "${comment}", readConverterExp = "${column.readConverterExp()}")
        <#elseif column.javaType == "Date">
    @Excel(name = "${comment}", width = 30, dateFormat = "yyyy-MM-dd")
        <#else>
    @Excel(name = "${comment}")
        </#if>
    </#if>
    <#if column.isSerialize==1>
    @JsonProperty(access = JsonProperty.Access.WRITE_ONLY)
    </#if>
    private ${column.javaType} ${column.javaField};
</#if>
</#list>

<#if table.subTable?? && table.tplCategory=="sub" >
    /** ${table.subTable.functionName}信息 */
    private List<${subClassName}Entity> ${subclassName}List=new ArrayList<>();;
</#if>

<#if table.subTable?? && table.tplCategory=="subone" >
    /** ${table.subTable.functionName}信息 */
    private ${subClassName}Entity ${subclassName}Entity=new ${subClassName}Entity();
</#if>
<#list columns as column>
<#if column.javaType == "Long"||column.javaType == "Integer"||column.javaType == "BigDecimal">
    /** 开始 ${column.columnComment} */
    private ${column.javaType} ${column.javaField}Start;

    /** 结束 ${column.columnComment} */
    private ${column.javaType} ${column.javaField}End;

    /** 增加 ${column.columnComment} */
    private ${column.javaType} ${column.javaField}Increment;

    /** ${column.columnComment}列表 */
    private List <${column.javaType}> ${column.javaField}List;

</#if>
<#if column.javaType == "String">
    /** ${column.columnComment} */
    private List<${column.javaType}> ${column.javaField}List;

</#if>
<#if column.javaType == "Date">
    /** 开始 ${column.columnComment} */
    private String ${column.javaField}Start;

    /** 结束 ${column.columnComment} */
    private String ${column.javaField}End;

</#if>
</#list>
    /** OR条件集合,列表项之间是OR,项内容之间是AND,如:(list[0].1 and list[0].2) or (list[1].3 and list[1].4) */
    private List<${ClassName}Entity> orConditionList;

    /** AND条件集合,列表项之间是AND,项内容之间是OR,如:(list[0].1 or list[0].2) and (list[1].3 or list[1].4) */
    private List<${ClassName}Entity> andConditionList;

    public ${ClassName}Entity(){}
<#--get set属性 -->
<#list columns as column>
    <#if !column.isSuperColumn(column.javaField)>
        <#if column.javaField[0..1]?matches("[A-Z]")>
            <#assign AttrName = column.javaField>
            <#else>
            <#assign AttrName = column.javaField?cap_first>
        </#if>
    /**
    * 获取 ${column.columnComment}
    * @return ${column.javaType}
    */
    public ${column.javaType} get${AttrName}(){
        return ${column.javaField};
    }
    /**
    * 设置 ${column.columnComment}
    * @param ${column.javaField}
    */
    public void set${AttrName}(${column.javaType} ${column.javaField}){
        this.${column.javaField} = ${column.javaField};
    }
    </#if>
</#list>

<#if subTable?? && table.tplCategory=="sub">
    public List<${subClassName}Entity> get${subClassName}List(){
      return ${subclassName}List;
    }

    public void set${subClassName}List(List<${subClassName}Entity> ${subclassName}List){
        this.${subclassName}List = ${subclassName}List;
    }
</#if>
<#if subTable?? && table.tplCategory=="subone">
    public ${subClassName}Entity get${subClassName}Entity(){
        return ${subclassName}Entity;
    }

    public void set${subClassName}Entity(${subClassName}Entity ${subclassName}Entity){
        this.${subclassName}Entity = ${subclassName}Entity;
    }
</#if>
<#list columns as column>
    <#if column.javaType == "Long"||column.javaType == "Integer"||column.javaType == "BigDecimal">
    /**
    * 获取 开始 ${column.columnComment}
    * @return ${column.javaField}Start
    */
    public ${column.javaType} get${column.javaField?cap_first}Start(){
        return this.${column.javaField}Start;
    }

    /**
    * 设置 开始 ${column.columnComment}
    * @param ${column.javaField}Start
    */
    public void set${column.javaField?cap_first}Start(${column.javaType} ${column.javaField}Start){
        this.${column.javaField}Start = ${column.javaField}Start;
    }

    /**
    * 获取 结束 ${column.columnComment}
    * @return $${column.javaField}End
    */
    public ${column.javaType} get${column.javaField?cap_first}End(){
        return this.${column.javaField}End;
    }

    /**
    * 设置 结束 ${column.columnComment}
    * @param ${column.javaField}End
    */
    public void set${column.javaField?cap_first}End(${column.javaType} ${column.javaField}End){
        this.${column.javaField}End = ${column.javaField}End;
    }

    /**
    * 获取 增加 ${column.columnComment}
    * @return ${column.javaField}Increment
    */
    public ${column.javaType} get${column.javaField?cap_first}Increment(){
        return this.${column.javaField}Increment;
    }

    /**
    * 设置 增加 ${column.columnComment}
    * @param ${column.javaField}Increment
    */
    public void set${column.javaField?cap_first}Increment(${column.javaType} ${column.javaField}Increment){
        this.${column.javaField}Increment = ${column.javaField}Increment;
    }

    /**
    * 获取 ${column.columnComment}
    * @return ${column.javaField}List
    */
    public List<${column.javaType}> get${column.javaField?cap_first}List(){
        return this.${column.javaField}List;
    }

    /**
    * 设置 ${column.columnComment}
    * @param ${column.javaField}List
    */
    public void set${column.javaField?cap_first}List(List<${column.javaType}> ${column.javaField}List){
        this.${column.javaField}List = ${column.javaField}List;
    }

    </#if>
    <#if column.javaType == "String">
    /**
    * 获取 ${column.columnComment}
    * @return ${column.javaField}List
    */
    public List<${column.javaType}> get${column.javaField?cap_first}List(){
        return this.${column.javaField}List;
    }

    /**
    * 设置 ${column.columnComment}
    * @param ${column.javaField}List
    */
    public void set${column.javaField?cap_first}List(List<${column.javaType}> ${column.javaField}List){
        this.${column.javaField}List = ${column.javaField}List;
    }
    </#if>
    <#if column.javaType == "Date">
    /**
    * 获取 开始 ${column.columnComment}
    * @return ${column.javaField}Start
    */
    public String get${column.javaField?cap_first}Start(){
        return this.${column.javaField}Start;
    }

    /**
    * 设置 开始 ${column.columnComment}
    * @param ${column.javaField}Start
    */
    public void set${column.javaField?cap_first}Start(String ${column.javaField}Start){
        this.${column.javaField}Start = ${column.javaField}Start;
    }

    /**
    * 获取 结束 ${column.columnComment}
    * @return ${column.javaField}End
    */
    public String get${column.javaField?cap_first}End(){
        return this.${column.javaField}End;
    }

    /**
    * 设置 结束 ${column.columnComment}
    * @param ${column.javaField}End
    */
    public void set${column.javaField?cap_first}End(String ${column.javaField}End){
        this.${column.javaField}End = ${column.javaField}End;
    }

    </#if>
</#list>
<#list columns as column>
    <#if column.javaType == "Long"||column.javaType == "Integer"||column.javaType == "BigDecimal">
    /**
    * 设置  ${column.columnComment}
    * @param ${column.javaField}
    */
    public ${ClassName}Entity ${column.javaField}(${column.javaType} ${column.javaField}){
	    set${column.javaField?cap_first}(${column.javaField});
		return this;
    }
    /**
    * 设置 开始 ${column.columnComment}
    * @param ${column.javaField}Start
    */
    public ${ClassName}Entity ${column.javaField}Start(${column.javaType} ${column.javaField}Start){
		this.${column.javaField}Start = ${column.javaField}Start;
		return this;
    }
    /**
    * 设置 结束 ${column.columnComment}
    * @param ${column.javaField}End
    */
    public ${ClassName}Entity ${column.javaField}End(${column.javaType} ${column.javaField}End){
		this.${column.javaField}End = ${column.javaField}End;
		return this;
    }
    /**
    * 设置 增加 ${column.columnComment}
    * @param ${column.javaField}Increment
    */
    public ${ClassName}Entity ${column.javaField}Increment(${column.javaType} ${column.javaField}Increment){
		this.${column.javaField}Increment = ${column.javaField}Increment;
		return this;
    }
    /**
    * 设置 ${column.columnComment}
    * @param ${column.javaField}List
    */
    public ${ClassName}Entity ${column.javaField}List(List<${column.javaType}> ${column.javaField}List){
        this.${column.javaField}List = ${column.javaField}List;
		return this;
    }
    </#if>
    <#if column.javaType  == "String">
	/**
    * 设置 ${column.columnComment}
    * @param ${column.javaField}
    */
    public ${ClassName}Entity ${column.javaField}(${column.javaType} ${column.javaField}){
        set${column.javaField?cap_first}(${column.javaField});
		return this;
    }

    /**
    * 设置 ${column.columnComment}
    * @param ${column.javaField}List
    */
    public ${ClassName}Entity ${column.javaField}List(List<${column.javaType}> ${column.javaField}List){
        this.${column.javaField}List = ${column.javaField}List;
		return this;
    }

    </#if>
    <#if column.javaType == "java.util.Date">
    /**
    * 设置 开始 ${column.columnComment}
    * @param ${column.javaField}Start
    */
    public ${ClassName}Entity ${column.javaField}Start(String ${column.javaField}Start){
		this.${column.javaField}Start = ${column.javaField}Start;
		return this;
    }

    /**
    * 设置 结束 ${column.columnComment}
    * @param ${column.javaField}End
    */
    public ${ClassName}Entity ${column.javaField}End(String ${column.javaField}End){
		this.${column.javaField}End = ${column.javaField}End;
		return this;
    }

    </#if>
</#list>
    /**
    * 获取 OR条件集合,列表项之间是OR,项内容之间是AND,如:(list[0].1 and list[0].2) or (list[1].3 and list[1].4)
    * @return orConditionList
    */
    public List<${ClassName}Entity> getOrConditionList(){
        return this.orConditionList;
    }

    /**
    * 设置 OR条件集合,列表项之间是OR,项内容之间是AND,如:(list[0].1 and list[0].2) or (list[1].3 and list[1].4)
    * @param orConditionList
    */
    public ${ClassName}Entity setOrConditionList(List<${ClassName}Entity> orConditionList){
        this.orConditionList = orConditionList;
        return this;
    }

    /**
    * 获取 AND条件集合,列表项之间是AND,项内容之间是OR,如:(list[0].1 or list[0].2) and (list[1].3 or list[1].4)
    * @return andConditionList
    */
    public List<${ClassName}Entity> getAndConditionList(){
        return this.andConditionList;
    }

    /**
    * 设置 AND条件集合,列表项之间是AND,项内容之间是OR,如:(list[0].1 or list[0].2) and (list[1].3 or list[1].4)
    * @param andConditionList
    */
    public ${ClassName}Entity setAndConditionList(List<${ClassName}Entity> andConditionList){
        this.andConditionList = andConditionList;
        return this;
    }

    @Override
    public int hashCode() {
         return this.getId().hashCode();
    }
    @Override
    public boolean equals(Object obj) {
        if (obj == null) return false;
        if (obj instanceof ${ClassName}Entity) {
            ${ClassName}Entity tmp = (${ClassName}Entity) obj;
            if (this.getId() == tmp.getId()) {
                 return true;
            }
        }
        return false;
    }

    public String toString(){
        StringBuilder sb = new StringBuilder("");
        <#list columns as column>
        <#if !column.isSuperColumn(column.javaField)>
        sb.append(",${column.javaField}:").append(get${column.javaField?cap_first}());
       </#if>
        </#list>
        return sb.toString();
    }

    public void initAttrValue(){
    <#list columns as column>
        <#if !column.isSuperColumn(column.javaField)>
        <#if column.javaType=="Long" && column.defaultValue??&& column.defaultValue!="">
            <#assign Default>${column.defaultValue}L</#assign>
        <#elseif column.javaType=="Integer" && column.defaultValue?? && column.defaultValue!="">
            <#assign Default>${column.defaultValue}</#assign>
        <#elseif column.javaType=="String" && column.defaultValue??>
            <#assign Default>"${column.defaultValue}"</#assign>
        <#elseif column.javaType=="BigDecimal" && column.defaultValue??&& column.defaultValue!="">
            <#assign Default>BigDecimal.valueOf(${column.defaultValue})</#assign>
        <#elseif column.javaType=="Date" >
            <#assign Default>null</#assign>
        <#else>
            <#assign Default>null</#assign>
        </#if>
            this.${column.javaField} = ${Default};
        </#if>
    </#list>
    }
}