using IRaCIS.Core.Domain.Share;
using System.Linq;

namespace IRaCIS.Core.Domain.Models;

[Comment("系统阅片问题")]
[Table("ReadingQuestionSystem")]
public class ReadingQuestionSystem : BaseAddAuditEntity
{
    #region 导航属性
    [JsonIgnore]
    [ForeignKey("GroupId")]
    public ReadingQuestionSystem GroupInfo { get; set; }
    [JsonIgnore]
    [ForeignKey("ReadingQuestionCriterionSystemId")]
    public ReadingQuestionCriterionSystem ReadingQuestionCriterionSystem { get; set; }

    [JsonIgnore]
    public List<ReadingTableQuestionSystem> ReadingTableQuestionTrialList { get; set; }

    [JsonIgnore]
    [ForeignKey("ParentId")]
    public ReadingQuestionSystem ParentReadingQuestionSystem { get; set; }
    [JsonIgnore]
    [ForeignKey("RelevanceId")]
    public ReadingQuestionSystem RelevanceReadingQuestionSystem { get; set; }

    [NotMapped]
    public List<string> ParentTriggerValueList
    {
        get
        {
            try
            {
                return this.ParentTriggerValue.Split(',').ToList();
            }
            catch (Exception)
            {

                return new List<string>();
            }
        }

    }
    [NotMapped]
    public List<string> RelevanceValueList
    {
        get
        {
            try
            {
                return this.RelevanceValue.Split(',').ToList();
            }
            catch (Exception)
            {

                return new List<string>();
            }
        }

    }

    [NotMapped]
    public List<string> HighlightAnswerList
    {
        get
        {

            try
            {
                var result = JsonConvert.DeserializeObject<List<string>>(this.HighlightAnswer);
                return result == null ? new List<string>() : result;
            }
            catch (Exception)
            {

                return new List<string>();
            }

        }
    }
    #endregion
    [Comment("系统标准Id")]
    public Guid ReadingQuestionCriterionSystemId { get; set; }

    [Comment("类型")]
    public string Type { get; set; } = string.Empty;

    [Comment("父问题触发")]
    public string ParentTriggerValue { get; set; } = string.Empty;

    [Comment("问题名称")]
    public string QuestionName { get; set; } = string.Empty;

    [Comment("是否是必须")]
    public IsRequired IsRequired { get; set; }

    [Comment("排序")]
    public int ShowOrder { get; set; }

    [Comment("父问题ID")]
    public Guid? ParentId { get; set; }

    [Comment("类型值")]
    public string TypeValue { get; set; } = string.Empty;

    [Comment("是否启用")]
    public bool IsEnable { get; set; }
    [Comment("是否是裁判问题")]
    public bool IsJudgeQuestion { get; set; }

    [Comment("备注")]
    public string Remark { get; set; } = string.Empty;

    [Comment("关联ID")]
    public Guid? RelevanceId { get; set; }

    [Comment("关联Value")]
    public string RelevanceValue { get; set; } = string.Empty;

    [Comment("分组")]
    public string GroupName { get; set; } = string.Empty;

    [Comment("图片数量")]
    public int ImageCount { get; set; } = 1;

    [Comment("是否显示")]
    public ShowQuestion ShowQuestion { get; set; } = ShowQuestion.Show;

    [Comment("最大问题数")]
    public int? MaxQuestionCount { get; set; }

    [Comment("病灶类型")]
    public LesionType? LesionType { get; set; }

    [Comment("问题类型")]
    public QuestionType? QuestionType { get; set; }

    [Comment("是否显示在Dicom阅片中")]
    public bool IsShowInDicom { get; set; } = false;

    [Comment("序号标记")]
    public string OrderMark { get; set; } = string.Empty;

    [Comment("字典code")]
    public string DictionaryCode { get; set; } = string.Empty;
    [Comment("问题类型")]
    public TableQuestionType? QuestionGenre { get; set; }

    [Comment("全局阅片显示类型")]
    public GlobalReadingShowType GlobalReadingShowType { get; set; } = GlobalReadingShowType.NotShow;

    [Comment("转化显示类型")]
    public ConvertShowType ConvertShowType { get; set; } = ConvertShowType.All;

    [Comment("默认值")]
    public string DefaultValue { get; set; } = string.Empty;

    [Comment("数值类型")]
    public ValueOfType? ValueType { get; set; }

    [Comment("单位")]
    public ValueUnit? Unit { get; set; }
    [Comment("问题英文名称")]
    public string QuestionEnName { get; set; } = string.Empty;

    [Comment("问题英文分组")]
    public string GroupEnName { get; set; } = string.Empty;

    [Comment("限制编辑")]
    public LimitEdit LimitEdit { get; set; } = LimitEdit.None;

    [Comment("限制显示")]
    public LimitShow LimitShow { get; set; } = LimitShow.AllShow;

    [Comment("数据来源")]
    public DataSources DataSource { get; set; } = DataSources.ManualEntry;

    [Comment("最大答案长度")]
    public int? MaxAnswerLength { get; set; }

    [Comment("分组ID")]
    public Guid? GroupId { get; set; }

    [Comment("文件类型")]
    public string FileType { get; set; } = string.Empty;

    [Comment("分组分类")]
    public GroupClassify? GroupClassify { get; set; }

    [Comment("分类类型")]
    public ClassifyType? ClassifyType { get; set; }

    /// <summary>
    /// 分类编辑类型  是否可编辑
    /// </summary>
    public ClassifyEditType? ClassifyEditType { get; set; }

    /// <summary>
    /// 分类显示类型  是否显示
    /// </summary>
    public ClassifyShowType? ClassifyShowType { get; set; }

    [Comment("问题分类")]
    public QuestionClassify? QuestionClassify { get; set; }

    [Comment("高亮问题的答案")]
    public string HighlightAnswer { get; set; } = "[]";

    [Comment("导出结果")]
    public string ExportResultStr { get; set; } = "[]";

    [Comment("分类算法")]
    public string ClassifyAlgorithms { get; set; } = string.Empty;

    [Comment("分类问题Id")]
    public Guid? ClassifyQuestionId { get; set; }

    [NotMapped]
    public List<ExportResult> ExportResult
    {
        get
        {
            try
            {
                var result = JsonConvert.DeserializeObject<List<ExportResult>>(this.ExportResultStr);
                return result == null ? new List<ExportResult>() : result;
            }
            catch (Exception)
            {

                return new List<ExportResult>();
            }

        }
    }
}