---
# Canto config file  -*- conf -*-
name: Fly-Canto
long_name: FlyBase's phenotype curation tool @ flybase-vm
database_name: FlyBase


instance_organism:
  taxonid: 7227                    

flybase_mode: 1

annotation_figure_field: 0

# disable deletion buttons on genotype management page?
show_quick_deletion_buttons: 0

# this will define Canto's internal SQL database (track.sqlite3 and files for all curation sessions) to the the 'data' sub-folder of 'canto-space' (<filepath>/canto-space/data), which is where all data should reside.
# Here, filepaths are somewhat relative. Please have an initial '/' in both '/data/track.sqlite3' and '/data' below, otherwise track.sqlite3 and the curation data will be added to a new 'data' folder at '<filepath>/canto-space/canto/data', rather than to the existing 'data' sub-folder of 'canto-space' at '<filepath>/canto-space/data'.
Model::TrackModel:
  connect_info:
# this sets the path (and name) of the sqlite3 file 'track.sqlite3', which queries curation sessions within canto
# as mentioned above, make sure it does include the initial '/', otherwise 'track.sqlite3' will be misplaced in a new 'data' folder at '<filepath>/canto-space/canto/data'
## Make sure the folder where the SQL database 'track.sqlite3' lives (/data in /data/track.sqlite3) matches the data_directory value mentioned below (/data) 
    - dbi:SQLite:dbname=/data/track.sqlite3
  schema_class: Canto::TrackDB
# this sets the path to the 'data' sub-folder of 'canto-space', which is where all curation data should reside.
# as mentioned above, make sure it does include the initial '/', otherwise curation session will be misplaced in a new folder '<filepath>/canto-space/canto/data' rather than in the existing 'data' sub-folder of 'canto-space'
## Make sure the folder where the SQL database 'track.sqlite3' lives (/data/track.sqlite3) matches this data_directory value (/data)
data_directory: /data

#Database to connect to - 'connect_info:' bit is the only part that needs changes on a weekly basis
Model::ChadoModel:
  connect_info:
    - "dbi:Pg:dbname=flybase; host=deneb.pdn.cam.ac.uk"
    - USERNAME
    - PASSWORD
  schema_class: Canto::ChadoDB

#This is required to enable connection to main Chado
chado:
  taxon_id_lookup_strategy: dbxref
  ignore_case_in_gene_query: 0
  
#This is also required to enable the Chado database connection 
implementation_classes:
  gene_adaptor: Canto::Chado::GeneLookup
  go_adaptor: Canto::Track::OntologyLookup
  ontology_adaptor: Canto::Track::OntologyLookup

# Configuration of private notes (internal notes in FlyBase lingo)
## the heading above the external_notes section on the front page of the publication session, if any (this notes are external to Canto but internal for FlyBase, hence the difference in labels)
external_notes_label: Internal notes from JSON
## header for 'message to curators' section on the front page (if enabled); for FlyBase, these are the publication-level internal notes created by the curator within the session
message_to_curators_label: Internal notes from session
# if 1 (if yes), show the internal notes on the front page
show_message_for_curators_on_front_page: 1


# configuration of alleles
## trying to remove fields for strain and allele expression - did not seem to work on initial test
alleles_have_expression: 0
#disable strains
strains_mode: 0
split_genotypes_by_organism: 0
##this enables the allele creation table on the genotype management page
show_genotype_management_genes_list: 1
#this allows annotation of diploid genotypes 
diploid_mode: 1

## display wildtype 'alleles' simply as '+'
wildtype_name_template: '@@gene_display_name@@[+]'

## allow internal notes on single alleles and config:
notes_on_single_allele_genotypes_only: 1

allele_note_types:
  - name: phenotype
    display_name: Phenotype
  - name: genetic_interaction
    display_name: Genetic interaction
  - name: xenogenetic_interaction
    display_name: Xenogenetic interaction
  - name: rescue_complementation
    display_name: Rescue/Complementation
  - name: internal_note
    display_name: Internal note


## configuration of allele types
allele_type_list:
  - name: other
    export_type: other
    show_description: true
    description_required: false
    allele_name_required: false
    allow_expression_change: false
    expression_required: false
    hide_type_name: true
    placeholder: Please provide a description
  - name: accessory
    export_type: accessory
    show_description: true
    description_required: false
    allele_name_required: false
    allow_expression_change: false
    expression_required: false
    do_not_annotate: true
    placeholder: Please provide a description
  - name: aberration
    export_type: aberration
    show_description: true
    description_required: false
    allele_name_required: false
    allow_expression_change: false
    expression_required: false

# put the genotype lists in the same order as the allele_type_list
sort_genotype_management_page_by_allele_type: 1


# the name of the organisation running this Canto - shown in various places in the user interface
database_name: FlyBase

database_url: www.flybase.org

instance_front_subtitle: Fly-Canto for FlyBase

available_annotation_type_list:
  - name: phenotypic_class
    category: ontology
    namespace: phenotypic_class
    hide_extension_relations: [qual,dv_qual]
    very_short_display_name: 'phen-class'
    short_display_name: 'phen-class'
    display_name: 'phenotype class'
    synonyms_to_display:
      - exact
    feature_type: 'genotype'
    can_have_conditions: 0
    #allow_annotation_transfer - use true/false
    allow_annotation_transfer: true
    broad_term_suggestions: >
      lethal, sterile, visible, abnormal cell number, abnormal locomotor behavior
    specific_term_examples: >
      increased cell size, decreased body size
    help_text: >
      Annotate abnormal phenotypes of organims or cells with this genotype.
    more_help_text: >
      This a basic discription of a phenotype, i.e. any observable characteristic or trait of an organism;
      observable characteristics include morphology, development, behaviour
    extra_help_text: >
      Alleles may be annotated with multiple phenotype terms.
    detailed_help_path:
  - name: anatomy
    category: ontology
    namespace: FlyBase_anatomy_CV
    hide_extension_relations: [qual,dv_qual]
    very_short_display_name: 'anatomy'
    short_display_name: 'anatomy'
    display_name: 'phenotype anatomy'
    synonyms_to_display:
      - exact
    feature_type: 'genotype'
    can_have_conditions: 0
    #allow_annotation_transfer - use true/false
    allow_annotation_transfer: true
    broad_term_suggestions: >
      embryo, wing, eye, ovary, wing disc, neuromuscular junction
    specific_term_examples: >
      NMJ bouton, oocyte, photoreceptor cell of the eye
    help_text: >
      Annotate the anatomy (organ, structure, cell or subcellular structure) where abnormal phenotype occurs in organims or cells with this genotype.
    more_help_text: >
      A phenotype is any observable characteristic or trait of an organism;
      observable characteristics include morphology, development, behaviour
    extra_help_text: >
      Alleles may be annotated with multiple phenotype terms
    detailed_help_path: 
  - name: phenotype_interaction
    category: interaction
    namespace: phenotypic_class
    term_suggestions_annotation_type: phenotypic_class
    interaction_term_required: 1
    #allow_annotation_transfer - use true/false
    allow_annotation_transfer: true
    hide_extension_relations: [qual,dv_qual]
    display_name: 'phenotype class interaction'
    very_short_display_name: 'phen-class interaction'
    short_display_name: 'phen-class interaction'
    feature_type: 'metagenotype'
    help_text: 'Examples: suppressible, non-suppressible, enhanceable, non-enhanceable, non-modified.'
    evidence_codes:
      - suppressible
      - "suppressible | partially"
      - enhanceable
      - non-suppressible
      - non-enhanceable
      - non-modified
    detailed_help_path: /docs/genetic_interaction_annotation
  - name: anatomy_interaction
    category: interaction
    namespace: FlyBase_anatomy_CV
    term_suggestions_annotation_type: anatomy
    interaction_term_required: 1
    #allow_annotation_transfer - use true/false
    allow_annotation_transfer: true
    hide_extension_relations: [qual,dv_qual]
    display_name: 'phenotype anatomy interaction'
    very_short_display_name: 'anatomy interaction'
    short_display_name: 'anatomy interaction'
    feature_type: 'metagenotype'
    help_text: 'Examples: suppressible, non-suppressible, enhanceable, non-enhanceable, non-modified.'
    evidence_codes:
      - suppressible
      - "suppressible | partially"
      - enhanceable
      - non-suppressible
      - non-enhanceable
      - non-modified
    detailed_help_path: /docs/genetic_interaction_annotation
  - name: complementation
    can_have_conditions: 0
    #single_allele_only -  use true/false
    single_allele_only: true
    #interaction_same_locus -  use true/false
    interaction_same_locus: false
    #allow_annotation_transfer - use true/false
    allow_annotation_transfer: true
    category: interaction
    display_name: 'complementation'
    feature_type: 'metagenotype'
    help_text: 'Examples: Complements, Partially complements, Fails to complement'
    evidence_codes:
      - Complements
      - Partially complements
      - Fails to complement
  - name: rescue
    can_have_conditions: 0
    allow_annotation_transfer: 1
    #single_locus_only -  use true/false
    single_locus_only: true
    #interaction_same_locus -  use true/false
    interaction_same_locus: true
    #allow_annotation_transfer - use true/false
    allow_annotation_transfer: true
    category: interaction
    display_name: 'rescue'
    feature_type: 'metagenotype'
    help_text: 'Examples: Rescues, Partially Rescues, Fails to Rescue'
    evidence_codes:
      - Rescues
      - Partially rescues
      - Fails to rescue
  - name: expression
    category: ontology
    namespace: FlyBase_anatomy_CV
    hide_extension_relations: [qual,dv_qual]
    very_short_display_name: 'exp'
    short_display_name: 'exp'
    display_name: 'expression'
    synonyms_to_display:
      - exact
    feature_type: 'gene'
    can_have_conditions: 0
    broad_term_suggestions: >
      wing, ovary
    specific_term_examples: >
      
    help_text: >
      Annotate the expression pattern of this gene.
    more_help_text: >
      
    extra_help_text: >
      
    detailed_help_path: /docs/fypo_annotation
  - name: disease_(DO)
    category: ontology
    namespace: disease_ontology
    hide_extension_relations: [qual,dv_qual]
    very_short_display_name: 'phen-class'
    short_display_name: 'DO'
    display_name: 'Disease_(DO)'
    synonyms_to_display:
      - exact
    feature_type: 'genotype'
    can_have_conditions: 0
    #allow_annotation_transfer - use true/false
    allow_annotation_transfer: true
    broad_term_suggestions: >
      
    specific_term_examples: >
      
    help_text: >
      Annotate diseases modeled by this genotype.
    more_help_text: >
      
    extra_help_text: >
      
    detailed_help_path:

  - name: disease_interaction
    category: interaction
    namespace: disease_ontology
    term_suggestions_annotation_type: disease_ontology
    interaction_term_required: 1
    #allow_annotation_transfer - use true/false
    allow_annotation_transfer: true
    hide_extension_relations: [qual,dv_qual]
    display_name: 'disease_(DO)_interaction'
    very_short_display_name: 'DO interaction'
    short_display_name: 'DO interaction'
    feature_type: 'metagenotype'
    help_text: 'Examples: ameliorated by, exacerbated by, NOT ameliorated by, NOT exacerbated by.'
    evidence_codes:
      - "is ameliorated by"
      - "is exacerbated by"
      - "is NOT ameliorated by"
      - "is NOT exacerbated by"
    detailed_help_path: /docs/genetic_interaction_annotation


# Which of the annotation types listed above (under 'available_annotation_type_list:') to display and enable.
enabled_annotation_type_list:
  - phenotypic_class
  - anatomy
  - phenotype_interaction
  - anatomy_interaction
  - complementation
  - rescue
#  - expression
#  - disease_(DO)
#  - disease_interaction


ontology_namespace_config:
  subsets_to_ignore:
    primary_autocomplete:
      - "is_a(Grouping_terms)"
    primary_select:
      - "is_a(Grouping_terms)"
      - "is_a(qc_do_not_annotate)"
    extension:
# - add the ash to allow top/root terms (while still disallowing 'do not annotate' terms):
      # - "is_a(canto_root_subset)"
      - "is_a(qc_do_not_annotate)"
  do_not_annotate_subsets:
    - "is_a(canto_root_subset)"
    - "is_a(qc_do_not_annotate)"


# configuration for annotation extensions in the user interface
# See: https://github.com/pombase/canto/wiki/AnnotationExtensionConfig
extension_conf_files:
   - extension_config.tsv


# to show the gene list on the genotype management gene list, un-comment the next three lines - i.e. remove the #. The spaces before "taxonid:" are needed
#show_genotype_management_genes_list: 1
#instance_organism:
#   taxonid: 7227


cache:
  memcached:
    servers:
      - 127.0.0.1:11211


#which interaction evidence codes can be used with which phenotype classes
namespace_term_evidence_codes:
  phenotypic_class:
    # viable (minus partially lethal - majority live)
    - constraint: "is_a(FBcv:0000349)-is_a(FBcv:0000350)"
      evidence_codes: []
    # increased mortality during development (except lethal)
    - constraint: "is_a(FBcv:0002019)-is_a(FBcv:0000351)"
      evidence_codes:
       - suppressible
       - "suppressible | partially"
       - enhanceable
       - non-suppressible
       - non-enhanceable
       - non-modified
    # lethal (but not the more specific child terms)
    - constraint: "is_a(FBcv:0000351)-is_a(FBcv:0002000)"
      evidence_codes:
       - suppressible
       - non-suppressible
    # lethal terms detailed with developmental stage
    - constraint: "is_a(FBcv:0002000)"
      evidence_codes:
       - suppressible
       - non-suppressible
       - non-enhanceable
       - non-modified
    # partially lethal
    - constraint: "is_a(FBcv:0002015)"
      evidence_codes:
       - suppressible
       - "suppressible | partially"
       - enhanceable
       - non-suppressible
       - non-enhanceable
       - non-modified
    # some die during embryonic stage
    - constraint: "is_a(FBcv:0002041)"
      evidence_codes:
       - suppressible
       - non-suppressible
       - non-enhanceable
       - non-modified
    # some die during larval stage
    - constraint: "is_a(FBcv:0002023)"
      evidence_codes:
       - suppressible
       - non-suppressible
       - non-enhanceable
       - non-modified
    # some die during P-stage
    - constraint: "is_a(FBcv:0002020)"
      evidence_codes:
       - suppressible
       - non-suppressible
       - non-enhanceable
       - non-modified
    # some die during immature adult stage
    - constraint: "is_a(FBcv:0002051)"
      evidence_codes:
       - suppressible
       - non-suppressible
       - non-enhanceable
       - non-modified
    # fertile (minus semi-fertile)
    - constraint: "is_a(FBcv:0000374)-is_a(FBcv:0000375)"
      evidence_codes: []
    # semi-fertile
    - constraint: "is_a(FBcv:0000375)"
      evidence_codes:
       - suppressible
       - "suppressible | partially"
       - enhanceable
       - non-suppressible
       - non-enhanceable
       - non-modified
    # semi-sterile
    - constraint: "is_a(FBcv:0000365)"
      evidence_codes:
       - suppressible
       - "suppressible | partially"
       - enhanceable
       - non-suppressible
       - non-enhanceable
       - non-modified
    # sterile
    - constraint: "is_a(FBcv:0000364)"
      evidence_codes:       
       - suppressible
       - non-suppressible

class_info:
  track:
    cv:
      class_display_name: controlled vocabulary
      editable: 1
      display_field: name
      field_info_list:
        - name: name
          editable: 1
        - name: definition
          editable: 1
        - name: "term count"
          source:
            sql: 'select count(*) from cvterm where cvterm.cv_id = me.cv_id'
        - name: "load date"
          source:
            sql: "select value from cvprop p join cvterm pt on p.type_id = pt.cvterm_id where p.cv_id = me.cv_id and pt.name = 'cv_date'"
    cvprop:
      class_display_name: controlled vocabulary properties
      display_field: value
      field_info_list:
        - name: type
          source: type_id
          referenced_class: Cvterm
        - name: value
          editable: 1
    cvterm:
      class_display_name: controlled vocabulary term
      editable: 1
      display_field: name
      field_info_list:
        - name: name
          editable: 1
        - name: definition
          editable: 1
        - name: cv_id
          editable: 1
    db:
      editable: 1
      display_field: name
      field_info_list:
        - name: name
          editable: 1
        - name: description
          editable: 1
        - name: url
          editable: 1
        - name: "accessions stored"
          source:
            sql: 'select count(*) from dbxref where dbxref.db_id = me.db_id'
    dbxref:
      editable: 1
      display_field: accession
      field_info_list:
        - name: db_id
          editable: 1
        - name: accession
          editable: 1
        - name: description
          editable: 1
        - name: cvterm_id
          editable: 1
    organism:
      editable: 1
      display_field: full_name
      order_by:
        - scientific_name
      field_info_list:
        - name: scientific_name
          editable: 1
    organism_report:
      extends: organism
      '+field_info_list':
        - name: Number of genes
          source:
            sql: 'select count(*) from gene where gene.organism = me.organism_id'
    person:
      object_title_format: 'Details for @@DISPLAY_FIELD@@'
      editable: 1
      display_field: name
      order_by: name
      search_fields:
        - email_address
        - name
        - orcid
      field_info_list:
        - name: name
          source: name
          editable: 1
        - name: orcid
          editable: 1
        - name: known_as
          editable: 1
        - name: email_address
          editable: 1
        - name: role
          default_value: "'user'"
          values_constraint: 'where me.cv_id = (SELECT cv_id FROM cv where cv.name = "Canto user types")'
          editable: 1
          admin_only: 1
        - name: Sessions
          source:
            sql: "select count(curs) from curs_curator cc1 where cc1.curator = person_id and curs_curator_id = (select max(curs_curator_id) from curs_curator cc2 where cc2.curs = cc1.curs)"
        - name: Approved sessions
          source:
            sql: "select count(curs) from curs_curator cc1 where cc1.curator = person_id and curs_curator_id = (select max(curs_curator_id) from curs_curator cc2 where cc2.curs = cc1.curs) and cc1.curs in (select curs_id from curs where curs_id in (select curs from cursprop p join cvterm t on p.type = t.cvterm_id where t.name = 'annotation_status' and p.value = 'APPROVED'))"
        - name: password
          editable: 1
          admin_only: 1
    lab:
      editable: 1
      display_field: name
      order_by: name
      field_info_list:
        - name: name
          editable: 1
        - name: lab_head
          editable: 1
        - name: people
          is_collection: 1
          editable: 1
    pub:
      object_title_format: 'Details for publication: @@$object->uniquename()@@'
      class_display_name: publication
      display_field: 'Publication ID'
      search_fields:
        - uniquename
      editable: 1
      # hack to order by pubmed id, or by doi number
      order_by: "cast((case me.uniquename like 'PMID:%' WHEN 1 THEN substr(me.uniquename, 6) ELSE me.uniquename END) as integer)"
      field_info_list:
        - name: 'Publication ID'
          source: uniquename
        - name: title
        - name: authors
        - name: abstract
          extra_field_class: non-important-attribute-field
          hide_context:
            - list
            - inline_list
        - name: citation
          hide_context:
            - list
            - inline_list
        - name: publication_date
        - name: affiliation
          hide_context:
            - list
            - inline_list
        - name: corresponding_author
          editable: 1
          hide_context:
            - list
            - inline_list
        - name: current_curator
          referenced_class: Person
          source:
            sql: "select curator from curs_curator where curs_curator_id = (select max(curs_curator_id) from curs_curator cc, curs c where cc.curs = c.curs_id and c.pub = me.pub_id)"
        
        - name: session_status
          source:
            sql: "select value from curs, cursprop p, cvterm t where me.pub_id = curs.pub and curs.curs_id = p.curs and t.cvterm_id = p.type and t.name = 'annotation_status'"
          editable: 0
        - name: approver_name
          source:
            sql: "select value from curs, cursprop p, cvterm t where me.pub_id = curs.pub and curs.curs_id = p.curs and t.cvterm_id = p.type and t.name = 'approver_name'"
          editable: 0
        - name: load_type
          source: load_type_id
          values_constraint: 'where me.cv_id = (SELECT cv_id FROM cv where cv.name = "Canto publication load types")'
          referenced_class: Cvterm
          editable: 1
          hide_context:
            - list
            - inline_list
        - name: triage_status
          source: triage_status_id
          values_constraint: 'where me.cv_id = (SELECT cv_id FROM cv where cv.name = "Canto publication triage status")'
          referenced_class: Cvterm
          editable: 1
          hide_context:
            - inline_list
        - name: curation_priority
          source: curation_priority_id
          values_constraint: 'where me.cv_id = (SELECT cv_id FROM cv where cv.name = "Canto curation priorities")'
          referenced_class: Cvterm
          editable: 1
    pub_curation_status:
      class_display_name: publication curation status
      display_field: status_id
      editable: 1
      field_info_list:
        - name: publication
          source: pub_id
          editable: 1
        - name: annotation_type
          editable: 1
        - name: status
          source: status_id
          values_constraint: 'where me.cv_id = (SELECT cv_id FROM cv where cv.name = "Canto publication curation status")'
          referenced_class: Cvterm
          editable: 1
    pubprop:
      class_display_name: publication properties
      display_field: value
      editable: 1
      field_info_list:
        - name: publication
          source: pub_id
          editable: 1
        - name: type_id
          values_constraint: 'where me.cv_id = (SELECT cv_id FROM cv where cv.name = "Canto publication experiment types")'
          referenced_class: Cvterm
          editable: 1
        - name: value
          editable: 1
    curs:
      class_display_name: curation session
      display_field: curs_key
      editable: 0
      field_info_list:
        - name: curs_key
          editable: 0
        - name: publication
          editable: 0
          source: pub
        - name: creation_date
          editable: 0
        - name: current_curator
          referenced_class: Person
          source:
            sql: "select curator from curs_curator where curs_curator_id = (select max(curs_curator_id) from curs_curator where curs = me.curs_id)"
        - name: accepted
          source:
            sql: "select (case when (accepted_date is null) THEN 'no' ELSE accepted_date END) from curs_curator where curs_curator_id = (select max(curs_curator_id) from curs_curator where curs = me.curs_id)"
        - name: last_assigned
          source:
            sql: "select creation_date from curs_curator where curs_curator_id = (select max(curs_curator_id) from curs_curator where curs = me.curs_id)"
        - name: last_sent_date
          source:
            sql: "select value from cursprop p, cvterm t where me.curs_id = p.curs and t.cvterm_id = p.type and t.name = 'link_sent_to_curator_date' order by value DESC"
        - name: session_sent_count
          source:
            sql: "cast((select count(value) from cursprop p, cvterm t where me.curs_id = p.curs and t.cvterm_id = p.type and t.name = 'link_sent_to_curator_date') as int)"
        - name: status
          source:
            sql: "select value from cursprop p, cvterm t where me.curs_id = p.curs and t.cvterm_id = p.type and t.name = 'annotation_status'"
        - name: approver_name
          source:
            sql: "select value from cursprop p, cvterm t where me.curs_id = p.curs and t.cvterm_id = p.type and t.name = 'approver_name'"
        - name: genes_added
          source:
            sql: "cast((select value from cursprop p, cvterm t where me.curs_id = p.curs and t.cvterm_id = p.type and t.name = 'session_genes_count') as int)"
        - name: term_suggestions
          source:
            sql: "cast((select value from cursprop p, cvterm t where me.curs_id = p.curs and t.cvterm_id = p.type and t.name = 'session_term_suggestions_count') as int)"
# if the hook dies the creation fails
      pre_create_hook: 'Canto::Track::create_curs_db_hook'
    cursprop:
      class_display_name: Session properties
      editable: 1
      field_info_list:
        - name: type
          values_constraint: 'where me.cv_id = (SELECT cv_id FROM cv where cv.name = "Canto cursprop types")'
          referenced_class: Cvterm
          editable: 1
        - name: value
          editable: 1
        - name: curs
          editable: 1
    curs_curator:
      class_display_name: Session curator
      editable: 1
      field_info_list:
        - name: curs
          editable: 1
        - name: curator
          editable: 1
    gene:
      editable: 1
      display_field: primary_identifier
      search_fields:
        - primary_identifier
        - primary_name
        - product
      field_info_list:
        - name: primary_identifier
          editable: 1
        - name: primary_name
          editable: 1
        - name: product
          editable: 1
        - name: genesynonyms
          editable: 1
          is_collection: 1
        - name: organism
          editable: 1
    genesynonym:
      editable: 1
      display_field: identifier
      field_info_list:
        - name: identifier
          editable: 1
        - name: gene
          editable: 1
    named_genes:
      extends: gene
      constraint: "primary_name is not null"

    all_publications:
      extends: pub
    curated_publications:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and (p.value = 'NEEDS_APPROVAL' or p.value = 'APPROVAL_IN_PROGRESS' or p.value ='APPROVED')))"
    high_priority_publications:
      extends: pub
      constraint: "triage_status_id in (select cvterm_id from cvterm where name = 'HIGH_PRIORITY')"
    high_priority_publications_with_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs) and triage_status_id in (select cvterm_id from cvterm where name = 'HIGH_PRIORITY')"
    high_priority_publications_with_approved_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'APPROVED')) and triage_status_id in (select cvterm_id from cvterm where name = 'HIGH_PRIORITY')"
    high_priority_publications_with_multiple_sessions:
      extends: pub
      constraint: "triage_status_id in (select cvterm_id from cvterm where name = 'HIGH_PRIORITY') and exists (select * from curs c1, curs c2 where c1.pub = me.pub_id and c2.pub = me.pub_id and c1.curs_id <> c2.curs_id)"
    high_priority_publications_without_sessions:
      extends: pub
      constraint: "pub_id not in (select pub from curs) and triage_status_id in (select cvterm_id from cvterm where name = 'HIGH_PRIORITY')"
    high_priority_publications_with_new_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'SESSION_CREATED')) and triage_status_id in (select cvterm_id from cvterm where name = 'HIGH_PRIORITY')"
    high_priority_publications_with_active_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and (p.value = 'SESSION_ACCEPTED' or p.value = 'CURATION_IN_PROGRESS' or p.value = 'CURATION_PAUSED'))) and triage_status_id in (select cvterm_id from cvterm where name = 'HIGH_PRIORITY')"
    disease_publications:
      extends: pub
      constraint: "triage_status_id in (select cvterm_id from cvterm where name = 'DISEASE')"
    disease_publications_with_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs) and triage_status_id in (select cvterm_id from cvterm where name = 'DISEASE')"
    disease_publications_with_approved_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'APPROVED')) and triage_status_id in (select cvterm_id from cvterm where name = 'DISEASE')"
    disease_publications_with_multiple_sessions:
      extends: pub
      constraint: "triage_status_id in (select cvterm_id from cvterm where name = 'DISEASE') and exists (select * from curs c1, curs c2 where c1.pub = me.pub_id and c2.pub = me.pub_id and c1.curs_id <> c2.curs_id)"
    disease_publications_without_sessions:
      extends: pub
      constraint: "pub_id not in (select pub from curs) and triage_status_id in (select cvterm_id from cvterm where name = 'DISEASE')"
    disease_publications_with_new_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'SESSION_CREATED')) and triage_status_id in (select cvterm_id from cvterm where name = 'DISEASE')"
    disease_publications_with_active_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and (p.value = 'SESSION_ACCEPTED' or p.value = 'CURATION_IN_PROGRESS' or p.value = 'CURATION_PAUSED'))) and triage_status_id in (select cvterm_id from cvterm where name = 'DISEASE')"
    pheno_publications:
      extends: pub
      constraint: "triage_status_id in (select cvterm_id from cvterm where name = 'PHENO')"
    pheno_publications_with_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO')"
    pheno_publications_with_approved_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'APPROVED')) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO')"
    pheno_publications_with_multiple_sessions:
      extends: pub
      constraint: "triage_status_id in (select cvterm_id from cvterm where name = 'PHENO') and exists (select * from curs c1, curs c2 where c1.pub = me.pub_id and c2.pub = me.pub_id and c1.curs_id <> c2.curs_id)"
    pheno_publications_without_sessions:
      extends: pub
      constraint: "pub_id not in (select pub from curs) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO')"
    pheno_publications_with_new_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'SESSION_CREATED')) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO')"
    pheno_publications_with_active_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and (p.value = 'SESSION_ACCEPTED' or p.value = 'CURATION_IN_PROGRESS' or p.value = 'CURATION_PAUSED'))) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO')"
    pheno_anat_publications:
      extends: pub
      constraint: "triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_ANAT')"
    pheno_anat_publications_with_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_ANAT')"
    pheno_anat_publications_with_approved_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'APPROVED')) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_ANAT')"
    pheno_anat_publications_with_multiple_sessions:
      extends: pub
      constraint: "triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_ANAT') and exists (select * from curs c1, curs c2 where c1.pub = me.pub_id and c2.pub = me.pub_id and c1.curs_id <> c2.curs_id)"
    pheno_anat_publications_without_sessions:
      extends: pub
      constraint: "pub_id not in (select pub from curs) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_ANAT')"
    pheno_anat_publications_with_new_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'SESSION_CREATED')) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_ANAT')"
    pheno_anat_publications_with_active_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and (p.value = 'SESSION_ACCEPTED' or p.value = 'CURATION_IN_PROGRESS' or p.value = 'CURATION_PAUSED'))) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_ANAT')"
    pheno_chem_publications:
      extends: pub
      constraint: "triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_CHEM')"
    pheno_chem_publications_with_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_CHEM')"
    pheno_chem_publications_with_approved_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'APPROVED')) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_CHEM')"
    pheno_chem_publications_with_multiple_sessions:
      extends: pub
      constraint: "triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_CHEM') and exists (select * from curs c1, curs c2 where c1.pub = me.pub_id and c2.pub = me.pub_id and c1.curs_id <> c2.curs_id)"
    pheno_chem_publications_without_sessions:
      extends: pub
      constraint: "pub_id not in (select pub from curs) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_CHEM')"
    pheno_chem_publications_with_new_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'SESSION_CREATED')) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_CHEM')"
    pheno_chem_publications_with_active_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and (p.value = 'SESSION_ACCEPTED' or p.value = 'CURATION_IN_PROGRESS' or p.value = 'CURATION_PAUSED'))) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_CHEM')"
    pheno_dataset_publications:
      extends: pub
      constraint: "triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_DATASET')"
    pheno_dataset_publications_with_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_DATASET')"
    pheno_dataset_publications_with_approved_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'APPROVED')) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_DATASET')"
    pheno_dataset_publications_with_multiple_sessions:
      extends: pub
      constraint: "triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_DATASET') and exists (select * from curs c1, curs c2 where c1.pub = me.pub_id and c2.pub = me.pub_id and c1.curs_id <> c2.curs_id)"
    pheno_dataset_publications_without_sessions:
      extends: pub
      constraint: "pub_id not in (select pub from curs) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_DATASET')"
    pheno_dataset_publications_with_new_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'SESSION_CREATED')) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_DATASET')"
    pheno_dataset_publications_with_active_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and (p.value = 'SESSION_ACCEPTED' or p.value = 'CURATION_IN_PROGRESS' or p.value = 'CURATION_PAUSED'))) and triage_status_id in (select cvterm_id from cvterm where name = 'PHENO_DATASET')"
    low_priority_publications:
      extends: pub
      constraint: "triage_status_id in (select cvterm_id from cvterm where name = 'LOW_PRIORITY')"
    low_priority_publications_with_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs) and triage_status_id in (select cvterm_id from cvterm where name = 'LOW_PRIORITY')"
    low_priority_publications_with_approved_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'APPROVED')) and triage_status_id in (select cvterm_id from cvterm where name = 'LOW_PRIORITY')"
    low_priority_publications_with_multiple_sessions:
      extends: pub
      constraint: "triage_status_id in (select cvterm_id from cvterm where name = 'LOW_PRIORITY') and exists (select * from curs c1, curs c2 where c1.pub = me.pub_id and c2.pub = me.pub_id and c1.curs_id <> c2.curs_id)"
    low_priority_publications_without_sessions:
      extends: pub
      constraint: "pub_id not in (select pub from curs) and triage_status_id in (select cvterm_id from cvterm where name = 'LOW_PRIORITY')"
    low_priority_publications_with_new_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'SESSION_CREATED')) and triage_status_id in (select cvterm_id from cvterm where name = 'LOW_PRIORITY')"
    low_priority_publications_with_active_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and (p.value = 'SESSION_ACCEPTED' or p.value = 'CURATION_IN_PROGRESS' or p.value = 'CURATION_PAUSED'))) and triage_status_id in (select cvterm_id from cvterm where name = 'LOW_PRIORITY')"
    training_publications:
      extends: pub
      constraint: "triage_status_id in (select cvterm_id from cvterm where name = 'TRAINING')"
    training_publications_with_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs) and triage_status_id in (select cvterm_id from cvterm where name = 'TRAINING')"
    training_publications_with_approved_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'APPROVED')) and triage_status_id in (select cvterm_id from cvterm where name = 'TRAINING')"
    training_publications_with_multiple_sessions:
      extends: pub
      constraint: "triage_status_id in (select cvterm_id from cvterm where name = 'TRAINING') and exists (select * from curs c1, curs c2 where c1.pub = me.pub_id and c2.pub = me.pub_id and c1.curs_id <> c2.curs_id)"
    training_publications_without_sessions:
      extends: pub
      constraint: "pub_id not in (select pub from curs) and triage_status_id in (select cvterm_id from cvterm where name = 'TRAINING')"
    training_publications_with_new_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'SESSION_CREATED')) and triage_status_id in (select cvterm_id from cvterm where name = 'TRAINING')"
    training_publications_with_active_sessions:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and (p.value = 'SESSION_ACCEPTED' or p.value = 'CURATION_IN_PROGRESS' or p.value = 'CURATION_PAUSED'))) and triage_status_id in (select cvterm_id from cvterm where name = 'TRAINING')"

    publications_with_session_needing_approval:
      extends: pub
      '+field_info_list':
        - name: last_status_change
          source:
            sql: "select value from curs, cursprop p, cvterm t where me.pub_id = curs.pub and curs.curs_id = p.curs and t.cvterm_id = p.type and t.name = 'annotation_status_datestamp'"
          editable: 0
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and (p.value = 'NEEDS_APPROVAL' or p.value = 'APPROVAL_IN_PROGRESS')))"
    publications_with_approved_session:
      extends: pub
      constraint: "pub_id in (select pub from curs where curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'APPROVED'))"
    sessions_needing_approval:
      extends: curs
      constraint: "me.curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and (p.value = 'NEEDS_APPROVAL' or p.value = 'APPROVAL_IN_PROGRESS'))"
    sessions_without_a_curator:
      extends: curs
      constraint: "me.curs_id not in (select curs from curs_curator)"
    exported_sessions:
      extends: curs
      constraint: "me.curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'EXPORTED')"
    sessions_with_term_requests:
      extends: curs
      constraint: "me.curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and (p.value = 'CURATION_IN_PROGRESS' or p.value = 'CURATION_PAUSED' or p.value = 'NEEDS_APPROVAL' or p.value = 'APPROVAL_IN_PROGRESS')) and me.curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'session_term_suggestions_count' and value > 0)"
    reactivated_sessions:
      extends: curs
      constraint: "me.curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and (p.value = 'CURATION_IN_PROGRESS')) and me.curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'session_reactivated_timestamp')"
    approved_sessions:
      extends: curs
      constraint: "me.curs_id in (select curs from cursprop p, cvterm t where t.cvterm_id = p.type and t.name = 'annotation_status' and p.value = 'APPROVED')"
    all_sessions:
      extends: curs

  chado:
    chadoprop:
      class_display_name: chado properties
      editable: 0
      display_field: value
      field_info_list:
        - name: type
          source: type_id
          referenced_class: Cvterm
        - name: value
          editable: 0
    cv:
      class_display_name: controlled vocabulary
      editable: 1
      display_field: name
      field_info_list:
        - name: name
          editable: 1
        - name: definition
          editable: 1
        - name: "terms in this CV"
          source:
            sql: 'select count(*) from cvterm where cvterm.cv_id = me.cv_id'
        - name: "terms used"
          source:
            sql: 'select count(*) from cvterm c where c.cv_id = me.cv_id and c.cvterm_id in (select cvterm_id from feature_cvterm)'
        - name: "annotation count"
          source:
            sql: 'select count(*) from feature_cvterm fc, cvterm c where fc.cvterm_id = c.cvterm_id and c.cv_id = me.cv_id'
    cvterm:
      class_display_name: controlled vocabulary term
      editable: 1
      display_field: name
      field_info_list:
        - name: name
          editable: 1
        - name: definition
          editable: 1
        - name: cv
          source: cv_id
          editable: 1
        - name: dbxref_id
          editable: 1
        - name: "features annotated with this term"
          source:
            sql: 'select count(*) from feature_cvterm fc where fc.cvterm_id = me.cvterm_id'
    organism:
      editable: 1
      display_field: full_name
      order_by:
        - genus
        - species
      field_info_list:
        - name: genus
          editable: 1
        - name: species
          editable: 1
    pub:
      object_title_format: 'Details for publication ID: @@$object->uniquename()@@'
      class_display_name: publication
      display_field: title
      editable: 1
      field_info_list:
        - name: title
          editable: 1
        - name: uniquename
          editable: 1
        - name: type
          source: type_id
          values_constraint: 'where me.cv_id = (SELECT cv_id FROM cv where cv.name = "genedb_literature")'
          referenced_class: Cvterm
          editable: 1
    feature:
      editable: 1
      display_field: uniquename
      search_fields:
        - uniquename
        - name
      field_info_list:
        - name: uniquename
          editable: 1
        - name: name
          editable: 1
        - name: type
          source: type_id
          values_constraint: 'where me.cv_id = (SELECT cv_id FROM cv where cv.name = "sequence")'
          referenced_class: Cvterm
          editable: 1
        - name: featureprops
          is_collection: 1
          editable: 1
    featureprop:
      editable: 1
      display_field: value
      field_info_list:
        - name: type
          source: type_id
          referenced_class: Cvterm
        - name: value
          editable: 1
    db:
      editable: 1
      display_field: name
      field_info_list:
        - name: name
          editable: 1
        - name: description
          editable: 1
        - name: url
          editable: 1
        - name: "accessions stored"
          source:
            sql: 'select count(*) from dbxref where dbxref.db_id = me.db_id'
    dbxref:
      editable: 1
      display_field: accession
      field_info_list:
        - name: db_id
          editable: 1
        - name: accession
          editable: 1
        - name: description
          editable: 1
    genes:
      extends: feature
      constraint: "type_id = (select cvterm_id from cvterm, cv where cvterm.name = 'gene' and cvterm.cv_id = cv.cv_id and cv.name = 'sequence')"
    pombe_genes:
      class_display_name: S. pombe genes
      extends: feature
      constraint: "type_id = (select cvterm_id from cvterm, cv where cvterm.name = 'gene' and cvterm.cv_id = cv.cv_id and cv.name = 'sequence') and organism_id = (select organism_id from organism where genus = 'Schizosaccharomyces' and species = 'pombe')"
    protein_and_domain_terms:
      class_display_name: PomBase family or domain terms
      extends: cvterm
      constraint: "cv_id = (select cv_id from cv where cv.name = 'PomBase family or domain')"
    types_and_counts:
      class_display_name: SO DNA feature types and counts
      constraint: "(select count(*) from feature where type_id = me.cvterm_id) > 0"
      display_field: name
      extends: cvterm
      field_info_list:
        - name: name
          editable: 1
        - name: cv
          source: cv_id
          editable: 1
        - name: "features of this type"
          as: count
          source:
            sql: 'select count(*) from feature where type_id = me.cvterm_id'

reports:
  track:
    - report: all_publications
      children:
        - report: high_priority_publications
          children:
            - report: high_priority_publications_with_sessions
              children:
               - report: high_priority_publications_with_new_sessions
               - report: high_priority_publications_with_active_sessions
               - report: high_priority_publications_with_approved_sessions
               - report: high_priority_publications_with_multiple_sessions
            - report: high_priority_publications_without_sessions
        - report: disease_publications
          children:
            - report: disease_publications_with_sessions
              children:
               - report: disease_publications_with_new_sessions
               - report: disease_publications_with_active_sessions
               - report: disease_publications_with_approved_sessions
               - report: disease_publications_with_multiple_sessions
            - report: disease_publications_without_sessions
        - report: pheno_publications
          children:
            - report: pheno_publications_with_sessions
              children:
               - report: pheno_publications_with_new_sessions
               - report: pheno_publications_with_active_sessions
               - report: pheno_publications_with_approved_sessions
               - report: pheno_publications_with_multiple_sessions
            - report: pheno_publications_without_sessions
#        - report: pheno_anat_publications
#          children:
#            - report: pheno_anat_publications_with_sessions
#              children:
#               - report: pheno_anat_publications_with_new_sessions
#               - report: pheno_anat_publications_with_active_sessions
#               - report: pheno_anat_publications_with_approved_sessions
#               - report: pheno_anat_publications_with_multiple_sessions
#            - report: pheno_anat_publications_without_sessions
#        - report: pheno_chem_publications
#          children:
#            - report: pheno_chem_publications_with_sessions
#              children:
#               - report: pheno_chem_publications_with_new_sessions
#               - report: pheno_chem_publications_with_active_sessions
#               - report: pheno_chem_publications_with_approved_sessions
#               - report: pheno_chem_publications_with_multiple_sessions
#            - report: pheno_chem_publications_without_sessions
        - report: pheno_dataset_publications
          children:
            - report: pheno_dataset_publications_with_sessions
              children:
               - report: pheno_dataset_publications_with_new_sessions
               - report: pheno_dataset_publications_with_active_sessions
               - report: pheno_dataset_publications_with_approved_sessions
               - report: pheno_dataset_publications_with_multiple_sessions
            - report: pheno_dataset_publications_without_sessions
#        - report: low_priority_publications
#          children:
#            - report: low_priority_publications_with_sessions
#              children:
#               - report: low_priority_publications_with_new_sessions
#               - report: low_priority_publications_with_active_sessions
#               - report: low_priority_publications_with_approved_sessions
#               - report: low_priority_publications_with_multiple_sessions
#            - report: low_priority_publications_without_sessions
#        - report: training_publications
#          children:
#            - report: training_publications_with_sessions
#              children:
#               - report: training_publications_with_new_sessions
#               - report: training_publications_with_active_sessions
#               - report: training_publications_with_approved_sessions
#               - report: training_publications_with_multiple_sessions
#            - report: training_publications_without_sessions
    - report: all_sessions
      children:
        - report: approved_sessions
        - report: exported_sessions
        - report: sessions_needing_approval
        - report: reactivated_sessions
        - report: sessions_without_a_curator


curs_config:
  # Possible reasons for a paper to have no phenotype annotation in the case where genes/alleles are mentioned
  no_annotation_reasons:
    - No phenotypic data
    - Only pheno_chem data
    - Other