From b1ab56f0c67a8f333a0ac3be82e9d402376ecfee Mon Sep 17 00:00:00 2001 From: etowahadams Date: Mon, 17 Jun 2024 18:01:06 -0400 Subject: [PATCH] Add mouse events documentation (#102) * feat: add mouseEvents * feat: updated gosling schema * Update docs/user-interaction.mdx Co-authored-by: SEHI L'YI * Update docs/user-interaction.mdx Co-authored-by: SEHI L'YI * Update docs/user-interaction.mdx Co-authored-by: SEHI L'YI * Update docs/user-interaction.mdx Co-authored-by: SEHI L'YI --------- Co-authored-by: SEHI L'YI --- assets/gosling.schema.json | 10777 ++++++++++++------ docs/user-interaction.mdx | 36 + static/img/doc_images/mouse_interaction.png | Bin 0 -> 27598 bytes 3 files changed, 7464 insertions(+), 3349 deletions(-) create mode 100644 static/img/doc_images/mouse_interaction.png diff --git a/assets/gosling.schema.json b/assets/gosling.schema.json index 07f180f..791ad3c 100644 --- a/assets/gosling.schema.json +++ b/assets/gosling.schema.json @@ -13,17 +13,43 @@ "type": "string" }, "Assembly": { - "enum": [ - "hg38", - "hg19", - "hg18", - "hg17", - "hg16", - "mm10", - "mm9", - "unknown" - ], - "type": "string" + "anyOf": [ + { + "const": "hg38", + "type": "string" + }, + { + "const": "hg19", + "type": "string" + }, + { + "const": "hg18", + "type": "string" + }, + { + "const": "hg17", + "type": "string" + }, + { + "const": "hg16", + "type": "string" + }, + { + "const": "mm10", + "type": "string" + }, + { + "const": "mm9", + "type": "string" + }, + { + "const": "unknown", + "type": "string" + }, + { + "$ref": "#/definitions/ChromSizes" + } + ] }, "AxisPosition": { "enum": [ @@ -35,18 +61,28 @@ ], "type": "string" }, - "BAMData": { + "BamData": { "additionalProperties": false, "description": "Binary Alignment Map (BAM) is the comprehensive raw data of genome sequencing; it consists of the lossless, compressed binary representation of the Sequence Alignment Map-files.", "properties": { + "extractJunction": { + "description": "Determine whether to extract exon-to-exon junctions. __Default__: `false`", + "type": "boolean" + }, "indexUrl": { "description": "URL link to the index file of the BAM file", "type": "string" }, + "junctionMinCoverage": { + "description": "Determine the threshold of coverage when extracting exon-to-exon junctions. __Default__: `1`", + "type": "number" + }, "loadMates": { + "description": "Load mates that are located in the same chromosome. __Default__: `false`", "type": "boolean" }, "maxInsertSize": { + "description": "Determines the threshold of insert sizes for determining the structural variants. __Default__: `5000`", "type": "number" }, "type": { @@ -65,7 +101,42 @@ ], "type": "object" }, - "BEDDBData": { + "BedData": { + "additionalProperties": false, + "description": "BED file format", + "properties": { + "customFields": { + "description": "An array of strings, where each string is the name of a non-standard field in the BED file. If there are `n` custom fields, we assume that the last `n` columns of the BED file correspond to the custom fields.", + "items": { + "type": "string" + }, + "type": "array" + }, + "indexUrl": { + "description": "Specify the URL address of the data file index.", + "type": "string" + }, + "sampleLength": { + "description": "Specify the number of rows loaded from the URL.\n\n__Default:__ `1000`", + "type": "number" + }, + "type": { + "const": "bed", + "type": "string" + }, + "url": { + "description": "Specify the URL address of the data file.", + "type": "string" + } + }, + "required": [ + "type", + "url", + "indexUrl" + ], + "type": "object" + }, + "BeddbData": { "additionalProperties": false, "description": "Regular BED or similar files can be pre-aggregated for the scalable data exploration. Find our more about this format at [HiGlass Docs](https://docs.higlass.io/data_preparation.html#bed-files).", "properties": { @@ -173,23 +244,27 @@ ], "type": "object" }, - "BIGWIGData": { + "BigWigData": { "additionalProperties": false, "properties": { + "aggregation": { + "$ref": "#/definitions/BinAggregate", + "description": "Determine aggregation function to apply within bins. __Default__: `\"mean\"`" + }, "binSize": { "description": "Binning the genomic interval in tiles (unit size: 256).", "type": "number" }, "column": { - "description": "Assign a field name of the middle position of genomic intervals.", + "description": "Assign a field name of the middle position of genomic intervals. __Default__: `\"position\"`", "type": "string" }, "end": { - "description": "Assign a field name of the end position of genomic intervals.", + "description": "Assign a field name of the end position of genomic intervals. __Default__: `\"end\"`", "type": "string" }, "start": { - "description": "Assign a field name of the start position of genomic intervals.", + "description": "Assign a field name of the start position of genomic intervals. __Default__: `\"start\"`", "type": "string" }, "type": { @@ -201,100 +276,22 @@ "type": "string" }, "value": { - "description": "Assign a field name of quantitative values.", + "description": "Assign a field name of quantitative values. __Default__: `\"value\"`", "type": "string" } }, "required": [ "type", - "url", - "column", - "value" + "url" ], "type": "object" }, - "CSVData": { - "additionalProperties": false, - "description": "Any small enough tabular data files, such as tsv, csv, BED, BEDPE, and GFF, can be loaded using \"csv\" data specification.", - "properties": { - "chromosomeField": { - "description": "Specify the name of chromosome data fields.", - "type": "string" - }, - "chromosomePrefix": { - "description": "experimental", - "type": "string" - }, - "genomicFields": { - "description": "Specify the name of genomic data fields.", - "items": { - "type": "string" - }, - "type": "array" - }, - "genomicFieldsToConvert": { - "description": "experimental", - "items": { - "additionalProperties": false, - "properties": { - "chromosomeField": { - "type": "string" - }, - "genomicFields": { - "items": { - "type": "string" - }, - "type": "array" - } - }, - "required": [ - "chromosomeField", - "genomicFields" - ], - "type": "object" - }, - "type": "array" - }, - "headerNames": { - "description": "Specify the names of data fields if a CSV file is headerless.", - "items": { - "type": "string" - }, - "type": "array" - }, - "longToWideId": { - "description": "experimental", - "type": "string" - }, - "quantitativeFields": { - "description": "Specify the name of quantitative data fields.", - "items": { - "type": "string" - }, - "type": "array" - }, - "sampleLength": { - "description": "Specify the number of rows loaded from the URL.\n\n__Default:__ `1000`", - "type": "number" - }, - "separator": { - "description": "Specify file separator, __Default:__ ','", - "type": "string" - }, - "type": { - "const": "csv", - "type": "string" - }, - "url": { - "description": "Specify the URL address of the data file.", - "type": "string" - } - }, - "required": [ - "type", - "url" + "BinAggregate": { + "enum": [ + "mean", + "sum" ], - "type": "object" + "type": "string" }, "Channel": { "anyOf": [ @@ -353,60 +350,22 @@ ], "type": "object" }, - "Chromosome": { - "enum": [ - "1", - "2", - "3", - "4", - "5", - "6", - "7", - "8", - "9", - "10", - "11", - "12", - "13", - "14", - "15", - "16", - "17", - "18", - "19", - "20", - "21", - "22", - "X", - "Y", - "M", - "chr1", - "chr2", - "chr3", - "chr4", - "chr5", - "chr6", - "chr7", - "chr8", - "chr9", - "chr10", - "chr11", - "chr12", - "chr13", - "chr14", - "chr15", - "chr16", - "chr17", - "chr18", - "chr19", - "chr20", - "chr21", - "chr22", - "chrX", - "chrY", - "chrM" - ], - "type": "string" + "ChromSizes": { + "description": "Custom chromosome sizes, e.g., [[\"foo\", 1000], [\"bar\", 300], [\"baz\", 240]]", + "items": { + "items": [ + { + "type": "string" + }, + { + "type": "number" + } + ], + "maxItems": 2, + "minItems": 2, + "type": "array" + }, + "type": "array" }, "Color": { "additionalProperties": false, @@ -427,6 +386,26 @@ "$ref": "#/definitions/Range", "description": "Determine the colors that should be bound to data value. Default properties are determined considering the field type." }, + "scale": { + "enum": [ + "linear", + "log" + ], + "type": "string" + }, + "scaleOffset": { + "description": "Whether to use offset of the domain proportionally. This is bound to brushes on the color legend. __Default__: `[0, 1]`", + "items": { + "type": "number" + }, + "maxItems": 2, + "minItems": 2, + "type": "array" + }, + "title": { + "description": "Title of the legend. __Default__: `undefined`", + "type": "string" + }, "type": { "description": "Specify the data type", "enum": [ @@ -438,78 +417,130 @@ }, "type": "object" }, - "CombineMatesTransform": { + "CoverageTransform": { "additionalProperties": false, - "description": "By looking up ids, combine mates (a pair of reads) into a single row, performing long-to-wide operation. Result data have `{field}` and `{field}_2` names.", + "description": "Aggregate rows and calculate coverage", "properties": { - "idField": { + "endField": { "type": "string" }, - "isLongField": { + "groupField": { + "description": "The name of a nominal field to group rows by in prior to piling-up", "type": "string" }, - "maintainDuplicates": { - "type": "boolean" + "newField": { + "type": "string" }, - "maxInsertSize": { - "type": "number" + "startField": { + "type": "string" }, "type": { - "const": "combineMates", + "const": "coverage", "type": "string" } }, "required": [ "type", - "idField" + "startField", + "endField" ], "type": "object" }, - "CoverageTransform": { + "CsvData": { "additionalProperties": false, - "description": "Aggregate rows and calculate coverage", + "description": "Any small enough tabular data files, such as tsv, csv, BED, BEDPE, and GFF, can be loaded using \"csv\" data specification.", "properties": { - "endField": { + "chromosomeField": { + "description": "Specify the name of chromosome data fields.", "type": "string" }, - "groupField": { - "description": "The name of a nominal field to group rows by in prior to piling-up", + "chromosomePrefix": { + "description": "Specify the chromosome prefix if chromosomes are denoted using a prefix besides \"chr\" or a number", "type": "string" }, - "newField": { + "genomicFields": { + "description": "Specify the name of genomic data fields.", + "items": { + "type": "string" + }, + "type": "array" + }, + "genomicFieldsToConvert": { + "description": "experimental", + "items": { + "additionalProperties": false, + "properties": { + "chromosomeField": { + "type": "string" + }, + "genomicFields": { + "items": { + "type": "string" + }, + "type": "array" + } + }, + "required": [ + "chromosomeField", + "genomicFields" + ], + "type": "object" + }, + "type": "array" + }, + "headerNames": { + "description": "Specify the names of data fields if a CSV file does not contain a header.", + "items": { + "type": "string" + }, + "type": "array" + }, + "longToWideId": { + "description": "experimental", "type": "string" }, - "startField": { + "sampleLength": { + "description": "Specify the number of rows loaded from the URL.\n\n__Default:__ `1000`", + "type": "number" + }, + "separator": { + "description": "Specify file separator, __Default:__ ','", "type": "string" }, "type": { - "const": "coverage", + "const": "csv", + "type": "string" + }, + "url": { + "description": "Specify the URL address of the data file.", "type": "string" } }, "required": [ "type", - "startField", - "endField" + "url" ], "type": "object" }, "DataDeep": { "anyOf": [ { - "$ref": "#/definitions/JSONData" + "$ref": "#/definitions/JsonData" + }, + { + "$ref": "#/definitions/CsvData" }, { - "$ref": "#/definitions/CSVData" + "$ref": "#/definitions/BedData" }, { - "$ref": "#/definitions/BIGWIGData" + "$ref": "#/definitions/BigWigData" }, { "$ref": "#/definitions/MultivecData" }, { - "$ref": "#/definitions/BEDDBData" + "$ref": "#/definitions/BeddbData" }, { "$ref": "#/definitions/VectorData" @@ -518,7 +549,13 @@ "$ref": "#/definitions/MatrixData" }, { - "$ref": "#/definitions/BAMData" + "$ref": "#/definitions/BamData" + }, + { + "$ref": "#/definitions/VcfData" + }, + { + "$ref": "#/definitions/GffData" } ] }, @@ -526,7 +563,14 @@ "additionalProperties": false, "description": "Partial specification of `BasicSingleTrack` to use default visual encoding predefined by data type.", "properties": { - "_invalidTrack": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "_invalidTrack": { "description": "internal", "type": "boolean" }, @@ -554,6 +598,7 @@ "type": "number" }, "id": { + "description": "Assigned to `uid` in a HiGlass view config, used for API and caching.", "type": "string" }, "innerRadius": { @@ -585,7 +630,7 @@ "type": "object" }, "spacing": { - "description": "- If `{\"layout\": \"linear\"}`, specify the space between tracks in pixels;\n\n- If `{\"layout\": \"circular\"}`, specify the space between tracks in percentage ranging from 0 to 100.", + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", "type": "number" }, "startAngle": { @@ -598,7 +643,7 @@ }, "style": { "$ref": "#/definitions/Style", - "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overriden by the style of children elements (e.g., view, track)." + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." }, "subtitle": { "type": "string" @@ -626,12 +671,27 @@ { "$ref": "#/definitions/DomainChr" } - ] + ], + "description": "Specify the visible region of genomic x-axis" }, "xOffset": { "description": "Specify the x offset of views in the unit of pixels", "type": "number" }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, "yOffset": { "description": "Specify the y offset of views in the unit of pixels", "type": "number" @@ -641,9 +701,7 @@ } }, "required": [ - "data", - "height", - "width" + "data" ], "type": "object" }, @@ -671,13 +729,13 @@ "$ref": "#/definitions/GenomicLengthTransform" }, { - "$ref": "#/definitions/CoverageTransform" + "$ref": "#/definitions/SvTypeTransform" }, { - "$ref": "#/definitions/CombineMatesTransform" + "$ref": "#/definitions/CoverageTransform" }, { - "$ref": "#/definitions/JSONParseTransform" + "$ref": "#/definitions/JsonParseTransform" } ] }, @@ -730,7 +788,7 @@ }, "method": { "$ref": "#/definitions/DisplacementType", - "description": "A string that specifies the type of diseplancement." + "description": "A string that specifies the type of displacement." }, "newField": { "type": "string" @@ -774,7 +832,7 @@ "additionalProperties": false, "properties": { "chromosome": { - "$ref": "#/definitions/Chromosome" + "type": "string" } }, "required": [ @@ -786,18 +844,13 @@ "additionalProperties": false, "properties": { "chromosome": { - "$ref": "#/definitions/Chromosome", - "description": "If specified, only showing a certain interval in a chromosome." + "description": "If specified, only showing a certain interval in a chromosome.", + "type": "string" }, "interval": { - "items": [ - { - "type": "number" - }, - { - "type": "number" - } - ], + "items": { + "type": "number" + }, "maxItems": 2, "minItems": 2, "type": "array" @@ -809,57 +862,162 @@ ], "type": "object" }, - "DomainGene": { + "DomainInterval": { "additionalProperties": false, "properties": { - "gene": { - "anyOf": [ - { - "type": "string" - }, - { - "items": [ - { - "type": "string" - }, - { - "type": "string" - } - ], - "maxItems": 2, - "minItems": 2, - "type": "array" - } - ] + "interval": { + "description": "Show a certain interval within entire chromosome", + "items": { + "type": "number" + }, + "maxItems": 2, + "minItems": 2, + "type": "array" } }, "required": [ - "gene" + "interval" ], "type": "object" }, - "DomainInterval": { + "DummyTrack": { "additionalProperties": false, + "description": "A placeholder track. In contrast to other tracks, this track does not display any data. Instead it provides empty space for third party tools to display their data on top of.", "properties": { - "interval": { - "items": [ - { - "type": "number" - }, - { - "type": "number" - } - ], + "_invalidTrack": { + "description": "internal", + "type": "boolean" + }, + "assembly": { + "const": "unknown", + "description": "No assemblies can be associated with a dummy track", + "type": "string" + }, + "height": { + "description": "Specify the track height in pixels.", + "type": "number" + }, + "id": { + "description": "Assigned to `uid` in a HiGlass view config, used for API and caching.", + "type": "string" + }, + "layout": { + "const": "linear", + "description": "Only linear layout are supported at this time", + "type": "string" + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "overlayOnPreviousTrack": { + "type": "boolean" + }, + "static": { + "const": true, + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "style": { + "$ref": "#/definitions/DummyTrackStyle", + "description": "Defines how the track is styled" + }, + "title": { + "description": "Text that gets shown on the DummyTrack", + "type": "string" + }, + "type": { + "const": "dummy-track", + "description": "Used to specify the dummy track", + "type": "string" + }, + "width": { + "description": "Specify the track width in pixels.", + "type": "number" + }, + "zoomLimits": { + "description": "Unused property for DummyTrack", + "items": { + "type": "null" + }, "maxItems": 2, "minItems": 2, "type": "array" } }, "required": [ - "interval" + "type" ], "type": "object" }, + "DummyTrackStyle": { + "additionalProperties": false, + "properties": { + "background": { + "description": "Background color of the track", + "type": "string" + }, + "outline": { + "description": "Color of the outline of the track", + "type": "string" + }, + "textFontSize": { + "description": "Specify the font size of the title", + "type": "number" + }, + "textFontWeight": { + "description": "Specify the font weight of the title.", + "enum": [ + "bold", + "normal" + ], + "type": "string" + }, + "textStroke": { + "description": "Specify the stroke color of title.", + "type": "string" + }, + "textStrokeWidth": { + "description": "Specify the stroke width of the title.", + "type": "number" + } + }, + "type": "object" + }, + "EventStyle": { + "additionalProperties": false, + "description": "The styles defined here will be applied to the target marks of mouse events, such as a point mark after the user clicks on it.", + "properties": { + "arrange": { + "description": "Show event effects behind or in front of marks.", + "enum": [ + "behind", + "front" + ], + "type": "string" + }, + "color": { + "description": "color of the marks when mouse events are triggered", + "type": "string" + }, + "opacity": { + "description": "opacity of the marks when mouse events are triggered", + "type": "number" + }, + "stroke": { + "description": "stroke color of the marks when mouse events are triggered", + "type": "string" + }, + "strokeOpacity": { + "type": "number" + }, + "strokeWidth": { + "description": "stroke width of the marks when mouse events are triggered", + "type": "number" + } + }, + "type": "object" + }, "ExonSplitTransform": { "additionalProperties": false, "properties": { @@ -946,81 +1104,6 @@ } ] }, - "FlatTracks": { - "additionalProperties": false, - "properties": { - "assembly": { - "$ref": "#/definitions/Assembly", - "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." - }, - "centerRadius": { - "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", - "type": "number" - }, - "layout": { - "$ref": "#/definitions/Layout", - "description": "Specify the layout type of all tracks." - }, - "linkingId": { - "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", - "type": "string" - }, - "orientation": { - "$ref": "#/definitions/Orientation", - "description": "Specify the orientation." - }, - "spacing": { - "description": "- If `{\"layout\": \"linear\"}`, specify the space between tracks in pixels;\n\n- If `{\"layout\": \"circular\"}`, specify the space between tracks in percentage ranging from 0 to 100.", - "type": "number" - }, - "static": { - "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", - "type": "boolean" - }, - "style": { - "$ref": "#/definitions/Style", - "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overriden by the style of children elements (e.g., view, track)." - }, - "tracks": { - "items": { - "$ref": "#/definitions/Track" - }, - "type": "array" - }, - "xAxis": { - "$ref": "#/definitions/AxisPosition", - "description": "not supported" - }, - "xDomain": { - "anyOf": [ - { - "$ref": "#/definitions/DomainInterval" - }, - { - "$ref": "#/definitions/DomainChrInterval" - }, - { - "$ref": "#/definitions/DomainChr" - } - ] - }, - "xOffset": { - "description": "Specify the x offset of views in the unit of pixels", - "type": "number" - }, - "yOffset": { - "description": "Specify the y offset of views in the unit of pixels", - "type": "number" - }, - "zoomLimits": { - "$ref": "#/definitions/ZoomLimits" - } - }, - "required": [ - "tracks" - ], - "type": "object" - }, "GenomicDomain": { "anyOf": [ { @@ -1031,9 +1114,6 @@ }, { "$ref": "#/definitions/DomainChr" - }, - { - "$ref": "#/definitions/DomainGene" } ] }, @@ -1063,2004 +1143,2434 @@ ], "type": "object" }, - "GoslingSpec": { - "anyOf": [ - { - "$ref": "#/definitions/RootSpecWithSingleView" - }, - { - "$ref": "#/definitions/RootSpecWithMultipleViews" - } - ] - }, - "IncludeFilter": { + "GffData": { "additionalProperties": false, + "description": "Generic Feature Format Version 3 (GFF3) format data. It parses files that follow the [GFF3 specification](https://github.com/The-Sequence-Ontology/Specifications/blob/master/gff3.md).", "properties": { - "field": { - "description": "A filter is applied based on the values of the specified data field", - "type": "string" - }, - "include": { - "description": "Check whether the value includes a substring.", - "type": "string" - }, - "not": { - "description": "when `{\"not\": true}`, apply a NOT logical operation to the filter.\n\n__Default:__ `false`", - "type": "boolean" - }, - "type": { - "const": "filter", - "type": "string" - } - }, - "required": [ - "field", - "include", - "type" - ], - "type": "object" - }, - "JSONData": { - "additionalProperties": false, - "description": "The JSON data format allows users to include data directly in the Gosling's JSON specification.", - "properties": { - "chromosomeField": { - "description": "Specify the name of chromosome data fields.", - "type": "string" - }, - "genomicFields": { - "description": "Specify the name of genomic data fields.", - "items": { - "type": "string" - }, - "type": "array" - }, - "genomicFieldsToConvert": { - "description": "experimental", + "attributesToFields": { + "description": "Specifies which attributes to include as a fields. GFF files have an \"attributes\" column which contains a list of attributes which are each tag-value pairs (`tag=value`). This option allows for specific attributes to be accessible as a field. For example, if you have an attribute called \"gene_name\" and you want label features on your track using those values, you can use this option so that you can use `\"field\": \"gene_name\"` in the schema.\n\nIf there is a single `value` corresponding to the `tag`, Gosling will parse that value as a string. If there are multiple `value`s corresponding to a `tag`, Gosling will parse it as a comma-separated list string. If a feature does not have a particular attribute, then the attribute value will be set to the `defaultValue`.", "items": { "additionalProperties": false, "properties": { - "chromosomeField": { + "attribute": { "type": "string" }, - "genomicFields": { - "items": { - "type": "string" - }, - "type": "array" + "defaultValue": { + "type": "string" } }, "required": [ - "chromosomeField", - "genomicFields" + "attribute", + "defaultValue" ], "type": "object" }, "type": "array" }, - "quantitativeFields": { - "description": "Specify the name of quantitative data fields.", - "items": { - "type": "string" - }, - "type": "array" + "indexUrl": { + "description": "URL link to the tabix index file", + "type": "string" }, "sampleLength": { - "description": "Specify the number of rows loaded from the URL.\n\n__Default:__ `1000`", + "description": "The maximum number of samples to be shown on the track. Samples are uniformly randomly selected so that this threshold is not exceeded. __Default:__ `1000`", "type": "number" }, "type": { - "const": "json", - "description": "Define data type.", - "type": "string" - }, - "values": { - "description": "Values in the form of JSON.", - "items": { - "$ref": "#/definitions/Datum" - }, - "type": "array" - } - }, - "required": [ - "type", - "values" - ], - "type": "object" - }, - "JSONParseTransform": { - "additionalProperties": false, - "description": "Parse JSON Object Array and append vertically", - "properties": { - "baseGenomicField": { - "description": "Base genomic position when parsing relative position.", - "type": "string" - }, - "field": { - "description": "The field that contains the JSON object array.", - "type": "string" - }, - "genomicField": { - "description": "Relative genomic position to parse.", - "type": "string" - }, - "genomicLengthField": { - "description": "Length of genomic interval.", + "const": "gff", "type": "string" }, - "type": { - "const": "subjson", + "url": { + "description": "URL link to the GFF file", "type": "string" } }, "required": [ "type", - "field", - "baseGenomicField", - "genomicField", - "genomicLengthField" + "url", + "indexUrl" ], "type": "object" }, - "Layout": { - "enum": [ - "linear", - "circular" - ], - "type": "string" - }, - "LogBase": { + "GoslingSpec": { "anyOf": [ { - "type": "number" - }, - { - "const": "e", - "type": "string" - } - ] - }, - "LogTransform": { - "additionalProperties": false, - "properties": { - "base": { - "$ref": "#/definitions/LogBase", - "description": "If not specified, 10 is used." - }, - "field": { - "type": "string" - }, - "newField": { - "description": "If specified, store transformed values in a new field.", - "type": "string" - }, - "type": { - "const": "log", - "type": "string" - } - }, - "required": [ - "type", - "field" - ], - "type": "object" - }, - "LogicalOperation": { - "enum": [ - "less-than", - "lt", - "LT", - "greater-than", - "gt", - "GT", - "less-than-or-equal-to", - "ltet", - "LTET", - "greater-than-or-equal-to", - "gtet", - "GTET" - ], - "type": "string" - }, - "Mark": { - "enum": [ - "point", - "line", - "area", - "bar", - "rect", - "text", - "withinLink", - "betweenLink", - "rule", - "triangleLeft", - "triangleRight", - "triangleBottom", - "brush", - "header" - ], - "type": "string" - }, - "MatrixData": { - "additionalProperties": false, - "properties": { - "type": { - "const": "matrix", - "type": "string" - }, - "url": { - "type": "string" - } - }, - "required": [ - "type", - "url" - ], - "type": "object" - }, - "MultipleViews": { - "additionalProperties": false, - "properties": { - "arrangement": { - "description": "Specify how multiple views are arranged.", - "enum": [ - "parallel", - "serial", - "horizontal", - "vertical" - ], - "type": "string" - }, - "assembly": { - "$ref": "#/definitions/Assembly", - "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." - }, - "centerRadius": { - "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", - "type": "number" - }, - "layout": { - "$ref": "#/definitions/Layout", - "description": "Specify the layout type of all tracks." - }, - "linkingId": { - "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", - "type": "string" - }, - "orientation": { - "$ref": "#/definitions/Orientation", - "description": "Specify the orientation." - }, - "spacing": { - "description": "- If `{\"layout\": \"linear\"}`, specify the space between tracks in pixels;\n\n- If `{\"layout\": \"circular\"}`, specify the space between tracks in percentage ranging from 0 to 100.", - "type": "number" - }, - "static": { - "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", - "type": "boolean" - }, - "style": { - "$ref": "#/definitions/Style", - "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overriden by the style of children elements (e.g., view, track)." - }, - "views": { - "description": "An array of view specifications", - "items": { - "anyOf": [ - { - "$ref": "#/definitions/SingleView" - }, - { - "$ref": "#/definitions/MultipleViews" - } - ] - }, - "type": "array" - }, - "xAxis": { - "$ref": "#/definitions/AxisPosition", - "description": "not supported" - }, - "xDomain": { - "anyOf": [ - { - "$ref": "#/definitions/DomainInterval" + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" }, - { - "$ref": "#/definitions/DomainChrInterval" + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" }, - { - "$ref": "#/definitions/DomainChr" - } - ] - }, - "xOffset": { - "description": "Specify the x offset of views in the unit of pixels", - "type": "number" - }, - "yOffset": { - "description": "Specify the y offset of views in the unit of pixels", - "type": "number" - }, - "zoomLimits": { - "$ref": "#/definitions/ZoomLimits" - } - }, - "required": [ - "views" - ], - "type": "object" - }, - "MultivecData": { - "additionalProperties": false, - "description": "Two-dimensional quantitative values, one axis for genomic coordinate and the other for different samples, can be converted into HiGlass' `\"multivec\"` data. For example, multiple BigWig files can be converted into a single multivec file. You can also convert sequence data (FASTA) into this format where rows will be different nucleotide bases (e.g., A, T, G, C) and quantitative values represent the frequency. Find out more about this format at [HiGlass Docs](https://docs.higlass.io/data_preparation.html#multivec-files).", - "properties": { - "binSize": { - "description": "Binning the genomic interval in tiles (unit size: 256).", - "type": "number" - }, - "categories": { - "description": "assign names of individual samples.", - "items": { - "type": "string" - }, - "type": "array" - }, - "column": { - "description": "Assign a field name of the middle position of genomic intervals.", - "type": "string" - }, - "end": { - "description": "Assign a field name of the end position of genomic intervals.", - "type": "string" - }, - "row": { - "description": "Assign a field name of samples.", - "type": "string" - }, - "start": { - "description": "Assign a field name of the start position of genomic intervals.", - "type": "string" - }, - "type": { - "const": "multivec", - "type": "string" - }, - "url": { - "description": "Specify the URL address of the data file.", - "type": "string" - }, - "value": { - "description": "Assign a field name of quantitative values.", - "type": "string" - } - }, - "required": [ - "type", - "url", - "column", - "row", - "value" - ], - "type": "object" - }, - "OneOfFilter": { - "additionalProperties": false, - "properties": { - "field": { - "description": "A filter is applied based on the values of the specified data field", - "type": "string" - }, - "not": { - "description": "when `{\"not\": true}`, apply a NOT logical operation to the filter.\n\n__Default:__ `false`", - "type": "boolean" - }, - "oneOf": { - "anyOf": [ - { + "_invalidTrack": { + "description": "internal", + "type": "boolean" + }, + "_renderingId": { + "description": "internal", + "type": "string" + }, + "alignment": { + "const": "overlay", + "type": "string" + }, + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + }, + "baselineY": { + "type": "number" + }, + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" + }, + "color": { + "anyOf": [ + { + "$ref": "#/definitions/Color" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "data": { + "$ref": "#/definitions/DataDeep" + }, + "dataTransform": { "items": { - "type": "string" + "$ref": "#/definitions/DataTransform" }, "type": "array" }, - { + "description": { + "type": "string" + }, + "displacement": { + "$ref": "#/definitions/Displacement" + }, + "endAngle": { + "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "experimental": { + "additionalProperties": false, + "properties": { + "performanceMode": { + "default": false, + "description": "Render visual marks with less smooth curves to increase rendering performance. Only supported for `elliptical` `linkStyle` `withinLink` currently.", + "type": "boolean" + }, + "stretchGraphics": { + "description": "Performance rendering option. By default, certain marks ('bar', 'line', 'rect', 'area') are stretched when zooming in/out to improve rendering performance. No marks will be stretched in circular layouts.\n\nWhen this option is set to true, all marks will be stretched when zooming in/out. When this option is set to false, all marks will be rerendered when zooming in/out.", + "type": "boolean" + }, + "stretchGraphicsThreshold": { + "default": 1.5, + "description": "Threshold for stretching graphics. If the graphics are scaled larger than the threshold, then the graphic will be rerendered. If the graphics are scaled smaller than 1/threshold (e.g., 1/2), then the graphic will be rerendered. This is to prevent the graphics from being stretched too much.", + "type": "number" + } + }, + "type": "object" + }, + "flipY": { + "type": "boolean" + }, + "height": { + "description": "Specify the track height in pixels.", + "type": "number" + }, + "id": { + "description": "The ID of a view that is maintained for the use of JS API functions, e.g., positions of a view", + "type": "string" + }, + "innerRadius": { + "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "layout": { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "mark": { + "$ref": "#/definitions/Mark" + }, + "mouseEvents": { + "anyOf": [ + { + "type": "boolean" + }, + { + "$ref": "#/definitions/MouseEventsDeep" + } + ] + }, + "opacity": { + "anyOf": [ + { + "$ref": "#/definitions/Opacity" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "outerRadius": { + "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", + "type": "number" + }, + "overlayOnPreviousTrack": { + "type": "boolean" + }, + "overrideTemplate": { + "type": "boolean" + }, + "prerelease": { + "additionalProperties": false, + "description": "internal", + "type": "object" + }, + "responsiveSize": { + "$ref": "#/definitions/ResponsiveSize", + "description": "Determine whether to make the size of `GoslingComponent` bound to its parent element. __Default__: `false`" + }, + "responsiveSpec": { "items": { - "type": "number" + "additionalProperties": false, + "properties": { + "selectivity": { + "items": { + "$ref": "#/definitions/SelectivityCondition" + }, + "type": "array" + }, + "spec": { + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "_invalidTrack": { + "description": "internal", + "type": "boolean" + }, + "_renderingId": { + "description": "internal", + "type": "string" + }, + "alignment": { + "enum": [ + "overlay", + "stack" + ], + "type": "string" + }, + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + }, + "baselineY": { + "type": "number" + }, + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" + }, + "color": { + "anyOf": [ + { + "$ref": "#/definitions/Color" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "data": { + "$ref": "#/definitions/DataDeep" + }, + "dataTransform": { + "items": { + "$ref": "#/definitions/DataTransform" + }, + "type": "array" + }, + "displacement": { + "$ref": "#/definitions/Displacement" + }, + "endAngle": { + "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "experimental": { + "additionalProperties": false, + "properties": { + "performanceMode": { + "default": false, + "description": "Render visual marks with less smooth curves to increase rendering performance. Only supported for `elliptical` `linkStyle` `withinLink` currently.", + "type": "boolean" + }, + "stretchGraphics": { + "description": "Performance rendering option. By default, certain marks ('bar', 'line', 'rect', 'area') are stretched when zooming in/out to improve rendering performance. No marks will be stretched in circular layouts.\n\nWhen this option is set to true, all marks will be stretched when zooming in/out. When this option is set to false, all marks will be rerendered when zooming in/out.", + "type": "boolean" + }, + "stretchGraphicsThreshold": { + "default": 1.5, + "description": "Threshold for stretching graphics. If the graphics are scaled larger than the threshold, then the graphic will be rerendered. If the graphics are scaled smaller than 1/threshold (e.g., 1/2), then the graphic will be rerendered. This is to prevent the graphics from being stretched too much.", + "type": "number" + } + }, + "type": "object" + }, + "flipY": { + "type": "boolean" + }, + "height": { + "description": "Specify the track height in pixels.", + "type": "number" + }, + "id": { + "description": "The ID of a view that is maintained for the use of JS API functions, e.g., positions of a view", + "type": "string" + }, + "innerRadius": { + "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "layout": { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "mark": { + "$ref": "#/definitions/Mark" + }, + "mouseEvents": { + "anyOf": [ + { + "type": "boolean" + }, + { + "$ref": "#/definitions/MouseEventsDeep" + } + ] + }, + "opacity": { + "anyOf": [ + { + "$ref": "#/definitions/Opacity" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "outerRadius": { + "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", + "type": "number" + }, + "overlayOnPreviousTrack": { + "type": "boolean" + }, + "overrideTemplate": { + "type": "boolean" + }, + "prerelease": { + "additionalProperties": false, + "description": "internal", + "type": "object" + }, + "row": { + "anyOf": [ + { + "$ref": "#/definitions/Row" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "size": { + "anyOf": [ + { + "$ref": "#/definitions/Size" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "startAngle": { + "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "stretch": { + "type": "boolean" + }, + "stroke": { + "anyOf": [ + { + "$ref": "#/definitions/Stroke" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "strokeWidth": { + "anyOf": [ + { + "$ref": "#/definitions/StrokeWidth" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "subtitle": { + "type": "string" + }, + "text": { + "anyOf": [ + { + "$ref": "#/definitions/Text" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "title": { + "description": "If defined, will show the textual label on the left-top corner of a track.", + "type": "string" + }, + "tooltip": { + "items": { + "$ref": "#/definitions/Tooltip" + }, + "type": "array" + }, + "tracks": { + "anyOf": [ + { + "items": { + "$ref": "#/definitions/PartialTrack" + }, + "type": "array" + }, + { + "items": { + "anyOf": [ + { + "$ref": "#/definitions/PartialTrack" + }, + { + "$ref": "#/definitions/OverlaidTracks" + } + ] + }, + "type": "array" + } + ] + }, + "visibility": { + "items": { + "$ref": "#/definitions/VisibilityCondition" + }, + "type": "array" + }, + "width": { + "description": "Specify the track width in pixels.", + "type": "number" + }, + "x": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1e": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "xe": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1e": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "ye": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" + } + }, + "type": "object" + } + }, + "required": [ + "spec", + "selectivity" + ], + "type": "object" }, "type": "array" - } - ], - "description": "Check whether the value is an element in the provided list." - }, - "type": { - "const": "filter", - "type": "string" - } - }, - "required": [ - "field", - "oneOf", - "type" - ], - "type": "object" - }, - "Opacity": { - "additionalProperties": false, - "properties": { - "domain": { - "$ref": "#/definitions/ValueExtent", - "description": "Values of the data" - }, - "field": { - "description": "Name of the data field", - "type": "string" - }, - "range": { - "$ref": "#/definitions/ValueExtent", - "description": "Ranges of visual channel values" - }, - "type": { - "description": "Specify the data type", - "enum": [ - "quantitative", - "nominal" - ], - "type": "string" - } - }, - "type": "object" - }, - "Orientation": { - "enum": [ - "horizontal", - "vertical" - ], - "type": "string" - }, - "OverlaidTrack": { - "additionalProperties": false, - "description": "Superposing multiple tracks.", - "properties": { - "_invalidTrack": { - "description": "internal", - "type": "boolean" - }, - "_renderingId": { - "description": "internal", - "type": "string" - }, - "assembly": { - "$ref": "#/definitions/Assembly", - "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." - }, - "centerRadius": { - "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", - "type": "number" - }, - "color": { - "anyOf": [ - { - "$ref": "#/definitions/Color" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "data": { - "$ref": "#/definitions/DataDeep" - }, - "dataTransform": { - "items": { - "$ref": "#/definitions/DataTransform" - }, - "type": "array" - }, - "displacement": { - "$ref": "#/definitions/Displacement" - }, - "endAngle": { - "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "flipY": { - "type": "boolean" - }, - "height": { - "description": "Specify the track height in pixels.", - "type": "number" - }, - "id": { - "type": "string" - }, - "innerRadius": { - "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "layout": { - "$ref": "#/definitions/Layout", - "description": "Specify the layout type of all tracks." - }, - "linkingId": { - "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", - "type": "string" - }, - "mark": { - "$ref": "#/definitions/Mark" - }, - "opacity": { - "anyOf": [ - { - "$ref": "#/definitions/Opacity" + "row": { + "anyOf": [ + { + "$ref": "#/definitions/Row" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "orientation": { - "$ref": "#/definitions/Orientation", - "description": "Specify the orientation." - }, - "outerRadius": { - "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", - "type": "number" - }, - "overlay": { - "items": { - "additionalProperties": false, - "properties": { - "_invalidTrack": { - "description": "internal", - "type": "boolean" - }, - "_renderingId": { - "description": "internal", - "type": "string" - }, - "assembly": { - "$ref": "#/definitions/Assembly", - "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." - }, - "centerRadius": { - "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", - "type": "number" - }, - "color": { - "anyOf": [ - { - "$ref": "#/definitions/Color" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "data": { - "$ref": "#/definitions/DataDeep" - }, - "dataTransform": { - "items": { - "$ref": "#/definitions/DataTransform" + "size": { + "anyOf": [ + { + "$ref": "#/definitions/Size" }, - "type": "array" - }, - "displacement": { - "$ref": "#/definitions/Displacement" - }, - "endAngle": { - "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "flipY": { - "type": "boolean" - }, - "id": { - "type": "string" - }, - "innerRadius": { - "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "linkingId": { - "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", - "type": "string" - }, - "mark": { - "$ref": "#/definitions/Mark" - }, - "opacity": { - "anyOf": [ - { - "$ref": "#/definitions/Opacity" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "orientation": { - "$ref": "#/definitions/Orientation", - "description": "Specify the orientation." + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "startAngle": { + "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "stretch": { + "type": "boolean" + }, + "stroke": { + "anyOf": [ + { + "$ref": "#/definitions/Stroke" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "strokeWidth": { + "anyOf": [ + { + "$ref": "#/definitions/StrokeWidth" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "subtitle": { + "type": "string" + }, + "text": { + "anyOf": [ + { + "$ref": "#/definitions/Text" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "title": { + "description": "If defined, will show the textual label on the left-top corner of a track.", + "type": "string" + }, + "tooltip": { + "items": { + "$ref": "#/definitions/Tooltip" }, - "outerRadius": { - "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", - "type": "number" + "type": "array" + }, + "tracks": { + "items": { + "$ref": "#/definitions/PartialTrack" }, - "overlayOnPreviousTrack": { - "type": "boolean" + "type": "array" + }, + "visibility": { + "items": { + "$ref": "#/definitions/VisibilityCondition" }, - "overrideTemplate": { - "type": "boolean" - }, - "prerelease": { - "additionalProperties": false, - "description": "internal", - "type": "object" - }, - "row": { - "anyOf": [ - { - "$ref": "#/definitions/Row" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "size": { - "anyOf": [ - { - "$ref": "#/definitions/Size" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "spacing": { - "description": "- If `{\"layout\": \"linear\"}`, specify the space between tracks in pixels;\n\n- If `{\"layout\": \"circular\"}`, specify the space between tracks in percentage ranging from 0 to 100.", - "type": "number" - }, - "startAngle": { - "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "static": { - "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", - "type": "boolean" - }, - "stretch": { - "type": "boolean" - }, - "stroke": { - "anyOf": [ - { - "$ref": "#/definitions/Stroke" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "strokeWidth": { - "anyOf": [ - { - "$ref": "#/definitions/StrokeWidth" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "style": { - "$ref": "#/definitions/Style", - "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overriden by the style of children elements (e.g., view, track)." - }, - "text": { - "anyOf": [ - { - "$ref": "#/definitions/Text" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "tooltip": { - "items": { - "$ref": "#/definitions/Tooltip" + "type": "array" + }, + "width": { + "description": "Specify the track width in pixels.", + "type": "number" + }, + "x": { + "anyOf": [ + { + "$ref": "#/definitions/X" }, - "type": "array" - }, - "visibility": { - "items": { - "$ref": "#/definitions/VisibilityCondition" + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1": { + "anyOf": [ + { + "$ref": "#/definitions/X" }, - "type": "array" - }, - "x": { - "anyOf": [ - { - "$ref": "#/definitions/X" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "x1": { - "anyOf": [ - { - "$ref": "#/definitions/X" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "x1e": { - "anyOf": [ - { - "$ref": "#/definitions/X" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "xAxis": { - "$ref": "#/definitions/AxisPosition", - "description": "not supported" - }, - "xDomain": { - "anyOf": [ - { - "$ref": "#/definitions/DomainInterval" - }, - { - "$ref": "#/definitions/DomainChrInterval" - }, - { - "$ref": "#/definitions/DomainChr" - } - ] - }, - "xOffset": { - "description": "Specify the x offset of views in the unit of pixels", - "type": "number" - }, - "xe": { - "anyOf": [ - { - "$ref": "#/definitions/X" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "y": { - "anyOf": [ - { - "$ref": "#/definitions/Y" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "y1": { - "anyOf": [ - { - "$ref": "#/definitions/Y" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "y1e": { - "anyOf": [ - { - "$ref": "#/definitions/Y" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "yOffset": { - "description": "Specify the y offset of views in the unit of pixels", - "type": "number" - }, - "ye": { - "anyOf": [ - { - "$ref": "#/definitions/Y" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "zoomLimits": { - "$ref": "#/definitions/ZoomLimits" - } + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - "type": "object" - }, - "type": "array" - }, - "overlayOnPreviousTrack": { - "type": "boolean" - }, - "overrideTemplate": { - "type": "boolean" - }, - "prerelease": { - "additionalProperties": false, - "description": "internal", - "type": "object" - }, - "row": { - "anyOf": [ - { - "$ref": "#/definitions/Row" + "x1e": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "size": { - "anyOf": [ - { - "$ref": "#/definitions/Size" + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "spacing": { - "description": "- If `{\"layout\": \"linear\"}`, specify the space between tracks in pixels;\n\n- If `{\"layout\": \"circular\"}`, specify the space between tracks in percentage ranging from 0 to 100.", - "type": "number" - }, - "startAngle": { - "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "static": { - "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", - "type": "boolean" - }, - "stretch": { - "type": "boolean" - }, - "stroke": { - "anyOf": [ - { - "$ref": "#/definitions/Stroke" + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "strokeWidth": { - "anyOf": [ - { - "$ref": "#/definitions/StrokeWidth" + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "style": { - "$ref": "#/definitions/Style", - "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overriden by the style of children elements (e.g., view, track)." - }, - "subtitle": { - "type": "string" - }, - "text": { - "anyOf": [ - { - "$ref": "#/definitions/Text" + "xe": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "title": { - "description": "If defined, will show the textual label on the left-top corner of a track.", - "type": "string" - }, - "tooltip": { - "items": { - "$ref": "#/definitions/Tooltip" - }, - "type": "array" - }, - "visibility": { - "items": { - "$ref": "#/definitions/VisibilityCondition" - }, - "type": "array" - }, - "width": { - "description": "Specify the track width in pixels.", - "type": "number" - }, - "x": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "y": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "x1": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "y1": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "x1e": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "y1e": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "xAxis": { - "$ref": "#/definitions/AxisPosition", - "description": "not supported" - }, - "xDomain": { - "anyOf": [ - { - "$ref": "#/definitions/DomainInterval" + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" }, - { - "$ref": "#/definitions/DomainChrInterval" + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" }, - { - "$ref": "#/definitions/DomainChr" - } - ] - }, - "xOffset": { - "description": "Specify the x offset of views in the unit of pixels", - "type": "number" - }, - "xe": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "ye": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" } - ] + }, + "required": [ + "alignment", + "tracks" + ], + "type": "object" }, - "y": { - "anyOf": [ - { - "$ref": "#/definitions/Y" + { + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "y1": { - "anyOf": [ - { - "$ref": "#/definitions/Y" + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "y1e": { - "anyOf": [ - { - "$ref": "#/definitions/Y" + "_invalidTrack": { + "description": "internal", + "type": "boolean" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "yOffset": { - "description": "Specify the y offset of views in the unit of pixels", - "type": "number" - }, - "ye": { - "anyOf": [ - { - "$ref": "#/definitions/Y" + "_renderingId": { + "description": "internal", + "type": "string" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "zoomLimits": { - "$ref": "#/definitions/ZoomLimits" - } - }, - "required": [ - "height", - "overlay", - "width" - ], - "type": "object" - }, - "OverlaidTracks": { - "additionalProperties": false, - "properties": { - "_invalidTrack": { - "description": "internal", - "type": "boolean" - }, - "_renderingId": { - "description": "internal", - "type": "string" - }, - "alignment": { - "const": "overlay", - "type": "string" - }, - "assembly": { - "$ref": "#/definitions/Assembly", - "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." - }, - "centerRadius": { - "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", - "type": "number" - }, - "color": { - "anyOf": [ - { - "$ref": "#/definitions/Color" + "alignment": { + "const": "stack", + "type": "string" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "data": { - "$ref": "#/definitions/DataDeep" - }, - "dataTransform": { - "items": { - "$ref": "#/definitions/DataTransform" - }, - "type": "array" - }, - "displacement": { - "$ref": "#/definitions/Displacement" - }, - "endAngle": { - "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "flipY": { - "type": "boolean" - }, - "height": { - "description": "Specify the track height in pixels.", - "type": "number" - }, - "id": { - "type": "string" - }, - "innerRadius": { - "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "layout": { - "$ref": "#/definitions/Layout", - "description": "Specify the layout type of all tracks." - }, - "linkingId": { - "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", - "type": "string" - }, - "mark": { - "$ref": "#/definitions/Mark" - }, - "opacity": { - "anyOf": [ - { - "$ref": "#/definitions/Opacity" + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "orientation": { - "$ref": "#/definitions/Orientation", - "description": "Specify the orientation." - }, - "outerRadius": { - "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", - "type": "number" - }, - "overlayOnPreviousTrack": { - "type": "boolean" - }, - "overrideTemplate": { - "type": "boolean" - }, - "prerelease": { - "additionalProperties": false, - "description": "internal", - "type": "object" - }, - "row": { - "anyOf": [ - { - "$ref": "#/definitions/Row" + "baselineY": { + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "size": { - "anyOf": [ - { - "$ref": "#/definitions/Size" + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "spacing": { - "description": "- If `{\"layout\": \"linear\"}`, specify the space between tracks in pixels;\n\n- If `{\"layout\": \"circular\"}`, specify the space between tracks in percentage ranging from 0 to 100.", - "type": "number" - }, - "startAngle": { - "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "static": { - "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", - "type": "boolean" - }, - "stretch": { - "type": "boolean" - }, - "stroke": { - "anyOf": [ - { - "$ref": "#/definitions/Stroke" + "color": { + "anyOf": [ + { + "$ref": "#/definitions/Color" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "strokeWidth": { - "anyOf": [ - { - "$ref": "#/definitions/StrokeWidth" + "data": { + "$ref": "#/definitions/DataDeep" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "style": { - "$ref": "#/definitions/Style", - "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overriden by the style of children elements (e.g., view, track)." - }, - "subtitle": { - "type": "string" - }, - "text": { - "anyOf": [ - { - "$ref": "#/definitions/Text" + "dataTransform": { + "items": { + "$ref": "#/definitions/DataTransform" + }, + "type": "array" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "title": { - "description": "If defined, will show the textual label on the left-top corner of a track.", - "type": "string" - }, - "tooltip": { - "items": { - "$ref": "#/definitions/Tooltip" - }, - "type": "array" - }, - "tracks": { - "items": { - "$ref": "#/definitions/PartialTrack" - }, - "type": "array" - }, - "visibility": { - "items": { - "$ref": "#/definitions/VisibilityCondition" - }, - "type": "array" - }, - "width": { - "description": "Specify the track width in pixels.", - "type": "number" - }, - "x": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "description": { + "type": "string" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "x1": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "displacement": { + "$ref": "#/definitions/Displacement" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "x1e": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "endAngle": { + "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "xAxis": { - "$ref": "#/definitions/AxisPosition", - "description": "not supported" - }, - "xDomain": { - "anyOf": [ - { - "$ref": "#/definitions/DomainInterval" + "experimental": { + "additionalProperties": false, + "properties": { + "performanceMode": { + "default": false, + "description": "Render visual marks with less smooth curves to increase rendering performance. Only supported for `elliptical` `linkStyle` `withinLink` currently.", + "type": "boolean" + }, + "stretchGraphics": { + "description": "Performance rendering option. By default, certain marks ('bar', 'line', 'rect', 'area') are stretched when zooming in/out to improve rendering performance. No marks will be stretched in circular layouts.\n\nWhen this option is set to true, all marks will be stretched when zooming in/out. When this option is set to false, all marks will be rerendered when zooming in/out.", + "type": "boolean" + }, + "stretchGraphicsThreshold": { + "default": 1.5, + "description": "Threshold for stretching graphics. If the graphics are scaled larger than the threshold, then the graphic will be rerendered. If the graphics are scaled smaller than 1/threshold (e.g., 1/2), then the graphic will be rerendered. This is to prevent the graphics from being stretched too much.", + "type": "number" + } + }, + "type": "object" }, - { - "$ref": "#/definitions/DomainChrInterval" + "flipY": { + "type": "boolean" }, - { - "$ref": "#/definitions/DomainChr" - } - ] - }, - "xOffset": { - "description": "Specify the x offset of views in the unit of pixels", - "type": "number" - }, - "xe": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "height": { + "description": "Specify the track height in pixels.", + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "y": { - "anyOf": [ - { - "$ref": "#/definitions/Y" + "id": { + "description": "The ID of a view that is maintained for the use of JS API functions, e.g., positions of a view", + "type": "string" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "y1": { - "anyOf": [ - { - "$ref": "#/definitions/Y" + "innerRadius": { + "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "y1e": { - "anyOf": [ - { - "$ref": "#/definitions/Y" + "layout": { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "yOffset": { - "description": "Specify the y offset of views in the unit of pixels", - "type": "number" - }, - "ye": { - "anyOf": [ - { - "$ref": "#/definitions/Y" + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "zoomLimits": { - "$ref": "#/definitions/ZoomLimits" - } - }, - "required": [ - "alignment", - "tracks", - "width", - "height" - ], - "type": "object" - }, - "PREDEFINED_COLORS": { - "enum": [ - "viridis", - "grey", - "spectral", - "warm", - "cividis", - "bupu", - "rdbu" - ], - "type": "string" - }, - "PartialTrack": { - "additionalProperties": false, - "properties": { - "_invalidTrack": { - "description": "internal", - "type": "boolean" - }, - "_renderingId": { - "description": "internal", - "type": "string" - }, - "assembly": { - "$ref": "#/definitions/Assembly", - "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." - }, - "centerRadius": { - "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", - "type": "number" - }, - "color": { - "anyOf": [ - { - "$ref": "#/definitions/Color" + "mark": { + "$ref": "#/definitions/Mark" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "data": { - "$ref": "#/definitions/DataDeep" - }, - "dataTransform": { - "items": { - "$ref": "#/definitions/DataTransform" - }, - "type": "array" - }, - "displacement": { - "$ref": "#/definitions/Displacement" - }, - "encoding": { - "additionalProperties": { - "$ref": "#/definitions/Channel" - }, - "type": "object" - }, - "endAngle": { - "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "flipY": { - "type": "boolean" - }, - "height": { - "description": "Specify the track height in pixels.", - "type": "number" - }, - "id": { - "type": "string" - }, - "innerRadius": { - "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "layout": { - "$ref": "#/definitions/Layout", - "description": "Specify the layout type of all tracks." - }, - "linkingId": { - "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", - "type": "string" - }, - "mark": { - "$ref": "#/definitions/Mark" - }, - "opacity": { - "anyOf": [ - { - "$ref": "#/definitions/Opacity" + "mouseEvents": { + "anyOf": [ + { + "type": "boolean" + }, + { + "$ref": "#/definitions/MouseEventsDeep" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "orientation": { - "$ref": "#/definitions/Orientation", - "description": "Specify the orientation." - }, - "outerRadius": { - "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", - "type": "number" - }, - "overlay": { - "items": { - "additionalProperties": false, - "properties": { - "_invalidTrack": { - "description": "internal", - "type": "boolean" - }, - "_renderingId": { - "description": "internal", - "type": "string" - }, - "assembly": { - "$ref": "#/definitions/Assembly", - "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." - }, - "centerRadius": { - "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", - "type": "number" - }, - "color": { - "anyOf": [ - { - "$ref": "#/definitions/Color" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "data": { - "$ref": "#/definitions/DataDeep" - }, - "dataTransform": { - "items": { - "$ref": "#/definitions/DataTransform" + "opacity": { + "anyOf": [ + { + "$ref": "#/definitions/Opacity" }, - "type": "array" - }, - "displacement": { - "$ref": "#/definitions/Displacement" - }, - "endAngle": { - "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "flipY": { - "type": "boolean" - }, - "id": { - "type": "string" - }, - "innerRadius": { - "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "linkingId": { - "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", - "type": "string" - }, - "mark": { - "$ref": "#/definitions/Mark" - }, - "opacity": { - "anyOf": [ - { - "$ref": "#/definitions/Opacity" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "orientation": { - "$ref": "#/definitions/Orientation", - "description": "Specify the orientation." - }, - "outerRadius": { - "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", - "type": "number" - }, - "overlayOnPreviousTrack": { - "type": "boolean" - }, - "overrideTemplate": { - "type": "boolean" - }, - "prerelease": { + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "outerRadius": { + "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", + "type": "number" + }, + "overlayOnPreviousTrack": { + "type": "boolean" + }, + "overrideTemplate": { + "type": "boolean" + }, + "prerelease": { + "additionalProperties": false, + "description": "internal", + "type": "object" + }, + "responsiveSize": { + "$ref": "#/definitions/ResponsiveSize", + "description": "Determine whether to make the size of `GoslingComponent` bound to its parent element. __Default__: `false`" + }, + "responsiveSpec": { + "items": { "additionalProperties": false, - "description": "internal", - "type": "object" - }, - "row": { - "anyOf": [ - { - "$ref": "#/definitions/Row" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "size": { - "anyOf": [ - { - "$ref": "#/definitions/Size" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "spacing": { - "description": "- If `{\"layout\": \"linear\"}`, specify the space between tracks in pixels;\n\n- If `{\"layout\": \"circular\"}`, specify the space between tracks in percentage ranging from 0 to 100.", - "type": "number" - }, - "startAngle": { - "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "static": { - "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", - "type": "boolean" - }, - "stretch": { - "type": "boolean" - }, - "stroke": { - "anyOf": [ - { - "$ref": "#/definitions/Stroke" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "strokeWidth": { - "anyOf": [ - { - "$ref": "#/definitions/StrokeWidth" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "style": { - "$ref": "#/definitions/Style", - "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overriden by the style of children elements (e.g., view, track)." - }, - "text": { - "anyOf": [ - { - "$ref": "#/definitions/Text" + "properties": { + "selectivity": { + "items": { + "$ref": "#/definitions/SelectivityCondition" + }, + "type": "array" }, - { - "$ref": "#/definitions/ChannelValue" + "spec": { + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "_invalidTrack": { + "description": "internal", + "type": "boolean" + }, + "_renderingId": { + "description": "internal", + "type": "string" + }, + "alignment": { + "enum": [ + "overlay", + "stack" + ], + "type": "string" + }, + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + }, + "baselineY": { + "type": "number" + }, + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" + }, + "color": { + "anyOf": [ + { + "$ref": "#/definitions/Color" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "data": { + "$ref": "#/definitions/DataDeep" + }, + "dataTransform": { + "items": { + "$ref": "#/definitions/DataTransform" + }, + "type": "array" + }, + "displacement": { + "$ref": "#/definitions/Displacement" + }, + "endAngle": { + "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "experimental": { + "additionalProperties": false, + "properties": { + "performanceMode": { + "default": false, + "description": "Render visual marks with less smooth curves to increase rendering performance. Only supported for `elliptical` `linkStyle` `withinLink` currently.", + "type": "boolean" + }, + "stretchGraphics": { + "description": "Performance rendering option. By default, certain marks ('bar', 'line', 'rect', 'area') are stretched when zooming in/out to improve rendering performance. No marks will be stretched in circular layouts.\n\nWhen this option is set to true, all marks will be stretched when zooming in/out. When this option is set to false, all marks will be rerendered when zooming in/out.", + "type": "boolean" + }, + "stretchGraphicsThreshold": { + "default": 1.5, + "description": "Threshold for stretching graphics. If the graphics are scaled larger than the threshold, then the graphic will be rerendered. If the graphics are scaled smaller than 1/threshold (e.g., 1/2), then the graphic will be rerendered. This is to prevent the graphics from being stretched too much.", + "type": "number" + } + }, + "type": "object" + }, + "flipY": { + "type": "boolean" + }, + "height": { + "description": "Specify the track height in pixels.", + "type": "number" + }, + "id": { + "description": "The ID of a view that is maintained for the use of JS API functions, e.g., positions of a view", + "type": "string" + }, + "innerRadius": { + "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "layout": { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "mark": { + "$ref": "#/definitions/Mark" + }, + "mouseEvents": { + "anyOf": [ + { + "type": "boolean" + }, + { + "$ref": "#/definitions/MouseEventsDeep" + } + ] + }, + "opacity": { + "anyOf": [ + { + "$ref": "#/definitions/Opacity" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "outerRadius": { + "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", + "type": "number" + }, + "overlayOnPreviousTrack": { + "type": "boolean" + }, + "overrideTemplate": { + "type": "boolean" + }, + "prerelease": { + "additionalProperties": false, + "description": "internal", + "type": "object" + }, + "row": { + "anyOf": [ + { + "$ref": "#/definitions/Row" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "size": { + "anyOf": [ + { + "$ref": "#/definitions/Size" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "startAngle": { + "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "stretch": { + "type": "boolean" + }, + "stroke": { + "anyOf": [ + { + "$ref": "#/definitions/Stroke" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "strokeWidth": { + "anyOf": [ + { + "$ref": "#/definitions/StrokeWidth" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "subtitle": { + "type": "string" + }, + "text": { + "anyOf": [ + { + "$ref": "#/definitions/Text" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "title": { + "description": "If defined, will show the textual label on the left-top corner of a track.", + "type": "string" + }, + "tooltip": { + "items": { + "$ref": "#/definitions/Tooltip" + }, + "type": "array" + }, + "tracks": { + "anyOf": [ + { + "items": { + "$ref": "#/definitions/PartialTrack" + }, + "type": "array" + }, + { + "items": { + "anyOf": [ + { + "$ref": "#/definitions/PartialTrack" + }, + { + "$ref": "#/definitions/OverlaidTracks" + } + ] + }, + "type": "array" + } + ] + }, + "visibility": { + "items": { + "$ref": "#/definitions/VisibilityCondition" + }, + "type": "array" + }, + "width": { + "description": "Specify the track width in pixels.", + "type": "number" + }, + "x": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1e": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "xe": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1e": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "ye": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" + } + }, + "type": "object" } - ] - }, - "tooltip": { - "items": { - "$ref": "#/definitions/Tooltip" }, - "type": "array" + "required": [ + "spec", + "selectivity" + ], + "type": "object" }, - "visibility": { - "items": { - "$ref": "#/definitions/VisibilityCondition" + "type": "array" + }, + "row": { + "anyOf": [ + { + "$ref": "#/definitions/Row" }, - "type": "array" + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "size": { + "anyOf": [ + { + "$ref": "#/definitions/Size" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "startAngle": { + "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "stretch": { + "type": "boolean" + }, + "stroke": { + "anyOf": [ + { + "$ref": "#/definitions/Stroke" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "strokeWidth": { + "anyOf": [ + { + "$ref": "#/definitions/StrokeWidth" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "subtitle": { + "type": "string" + }, + "text": { + "anyOf": [ + { + "$ref": "#/definitions/Text" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "title": { + "description": "If defined, will show the textual label on the left-top corner of a track.", + "type": "string" + }, + "tooltip": { + "items": { + "$ref": "#/definitions/Tooltip" }, - "x": { + "type": "array" + }, + "tracks": { + "items": { "anyOf": [ { - "$ref": "#/definitions/X" + "$ref": "#/definitions/PartialTrack" }, { - "$ref": "#/definitions/ChannelValue" + "$ref": "#/definitions/OverlaidTracks" } ] }, - "x1": { - "anyOf": [ - { - "$ref": "#/definitions/X" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] + "type": "array" + }, + "visibility": { + "items": { + "$ref": "#/definitions/VisibilityCondition" }, - "x1e": { - "anyOf": [ - { - "$ref": "#/definitions/X" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "xAxis": { - "$ref": "#/definitions/AxisPosition", - "description": "not supported" - }, - "xDomain": { - "anyOf": [ - { - "$ref": "#/definitions/DomainInterval" - }, - { - "$ref": "#/definitions/DomainChrInterval" - }, - { - "$ref": "#/definitions/DomainChr" - } - ] - }, - "xOffset": { - "description": "Specify the x offset of views in the unit of pixels", - "type": "number" - }, - "xe": { - "anyOf": [ - { - "$ref": "#/definitions/X" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "y": { - "anyOf": [ - { - "$ref": "#/definitions/Y" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "y1": { - "anyOf": [ - { - "$ref": "#/definitions/Y" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "y1e": { - "anyOf": [ - { - "$ref": "#/definitions/Y" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "yOffset": { - "description": "Specify the y offset of views in the unit of pixels", - "type": "number" - }, - "ye": { - "anyOf": [ - { - "$ref": "#/definitions/Y" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "zoomLimits": { - "$ref": "#/definitions/ZoomLimits" - } + "type": "array" }, - "type": "object" - }, - "type": "array" - }, - "overlayOnPreviousTrack": { - "type": "boolean" - }, - "overrideTemplate": { - "type": "boolean" - }, - "prerelease": { - "additionalProperties": false, - "description": "internal", - "type": "object" - }, - "row": { - "anyOf": [ - { - "$ref": "#/definitions/Row" + "width": { + "description": "Specify the track width in pixels.", + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "size": { - "anyOf": [ - { - "$ref": "#/definitions/Size" + "x": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "spacing": { - "description": "- If `{\"layout\": \"linear\"}`, specify the space between tracks in pixels;\n\n- If `{\"layout\": \"circular\"}`, specify the space between tracks in percentage ranging from 0 to 100.", - "type": "number" - }, - "startAngle": { - "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "static": { - "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", - "type": "boolean" - }, - "stretch": { - "type": "boolean" - }, - "stroke": { - "anyOf": [ - { - "$ref": "#/definitions/Stroke" + "x1": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "strokeWidth": { - "anyOf": [ - { - "$ref": "#/definitions/StrokeWidth" + "x1e": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "style": { - "$ref": "#/definitions/Style", - "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overriden by the style of children elements (e.g., view, track)." - }, - "subtitle": { - "type": "string" - }, - "template": { - "type": "string" - }, - "text": { - "anyOf": [ - { - "$ref": "#/definitions/Text" + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "title": { - "description": "If defined, will show the textual label on the left-top corner of a track.", - "type": "string" - }, - "tooltip": { - "items": { - "$ref": "#/definitions/Tooltip" - }, - "type": "array" - }, - "visibility": { - "items": { - "$ref": "#/definitions/VisibilityCondition" - }, - "type": "array" - }, - "width": { - "description": "Specify the track width in pixels.", - "type": "number" - }, - "x": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "x1": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "x1e": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "xe": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "xAxis": { - "$ref": "#/definitions/AxisPosition", - "description": "not supported" - }, - "xDomain": { - "anyOf": [ - { - "$ref": "#/definitions/DomainInterval" + "y": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/DomainChrInterval" + "y1": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/DomainChr" - } - ] - }, - "xOffset": { - "description": "Specify the x offset of views in the unit of pixels", - "type": "number" - }, - "xe": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "y1e": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "y": { - "anyOf": [ - { - "$ref": "#/definitions/Y" + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "y1": { - "anyOf": [ - { - "$ref": "#/definitions/Y" + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "y1e": { - "anyOf": [ - { - "$ref": "#/definitions/Y" + "ye": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" } - ] - }, - "yOffset": { - "description": "Specify the y offset of views in the unit of pixels", - "type": "number" + }, + "required": [ + "tracks" + ], + "type": "object" }, - "ye": { - "anyOf": [ - { - "$ref": "#/definitions/Y" + { + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + }, + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" + }, + "description": { + "type": "string" + }, + "id": { + "description": "The ID of a view that is maintained for the use of JS API functions, e.g., positions of a view", + "type": "string" + }, + "layout": { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "responsiveSize": { + "$ref": "#/definitions/ResponsiveSize", + "description": "Determine whether to make the size of `GoslingComponent` bound to its parent element. __Default__: `false`" + }, + "responsiveSpec": { + "items": { + "additionalProperties": false, + "properties": { + "selectivity": { + "items": { + "$ref": "#/definitions/SelectivityCondition" + }, + "type": "array" + }, + "spec": { + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "_invalidTrack": { + "description": "internal", + "type": "boolean" + }, + "_renderingId": { + "description": "internal", + "type": "string" + }, + "alignment": { + "enum": [ + "overlay", + "stack" + ], + "type": "string" + }, + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + }, + "baselineY": { + "type": "number" + }, + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" + }, + "color": { + "anyOf": [ + { + "$ref": "#/definitions/Color" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "data": { + "$ref": "#/definitions/DataDeep" + }, + "dataTransform": { + "items": { + "$ref": "#/definitions/DataTransform" + }, + "type": "array" + }, + "displacement": { + "$ref": "#/definitions/Displacement" + }, + "endAngle": { + "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "experimental": { + "additionalProperties": false, + "properties": { + "performanceMode": { + "default": false, + "description": "Render visual marks with less smooth curves to increase rendering performance. Only supported for `elliptical` `linkStyle` `withinLink` currently.", + "type": "boolean" + }, + "stretchGraphics": { + "description": "Performance rendering option. By default, certain marks ('bar', 'line', 'rect', 'area') are stretched when zooming in/out to improve rendering performance. No marks will be stretched in circular layouts.\n\nWhen this option is set to true, all marks will be stretched when zooming in/out. When this option is set to false, all marks will be rerendered when zooming in/out.", + "type": "boolean" + }, + "stretchGraphicsThreshold": { + "default": 1.5, + "description": "Threshold for stretching graphics. If the graphics are scaled larger than the threshold, then the graphic will be rerendered. If the graphics are scaled smaller than 1/threshold (e.g., 1/2), then the graphic will be rerendered. This is to prevent the graphics from being stretched too much.", + "type": "number" + } + }, + "type": "object" + }, + "flipY": { + "type": "boolean" + }, + "height": { + "description": "Specify the track height in pixels.", + "type": "number" + }, + "id": { + "description": "The ID of a view that is maintained for the use of JS API functions, e.g., positions of a view", + "type": "string" + }, + "innerRadius": { + "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "layout": { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "mark": { + "$ref": "#/definitions/Mark" + }, + "mouseEvents": { + "anyOf": [ + { + "type": "boolean" + }, + { + "$ref": "#/definitions/MouseEventsDeep" + } + ] + }, + "opacity": { + "anyOf": [ + { + "$ref": "#/definitions/Opacity" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "outerRadius": { + "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", + "type": "number" + }, + "overlayOnPreviousTrack": { + "type": "boolean" + }, + "overrideTemplate": { + "type": "boolean" + }, + "prerelease": { + "additionalProperties": false, + "description": "internal", + "type": "object" + }, + "row": { + "anyOf": [ + { + "$ref": "#/definitions/Row" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "size": { + "anyOf": [ + { + "$ref": "#/definitions/Size" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "startAngle": { + "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "stretch": { + "type": "boolean" + }, + "stroke": { + "anyOf": [ + { + "$ref": "#/definitions/Stroke" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "strokeWidth": { + "anyOf": [ + { + "$ref": "#/definitions/StrokeWidth" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "subtitle": { + "type": "string" + }, + "text": { + "anyOf": [ + { + "$ref": "#/definitions/Text" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "title": { + "description": "If defined, will show the textual label on the left-top corner of a track.", + "type": "string" + }, + "tooltip": { + "items": { + "$ref": "#/definitions/Tooltip" + }, + "type": "array" + }, + "tracks": { + "anyOf": [ + { + "items": { + "$ref": "#/definitions/PartialTrack" + }, + "type": "array" + }, + { + "items": { + "anyOf": [ + { + "$ref": "#/definitions/PartialTrack" + }, + { + "$ref": "#/definitions/OverlaidTracks" + } + ] + }, + "type": "array" + } + ] + }, + "visibility": { + "items": { + "$ref": "#/definitions/VisibilityCondition" + }, + "type": "array" + }, + "width": { + "description": "Specify the track width in pixels.", + "type": "number" + }, + "x": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1e": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "xe": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1e": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "ye": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" + } + }, + "type": "object" + } + }, + "required": [ + "spec", + "selectivity" + ], + "type": "object" + }, + "type": "array" + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "subtitle": { + "type": "string" + }, + "title": { + "type": "string" + }, + "tracks": { + "items": { + "$ref": "#/definitions/Track" + }, + "type": "array" + }, + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" } - ] + }, + "required": [ + "tracks" + ], + "type": "object" }, - "zoomLimits": { - "$ref": "#/definitions/ZoomLimits" - } - }, - "type": "object" - }, - "Range": { - "anyOf": [ { - "$ref": "#/definitions/ValueExtent" - }, - { - "$ref": "#/definitions/PREDEFINED_COLORS" + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "arrangement": { + "description": "Specify how multiple views are arranged.", + "enum": [ + "parallel", + "serial", + "horizontal", + "vertical" + ], + "type": "string" + }, + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + }, + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" + }, + "description": { + "type": "string" + }, + "id": { + "description": "The ID of a view that is maintained for the use of JS API functions, e.g., positions of a view", + "type": "string" + }, + "layout": { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "responsiveSize": { + "$ref": "#/definitions/ResponsiveSize", + "description": "Determine whether to make the size of `GoslingComponent` bound to its parent element. __Default__: `false`" + }, + "responsiveSpec": { + "items": { + "additionalProperties": false, + "properties": { + "selectivity": { + "items": { + "$ref": "#/definitions/SelectivityCondition" + }, + "type": "array" + }, + "spec": { + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "arrangement": { + "description": "Specify how multiple views are arranged.", + "enum": [ + "parallel", + "serial", + "horizontal", + "vertical" + ], + "type": "string" + }, + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + }, + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" + }, + "id": { + "description": "The ID of a view that is maintained for the use of JS API functions, e.g., positions of a view", + "type": "string" + }, + "layout": { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "views": { + "description": "An array of view specifications", + "items": { + "anyOf": [ + { + "$ref": "#/definitions/SingleView" + }, + { + "$ref": "#/definitions/MultipleViews" + } + ] + }, + "type": "array" + }, + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" + } + }, + "type": "object" + } + }, + "required": [ + "spec", + "selectivity" + ], + "type": "object" + }, + "type": "array" + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "subtitle": { + "type": "string" + }, + "title": { + "type": "string" + }, + "views": { + "description": "An array of view specifications", + "items": { + "anyOf": [ + { + "$ref": "#/definitions/SingleView" + }, + { + "$ref": "#/definitions/MultipleViews" + } + ] + }, + "type": "array" + }, + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" + } + }, + "required": [ + "views" + ], + "type": "object" } ] }, - "RangeFilter": { + "IncludeFilter": { "additionalProperties": false, "properties": { "field": { "description": "A filter is applied based on the values of the specified data field", "type": "string" }, - "inRange": { - "description": "Check whether the value is in a number range.", - "items": { - "type": "number" - }, - "type": "array" + "include": { + "description": "Check whether the value includes a substring.", + "type": "string" }, "not": { "description": "when `{\"not\": true}`, apply a NOT logical operation to the filter.\n\n__Default:__ `false`", @@ -3073,439 +3583,2848 @@ }, "required": [ "field", - "inRange", + "include", "type" ], "type": "object" }, - "RootSpecWithMultipleViews": { + "JsonData": { "additionalProperties": false, + "description": "The JSON data format allows users to include data directly in the Gosling's JSON specification.", "properties": { - "arrangement": { - "description": "Specify how multiple views are arranged.", - "enum": [ - "parallel", - "serial", - "horizontal", - "vertical" - ], - "type": "string" - }, - "assembly": { - "$ref": "#/definitions/Assembly", - "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." - }, - "centerRadius": { - "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", - "type": "number" - }, - "description": { - "type": "string" - }, - "layout": { - "$ref": "#/definitions/Layout", - "description": "Specify the layout type of all tracks." - }, - "linkingId": { - "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", - "type": "string" - }, - "orientation": { - "$ref": "#/definitions/Orientation", - "description": "Specify the orientation." - }, - "spacing": { - "description": "- If `{\"layout\": \"linear\"}`, specify the space between tracks in pixels;\n\n- If `{\"layout\": \"circular\"}`, specify the space between tracks in percentage ranging from 0 to 100.", - "type": "number" - }, - "static": { - "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", - "type": "boolean" - }, - "style": { - "$ref": "#/definitions/Style", - "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overriden by the style of children elements (e.g., view, track)." - }, - "subtitle": { + "chromosomeField": { + "description": "Specify the name of chromosome data fields.", "type": "string" }, - "title": { - "type": "string" + "genomicFields": { + "description": "Specify the name of genomic data fields.", + "items": { + "type": "string" + }, + "type": "array" }, - "views": { - "description": "An array of view specifications", + "genomicFieldsToConvert": { + "description": "experimental", "items": { - "anyOf": [ - { - "$ref": "#/definitions/SingleView" + "additionalProperties": false, + "properties": { + "chromosomeField": { + "type": "string" }, - { - "$ref": "#/definitions/MultipleViews" + "genomicFields": { + "items": { + "type": "string" + }, + "type": "array" } - ] + }, + "required": [ + "chromosomeField", + "genomicFields" + ], + "type": "object" }, "type": "array" }, - "xAxis": { - "$ref": "#/definitions/AxisPosition", - "description": "not supported" - }, - "xDomain": { - "anyOf": [ - { - "$ref": "#/definitions/DomainInterval" - }, - { - "$ref": "#/definitions/DomainChrInterval" - }, - { - "$ref": "#/definitions/DomainChr" - } - ] - }, - "xOffset": { - "description": "Specify the x offset of views in the unit of pixels", + "sampleLength": { + "description": "Specify the number of rows loaded from the URL.\n\n__Default:__ `1000`", "type": "number" }, - "yOffset": { - "description": "Specify the y offset of views in the unit of pixels", - "type": "number" + "type": { + "const": "json", + "description": "Define data type.", + "type": "string" }, - "zoomLimits": { - "$ref": "#/definitions/ZoomLimits" + "values": { + "description": "Values in the form of JSON.", + "items": { + "$ref": "#/definitions/Datum" + }, + "type": "array" } }, "required": [ - "views" + "type", + "values" ], "type": "object" }, - "RootSpecWithSingleView": { - "anyOf": [ - { - "additionalProperties": false, - "properties": { - "_invalidTrack": { - "description": "internal", + "JsonParseTransform": { + "additionalProperties": false, + "description": "Parse JSON Object Array and append vertically", + "properties": { + "baseGenomicField": { + "description": "Base genomic position when parsing relative position.", + "type": "string" + }, + "field": { + "description": "The field that contains the JSON object array.", + "type": "string" + }, + "genomicField": { + "description": "Relative genomic position to parse.", + "type": "string" + }, + "genomicLengthField": { + "description": "Length of genomic interval.", + "type": "string" + }, + "type": { + "const": "subjson", + "type": "string" + } + }, + "required": [ + "type", + "field", + "baseGenomicField", + "genomicField", + "genomicLengthField" + ], + "type": "object" + }, + "Layout": { + "enum": [ + "linear", + "circular" + ], + "type": "string" + }, + "LogBase": { + "anyOf": [ + { + "type": "number" + }, + { + "const": "e", + "type": "string" + } + ] + }, + "LogTransform": { + "additionalProperties": false, + "properties": { + "base": { + "$ref": "#/definitions/LogBase", + "description": "If not specified, 10 is used." + }, + "field": { + "type": "string" + }, + "newField": { + "description": "If specified, store transformed values in a new field.", + "type": "string" + }, + "type": { + "const": "log", + "type": "string" + } + }, + "required": [ + "type", + "field" + ], + "type": "object" + }, + "LogicalOperation": { + "enum": [ + "less-than", + "lt", + "LT", + "greater-than", + "gt", + "GT", + "less-than-or-equal-to", + "ltet", + "LTET", + "greater-than-or-equal-to", + "gtet", + "GTET" + ], + "type": "string" + }, + "Mark": { + "enum": [ + "point", + "line", + "area", + "bar", + "rect", + "text", + "withinLink", + "betweenLink", + "rule", + "triangleLeft", + "triangleRight", + "triangleBottom", + "brush", + "header" + ], + "type": "string" + }, + "MatrixData": { + "additionalProperties": false, + "properties": { + "binSize": { + "description": "Determine the number of nearby cells to aggregate. __Default__: `1`", + "type": "number" + }, + "column": { + "description": "The name of the first genomic field. __Default__: `x`", + "type": "string" + }, + "row": { + "description": "The name of the first genomic field. __Default__: `y`", + "type": "string" + }, + "type": { + "const": "matrix", + "type": "string" + }, + "url": { + "description": "URL link to the matrix data file", + "type": "string" + }, + "value": { + "description": "The name of the value field. __Default__: `value`", + "type": "string" + } + }, + "required": [ + "type", + "url" + ], + "type": "object" + }, + "MouseEventsDeep": { + "additionalProperties": false, + "description": "Options for determining mouse events in detail, e.g., turning on specific events only", + "properties": { + "click": { + "description": "Whether to enable click events.", + "type": "boolean" + }, + "enableMouseOverOnMultipleMarks": { + "description": "Determine whether all marks underneath the mouse point should be affected by mouse over. __Default__: `false`", + "type": "boolean" + }, + "groupMarksByField": { + "description": "Group marks using keys in a data field. This affects how a set of marks are highlighted/selected by interaction. __Default__: `undefined`", + "type": "string" + }, + "mouseOver": { + "description": "Whether to enable mouseover events.", + "type": "boolean" + }, + "rangeSelect": { + "description": "Whether to send range selection events.", + "type": "boolean" + } + }, + "type": "object" + }, + "MultipleViews": { + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "arrangement": { + "description": "Specify how multiple views are arranged.", + "enum": [ + "parallel", + "serial", + "horizontal", + "vertical" + ], + "type": "string" + }, + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + }, + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" + }, + "id": { + "description": "The ID of a view that is maintained for the use of JS API functions, e.g., positions of a view", + "type": "string" + }, + "layout": { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "views": { + "description": "An array of view specifications", + "items": { + "anyOf": [ + { + "$ref": "#/definitions/SingleView" + }, + { + "$ref": "#/definitions/MultipleViews" + } + ] + }, + "type": "array" + }, + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" + } + }, + "required": [ + "views" + ], + "type": "object" + }, + "MultivecData": { + "additionalProperties": false, + "description": "Two-dimensional quantitative values, one axis for genomic coordinate and the other for different samples, can be converted into HiGlass' `\"multivec\"` data. For example, multiple BigWig files can be converted into a single multivec file. You can also convert sequence data (FASTA) into this format where rows will be different nucleotide bases (e.g., A, T, G, C) and quantitative values represent the frequency. Find out more about this format at [HiGlass Docs](https://docs.higlass.io/data_preparation.html#multivec-files).", + "properties": { + "aggregation": { + "$ref": "#/definitions/BinAggregate", + "description": "Determine aggregation function to apply within bins. __Default__: `\"mean\"`" + }, + "binSize": { + "description": "Binning the genomic interval in tiles (unit size: 256).", + "type": "number" + }, + "categories": { + "description": "assign names of individual samples.", + "items": { + "type": "string" + }, + "type": "array" + }, + "column": { + "description": "Assign a field name of the middle position of genomic intervals. __Default__: `\"position\"`", + "type": "string" + }, + "end": { + "description": "Assign a field name of the end position of genomic intervals. __Default__: `\"end\"`", + "type": "string" + }, + "row": { + "description": "Assign a field name of samples. __Default__: `\"category\"`", + "type": "string" + }, + "start": { + "description": "Assign a field name of the start position of genomic intervals. __Default__: `\"start\"`", + "type": "string" + }, + "type": { + "const": "multivec", + "type": "string" + }, + "url": { + "description": "Specify the URL address of the data file.", + "type": "string" + }, + "value": { + "description": "Assign a field name of quantitative values. __Default__: `\"value\"`", + "type": "string" + } + }, + "required": [ + "type", + "url" + ], + "type": "object" + }, + "OneOfFilter": { + "additionalProperties": false, + "properties": { + "field": { + "description": "A filter is applied based on the values of the specified data field", + "type": "string" + }, + "not": { + "description": "when `{\"not\": true}`, apply a NOT logical operation to the filter.\n\n__Default:__ `false`", + "type": "boolean" + }, + "oneOf": { + "description": "Check whether the value is an element in the provided list.", + "items": { + "type": [ + "string", + "number", + "null" + ] + }, + "type": "array" + }, + "type": { + "const": "filter", + "type": "string" + } + }, + "required": [ + "field", + "oneOf", + "type" + ], + "type": "object" + }, + "Opacity": { + "additionalProperties": false, + "properties": { + "domain": { + "$ref": "#/definitions/ValueExtent", + "description": "Values of the data" + }, + "field": { + "description": "Name of the data field", + "type": "string" + }, + "range": { + "$ref": "#/definitions/ValueExtent", + "description": "Ranges of visual channel values" + }, + "type": { + "description": "Specify the data type", + "enum": [ + "quantitative", + "nominal" + ], + "type": "string" + } + }, + "type": "object" + }, + "Orientation": { + "enum": [ + "horizontal", + "vertical" + ], + "type": "string" + }, + "OverlaidTrack": { + "additionalProperties": false, + "description": "Superposing multiple tracks.", + "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "_invalidTrack": { + "description": "internal", + "type": "boolean" + }, + "_overlay": { + "items": { + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "_invalidTrack": { + "description": "internal", + "type": "boolean" + }, + "_renderingId": { + "description": "internal", + "type": "string" + }, + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + }, + "baselineY": { + "type": "number" + }, + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" + }, + "color": { + "anyOf": [ + { + "$ref": "#/definitions/Color" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "data": { + "$ref": "#/definitions/DataDeep" + }, + "dataTransform": { + "items": { + "$ref": "#/definitions/DataTransform" + }, + "type": "array" + }, + "displacement": { + "$ref": "#/definitions/Displacement" + }, + "endAngle": { + "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "experimental": { + "additionalProperties": false, + "properties": { + "performanceMode": { + "default": false, + "description": "Render visual marks with less smooth curves to increase rendering performance. Only supported for `elliptical` `linkStyle` `withinLink` currently.", + "type": "boolean" + }, + "stretchGraphics": { + "description": "Performance rendering option. By default, certain marks ('bar', 'line', 'rect', 'area') are stretched when zooming in/out to improve rendering performance. No marks will be stretched in circular layouts.\n\nWhen this option is set to true, all marks will be stretched when zooming in/out. When this option is set to false, all marks will be rerendered when zooming in/out.", + "type": "boolean" + }, + "stretchGraphicsThreshold": { + "default": 1.5, + "description": "Threshold for stretching graphics. If the graphics are scaled larger than the threshold, then the graphic will be rerendered. If the graphics are scaled smaller than 1/threshold (e.g., 1/2), then the graphic will be rerendered. This is to prevent the graphics from being stretched too much.", + "type": "number" + } + }, + "type": "object" + }, + "flipY": { + "type": "boolean" + }, + "id": { + "description": "Assigned to `uid` in a HiGlass view config, used for API and caching.", + "type": "string" + }, + "innerRadius": { + "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "mark": { + "$ref": "#/definitions/Mark" + }, + "mouseEvents": { + "anyOf": [ + { + "type": "boolean" + }, + { + "$ref": "#/definitions/MouseEventsDeep" + } + ] + }, + "opacity": { + "anyOf": [ + { + "$ref": "#/definitions/Opacity" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "outerRadius": { + "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", + "type": "number" + }, + "overlayOnPreviousTrack": { + "type": "boolean" + }, + "overrideTemplate": { + "type": "boolean" + }, + "prerelease": { + "additionalProperties": false, + "description": "internal", + "type": "object" + }, + "row": { + "anyOf": [ + { + "$ref": "#/definitions/Row" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "size": { + "anyOf": [ + { + "$ref": "#/definitions/Size" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "startAngle": { + "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "stretch": { + "type": "boolean" + }, + "stroke": { + "anyOf": [ + { + "$ref": "#/definitions/Stroke" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "strokeWidth": { + "anyOf": [ + { + "$ref": "#/definitions/StrokeWidth" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "text": { + "anyOf": [ + { + "$ref": "#/definitions/Text" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "tooltip": { + "items": { + "$ref": "#/definitions/Tooltip" + }, + "type": "array" + }, + "visibility": { + "items": { + "$ref": "#/definitions/VisibilityCondition" + }, + "type": "array" + }, + "x": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1e": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "xe": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1e": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "ye": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" + } + }, + "type": "object" + }, + "type": "array" + }, + "_renderingId": { + "description": "internal", + "type": "string" + }, + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + }, + "baselineY": { + "type": "number" + }, + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" + }, + "color": { + "anyOf": [ + { + "$ref": "#/definitions/Color" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "data": { + "$ref": "#/definitions/DataDeep" + }, + "dataTransform": { + "items": { + "$ref": "#/definitions/DataTransform" + }, + "type": "array" + }, + "displacement": { + "$ref": "#/definitions/Displacement" + }, + "endAngle": { + "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "experimental": { + "additionalProperties": false, + "properties": { + "performanceMode": { + "default": false, + "description": "Render visual marks with less smooth curves to increase rendering performance. Only supported for `elliptical` `linkStyle` `withinLink` currently.", + "type": "boolean" + }, + "stretchGraphics": { + "description": "Performance rendering option. By default, certain marks ('bar', 'line', 'rect', 'area') are stretched when zooming in/out to improve rendering performance. No marks will be stretched in circular layouts.\n\nWhen this option is set to true, all marks will be stretched when zooming in/out. When this option is set to false, all marks will be rerendered when zooming in/out.", + "type": "boolean" + }, + "stretchGraphicsThreshold": { + "default": 1.5, + "description": "Threshold for stretching graphics. If the graphics are scaled larger than the threshold, then the graphic will be rerendered. If the graphics are scaled smaller than 1/threshold (e.g., 1/2), then the graphic will be rerendered. This is to prevent the graphics from being stretched too much.", + "type": "number" + } + }, + "type": "object" + }, + "flipY": { + "type": "boolean" + }, + "height": { + "description": "Specify the track height in pixels.", + "type": "number" + }, + "id": { + "description": "Assigned to `uid` in a HiGlass view config, used for API and caching.", + "type": "string" + }, + "innerRadius": { + "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "layout": { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "mark": { + "$ref": "#/definitions/Mark" + }, + "mouseEvents": { + "anyOf": [ + { + "type": "boolean" + }, + { + "$ref": "#/definitions/MouseEventsDeep" + } + ] + }, + "opacity": { + "anyOf": [ + { + "$ref": "#/definitions/Opacity" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "outerRadius": { + "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", + "type": "number" + }, + "overlayOnPreviousTrack": { + "type": "boolean" + }, + "overrideTemplate": { + "type": "boolean" + }, + "prerelease": { + "additionalProperties": false, + "description": "internal", + "type": "object" + }, + "row": { + "anyOf": [ + { + "$ref": "#/definitions/Row" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "size": { + "anyOf": [ + { + "$ref": "#/definitions/Size" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "startAngle": { + "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "stretch": { + "type": "boolean" + }, + "stroke": { + "anyOf": [ + { + "$ref": "#/definitions/Stroke" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "strokeWidth": { + "anyOf": [ + { + "$ref": "#/definitions/StrokeWidth" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "subtitle": { + "type": "string" + }, + "text": { + "anyOf": [ + { + "$ref": "#/definitions/Text" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "title": { + "description": "If defined, will show the textual label on the left-top corner of a track.", + "type": "string" + }, + "tooltip": { + "items": { + "$ref": "#/definitions/Tooltip" + }, + "type": "array" + }, + "visibility": { + "items": { + "$ref": "#/definitions/VisibilityCondition" + }, + "type": "array" + }, + "width": { + "description": "Specify the track width in pixels.", + "type": "number" + }, + "x": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1e": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "xe": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1e": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "ye": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" + } + }, + "required": [ + "_overlay" + ], + "type": "object" + }, + "OverlaidTracks": { + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "_invalidTrack": { + "description": "internal", + "type": "boolean" + }, + "_renderingId": { + "description": "internal", + "type": "string" + }, + "alignment": { + "const": "overlay", + "type": "string" + }, + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + }, + "baselineY": { + "type": "number" + }, + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" + }, + "color": { + "anyOf": [ + { + "$ref": "#/definitions/Color" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "data": { + "$ref": "#/definitions/DataDeep" + }, + "dataTransform": { + "items": { + "$ref": "#/definitions/DataTransform" + }, + "type": "array" + }, + "displacement": { + "$ref": "#/definitions/Displacement" + }, + "endAngle": { + "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "experimental": { + "additionalProperties": false, + "properties": { + "performanceMode": { + "default": false, + "description": "Render visual marks with less smooth curves to increase rendering performance. Only supported for `elliptical` `linkStyle` `withinLink` currently.", + "type": "boolean" + }, + "stretchGraphics": { + "description": "Performance rendering option. By default, certain marks ('bar', 'line', 'rect', 'area') are stretched when zooming in/out to improve rendering performance. No marks will be stretched in circular layouts.\n\nWhen this option is set to true, all marks will be stretched when zooming in/out. When this option is set to false, all marks will be rerendered when zooming in/out.", + "type": "boolean" + }, + "stretchGraphicsThreshold": { + "default": 1.5, + "description": "Threshold for stretching graphics. If the graphics are scaled larger than the threshold, then the graphic will be rerendered. If the graphics are scaled smaller than 1/threshold (e.g., 1/2), then the graphic will be rerendered. This is to prevent the graphics from being stretched too much.", + "type": "number" + } + }, + "type": "object" + }, + "flipY": { + "type": "boolean" + }, + "height": { + "description": "Specify the track height in pixels.", + "type": "number" + }, + "id": { + "description": "The ID of a view that is maintained for the use of JS API functions, e.g., positions of a view", + "type": "string" + }, + "innerRadius": { + "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "layout": { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "mark": { + "$ref": "#/definitions/Mark" + }, + "mouseEvents": { + "anyOf": [ + { "type": "boolean" }, - "_renderingId": { - "description": "internal", - "type": "string" + { + "$ref": "#/definitions/MouseEventsDeep" + } + ] + }, + "opacity": { + "anyOf": [ + { + "$ref": "#/definitions/Opacity" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "outerRadius": { + "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", + "type": "number" + }, + "overlayOnPreviousTrack": { + "type": "boolean" + }, + "overrideTemplate": { + "type": "boolean" + }, + "prerelease": { + "additionalProperties": false, + "description": "internal", + "type": "object" + }, + "row": { + "anyOf": [ + { + "$ref": "#/definitions/Row" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "size": { + "anyOf": [ + { + "$ref": "#/definitions/Size" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "startAngle": { + "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "stretch": { + "type": "boolean" + }, + "stroke": { + "anyOf": [ + { + "$ref": "#/definitions/Stroke" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "strokeWidth": { + "anyOf": [ + { + "$ref": "#/definitions/StrokeWidth" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "subtitle": { + "type": "string" + }, + "text": { + "anyOf": [ + { + "$ref": "#/definitions/Text" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "title": { + "description": "If defined, will show the textual label on the left-top corner of a track.", + "type": "string" + }, + "tooltip": { + "items": { + "$ref": "#/definitions/Tooltip" + }, + "type": "array" + }, + "tracks": { + "items": { + "$ref": "#/definitions/PartialTrack" + }, + "type": "array" + }, + "visibility": { + "items": { + "$ref": "#/definitions/VisibilityCondition" + }, + "type": "array" + }, + "width": { + "description": "Specify the track width in pixels.", + "type": "number" + }, + "x": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1e": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "xe": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1e": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "ye": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" + } + }, + "required": [ + "alignment", + "tracks" + ], + "type": "object" + }, + "PartialTrack": { + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "_invalidTrack": { + "description": "internal", + "type": "boolean" + }, + "_overlay": { + "items": { + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "_invalidTrack": { + "description": "internal", + "type": "boolean" + }, + "_renderingId": { + "description": "internal", + "type": "string" + }, + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + }, + "baselineY": { + "type": "number" + }, + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" + }, + "color": { + "anyOf": [ + { + "$ref": "#/definitions/Color" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "data": { + "$ref": "#/definitions/DataDeep" + }, + "dataTransform": { + "items": { + "$ref": "#/definitions/DataTransform" + }, + "type": "array" + }, + "displacement": { + "$ref": "#/definitions/Displacement" + }, + "endAngle": { + "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "experimental": { + "additionalProperties": false, + "properties": { + "performanceMode": { + "default": false, + "description": "Render visual marks with less smooth curves to increase rendering performance. Only supported for `elliptical` `linkStyle` `withinLink` currently.", + "type": "boolean" + }, + "stretchGraphics": { + "description": "Performance rendering option. By default, certain marks ('bar', 'line', 'rect', 'area') are stretched when zooming in/out to improve rendering performance. No marks will be stretched in circular layouts.\n\nWhen this option is set to true, all marks will be stretched when zooming in/out. When this option is set to false, all marks will be rerendered when zooming in/out.", + "type": "boolean" + }, + "stretchGraphicsThreshold": { + "default": 1.5, + "description": "Threshold for stretching graphics. If the graphics are scaled larger than the threshold, then the graphic will be rerendered. If the graphics are scaled smaller than 1/threshold (e.g., 1/2), then the graphic will be rerendered. This is to prevent the graphics from being stretched too much.", + "type": "number" + } + }, + "type": "object" + }, + "flipY": { + "type": "boolean" + }, + "id": { + "description": "Assigned to `uid` in a HiGlass view config, used for API and caching.", + "type": "string" + }, + "innerRadius": { + "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "mark": { + "$ref": "#/definitions/Mark" + }, + "mouseEvents": { + "anyOf": [ + { + "type": "boolean" + }, + { + "$ref": "#/definitions/MouseEventsDeep" + } + ] + }, + "opacity": { + "anyOf": [ + { + "$ref": "#/definitions/Opacity" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "outerRadius": { + "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", + "type": "number" + }, + "overlayOnPreviousTrack": { + "type": "boolean" + }, + "overrideTemplate": { + "type": "boolean" + }, + "prerelease": { + "additionalProperties": false, + "description": "internal", + "type": "object" + }, + "row": { + "anyOf": [ + { + "$ref": "#/definitions/Row" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "size": { + "anyOf": [ + { + "$ref": "#/definitions/Size" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "startAngle": { + "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "stretch": { + "type": "boolean" + }, + "stroke": { + "anyOf": [ + { + "$ref": "#/definitions/Stroke" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "strokeWidth": { + "anyOf": [ + { + "$ref": "#/definitions/StrokeWidth" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "text": { + "anyOf": [ + { + "$ref": "#/definitions/Text" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "tooltip": { + "items": { + "$ref": "#/definitions/Tooltip" + }, + "type": "array" + }, + "visibility": { + "items": { + "$ref": "#/definitions/VisibilityCondition" + }, + "type": "array" + }, + "x": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1e": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "xe": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1e": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "ye": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" + } + }, + "type": "object" + }, + "type": "array" + }, + "_renderingId": { + "description": "internal", + "type": "string" + }, + "assembly": { + "anyOf": [ + { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." }, - "alignment": { - "const": "overlay", + { + "const": "unknown", + "description": "No assemblies can be associated with a dummy track", "type": "string" + } + ], + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + }, + "baselineY": { + "type": "number" + }, + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" + }, + "color": { + "anyOf": [ + { + "$ref": "#/definitions/Color" }, - "assembly": { - "$ref": "#/definitions/Assembly", - "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "data": { + "$ref": "#/definitions/DataDeep" + }, + "dataTransform": { + "items": { + "$ref": "#/definitions/DataTransform" + }, + "type": "array" + }, + "displacement": { + "$ref": "#/definitions/Displacement" + }, + "encoding": { + "additionalProperties": { + "$ref": "#/definitions/Channel" + }, + "type": "object" + }, + "endAngle": { + "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "experimental": { + "additionalProperties": false, + "properties": { + "performanceMode": { + "default": false, + "description": "Render visual marks with less smooth curves to increase rendering performance. Only supported for `elliptical` `linkStyle` `withinLink` currently.", + "type": "boolean" }, - "centerRadius": { - "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "stretchGraphics": { + "description": "Performance rendering option. By default, certain marks ('bar', 'line', 'rect', 'area') are stretched when zooming in/out to improve rendering performance. No marks will be stretched in circular layouts.\n\nWhen this option is set to true, all marks will be stretched when zooming in/out. When this option is set to false, all marks will be rerendered when zooming in/out.", + "type": "boolean" + }, + "stretchGraphicsThreshold": { + "default": 1.5, + "description": "Threshold for stretching graphics. If the graphics are scaled larger than the threshold, then the graphic will be rerendered. If the graphics are scaled smaller than 1/threshold (e.g., 1/2), then the graphic will be rerendered. This is to prevent the graphics from being stretched too much.", "type": "number" + } + }, + "type": "object" + }, + "flipY": { + "type": "boolean" + }, + "height": { + "description": "Specify the track height in pixels.", + "type": "number" + }, + "id": { + "description": "Assigned to `uid` in a HiGlass view config, used for API and caching.", + "type": "string" + }, + "innerRadius": { + "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "layout": { + "anyOf": [ + { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." }, - "color": { - "anyOf": [ - { - "$ref": "#/definitions/Color" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] + { + "const": "linear", + "description": "Only linear layout are supported at this time", + "type": "string" + } + ], + "description": "Specify the layout type of all tracks." + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "mark": { + "$ref": "#/definitions/Mark" + }, + "mouseEvents": { + "anyOf": [ + { + "type": "boolean" + }, + { + "$ref": "#/definitions/MouseEventsDeep" + } + ] + }, + "opacity": { + "anyOf": [ + { + "$ref": "#/definitions/Opacity" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "outerRadius": { + "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", + "type": "number" + }, + "overlayOnPreviousTrack": { + "type": "boolean" + }, + "overrideTemplate": { + "type": "boolean" + }, + "prerelease": { + "additionalProperties": false, + "description": "internal", + "type": "object" + }, + "row": { + "anyOf": [ + { + "$ref": "#/definitions/Row" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "size": { + "anyOf": [ + { + "$ref": "#/definitions/Size" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "startAngle": { + "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "static": { + "anyOf": [ + { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + { + "const": true, + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + } + ], + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`." + }, + "stretch": { + "type": "boolean" + }, + "stroke": { + "anyOf": [ + { + "$ref": "#/definitions/Stroke" }, - "data": { - "$ref": "#/definitions/DataDeep" + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "strokeWidth": { + "anyOf": [ + { + "$ref": "#/definitions/StrokeWidth" }, - "dataTransform": { - "items": { - "$ref": "#/definitions/DataTransform" - }, - "type": "array" + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "style": { + "anyOf": [ + { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." }, - "description": { - "type": "string" + { + "$ref": "#/definitions/DummyTrackStyle", + "description": "Defines how the track is styled" + } + ], + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "subtitle": { + "type": "string" + }, + "template": { + "type": "string" + }, + "text": { + "anyOf": [ + { + "$ref": "#/definitions/Text" }, - "displacement": { - "$ref": "#/definitions/Displacement" + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "title": { + "description": "If defined, will show the textual label on the left-top corner of a track.", + "type": "string" + }, + "tooltip": { + "items": { + "$ref": "#/definitions/Tooltip" + }, + "type": "array" + }, + "type": { + "const": "dummy-track", + "description": "Used to specify the dummy track", + "type": "string" + }, + "visibility": { + "items": { + "$ref": "#/definitions/VisibilityCondition" + }, + "type": "array" + }, + "width": { + "description": "Specify the track width in pixels.", + "type": "number" + }, + "x": { + "anyOf": [ + { + "$ref": "#/definitions/X" }, - "endAngle": { - "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", - "type": "number" + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1": { + "anyOf": [ + { + "$ref": "#/definitions/X" }, - "flipY": { - "type": "boolean" + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1e": { + "anyOf": [ + { + "$ref": "#/definitions/X" }, - "height": { - "description": "Specify the track height in pixels.", - "type": "number" + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" }, - "id": { - "type": "string" + { + "$ref": "#/definitions/DomainChrInterval" }, - "innerRadius": { - "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", - "type": "number" + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "xe": { + "anyOf": [ + { + "$ref": "#/definitions/X" }, - "layout": { - "$ref": "#/definitions/Layout", - "description": "Specify the layout type of all tracks." + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y": { + "anyOf": [ + { + "$ref": "#/definitions/Y" }, - "linkingId": { - "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", - "type": "string" + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1": { + "anyOf": [ + { + "$ref": "#/definitions/Y" }, - "mark": { - "$ref": "#/definitions/Mark" + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1e": { + "anyOf": [ + { + "$ref": "#/definitions/Y" }, - "opacity": { - "anyOf": [ - { - "$ref": "#/definitions/Opacity" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" }, - "orientation": { - "$ref": "#/definitions/Orientation", - "description": "Specify the orientation." + { + "$ref": "#/definitions/DomainChrInterval" }, - "outerRadius": { - "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", - "type": "number" + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "ye": { + "anyOf": [ + { + "$ref": "#/definitions/Y" }, - "overlayOnPreviousTrack": { + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "zoomLimits": { + "anyOf": [ + { + "$ref": "#/definitions/ZoomLimits" + }, + { + "description": "Unused property for DummyTrack", + "items": { + "type": "null" + }, + "maxItems": 2, + "minItems": 2, + "type": "array" + } + ] + } + }, + "type": "object" + }, + "PredefinedColors": { + "enum": [ + "viridis", + "grey", + "spectral", + "warm", + "cividis", + "bupu", + "rdbu", + "hot", + "pink" + ], + "type": "string" + }, + "Range": { + "anyOf": [ + { + "$ref": "#/definitions/ValueExtent" + }, + { + "$ref": "#/definitions/PredefinedColors" + } + ] + }, + "RangeFilter": { + "additionalProperties": false, + "properties": { + "field": { + "description": "A filter is applied based on the values of the specified data field", + "type": "string" + }, + "inRange": { + "description": "Check whether the value is in a number range.", + "items": { + "type": "number" + }, + "type": "array" + }, + "not": { + "description": "when `{\"not\": true}`, apply a NOT logical operation to the filter.\n\n__Default:__ `false`", + "type": "boolean" + }, + "type": { + "const": "filter", + "type": "string" + } + }, + "required": [ + "field", + "inRange", + "type" + ], + "type": "object" + }, + "ResponsiveSize": { + "anyOf": [ + { + "type": "boolean" + }, + { + "additionalProperties": false, + "properties": { + "height": { "type": "boolean" }, - "overrideTemplate": { + "width": { "type": "boolean" + } + }, + "type": "object" + } + ] + }, + "Row": { + "additionalProperties": false, + "properties": { + "clip": { + "description": "Clip row when the actual y value exceeds the max value of the y scale. Used only for bar marks at the moment. __Default__: `true`", + "type": "boolean" + }, + "domain": { + "$ref": "#/definitions/ValueExtent", + "description": "Values of the data" + }, + "field": { + "description": "Name of the data field", + "type": "string" + }, + "grid": { + "description": "Whether to display grid. __Default__: `false`", + "type": "boolean" + }, + "legend": { + "description": "Whether to display legend. __Default__: `false`", + "type": "boolean" + }, + "padding": { + "description": "Determines the size of inner white spaces on the top and bottom of individiual rows. __Default__: `0`", + "type": "number" + }, + "range": { + "$ref": "#/definitions/ValueExtent", + "description": "Determine the start and end position of rendering area of this track along vertical axis. __Default__: `[0, height]`" + }, + "type": { + "const": "nominal", + "description": "Specify the data type", + "type": "string" + } + }, + "type": "object" + }, + "SelectivityCondition": { + "additionalProperties": false, + "properties": { + "measure": { + "enum": [ + "width", + "height", + "aspectRatio" + ], + "type": "string" + }, + "operation": { + "$ref": "#/definitions/LogicalOperation" + }, + "target": { + "description": "Does the condition applied to the visualization itself or its container? __Default__: `'self'`", + "enum": [ + "self", + "container" + ], + "type": "string" + }, + "threshold": { + "description": "Threshold in the unit of pixels.", + "type": "number" + } + }, + "required": [ + "operation", + "measure", + "threshold" + ], + "type": "object" + }, + "SingleTrack": { + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "_invalidTrack": { + "description": "internal", + "type": "boolean" + }, + "_renderingId": { + "description": "internal", + "type": "string" + }, + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + }, + "baselineY": { + "type": "number" + }, + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" + }, + "color": { + "anyOf": [ + { + "$ref": "#/definitions/Color" }, - "prerelease": { - "additionalProperties": false, - "description": "internal", - "type": "object" - }, - "row": { - "anyOf": [ - { - "$ref": "#/definitions/Row" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "size": { - "anyOf": [ - { - "$ref": "#/definitions/Size" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "spacing": { - "description": "- If `{\"layout\": \"linear\"}`, specify the space between tracks in pixels;\n\n- If `{\"layout\": \"circular\"}`, specify the space between tracks in percentage ranging from 0 to 100.", - "type": "number" - }, - "startAngle": { - "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "static": { - "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "data": { + "$ref": "#/definitions/DataDeep" + }, + "dataTransform": { + "items": { + "$ref": "#/definitions/DataTransform" + }, + "type": "array" + }, + "displacement": { + "$ref": "#/definitions/Displacement" + }, + "endAngle": { + "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "experimental": { + "additionalProperties": false, + "properties": { + "performanceMode": { + "default": false, + "description": "Render visual marks with less smooth curves to increase rendering performance. Only supported for `elliptical` `linkStyle` `withinLink` currently.", "type": "boolean" }, - "stretch": { + "stretchGraphics": { + "description": "Performance rendering option. By default, certain marks ('bar', 'line', 'rect', 'area') are stretched when zooming in/out to improve rendering performance. No marks will be stretched in circular layouts.\n\nWhen this option is set to true, all marks will be stretched when zooming in/out. When this option is set to false, all marks will be rerendered when zooming in/out.", "type": "boolean" }, - "stroke": { - "anyOf": [ - { - "$ref": "#/definitions/Stroke" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "strokeWidth": { - "anyOf": [ - { - "$ref": "#/definitions/StrokeWidth" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "style": { - "$ref": "#/definitions/Style", - "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overriden by the style of children elements (e.g., view, track)." - }, - "subtitle": { - "type": "string" - }, - "text": { - "anyOf": [ - { - "$ref": "#/definitions/Text" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "title": { - "description": "If defined, will show the textual label on the left-top corner of a track.", - "type": "string" + "stretchGraphicsThreshold": { + "default": 1.5, + "description": "Threshold for stretching graphics. If the graphics are scaled larger than the threshold, then the graphic will be rerendered. If the graphics are scaled smaller than 1/threshold (e.g., 1/2), then the graphic will be rerendered. This is to prevent the graphics from being stretched too much.", + "type": "number" + } + }, + "type": "object" + }, + "flipY": { + "type": "boolean" + }, + "height": { + "description": "Specify the track height in pixels.", + "type": "number" + }, + "id": { + "description": "Assigned to `uid` in a HiGlass view config, used for API and caching.", + "type": "string" + }, + "innerRadius": { + "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "layout": { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "mark": { + "$ref": "#/definitions/Mark" + }, + "mouseEvents": { + "anyOf": [ + { + "type": "boolean" }, - "tooltip": { - "items": { - "$ref": "#/definitions/Tooltip" - }, - "type": "array" + { + "$ref": "#/definitions/MouseEventsDeep" + } + ] + }, + "opacity": { + "anyOf": [ + { + "$ref": "#/definitions/Opacity" }, - "tracks": { - "items": { - "$ref": "#/definitions/PartialTrack" - }, - "type": "array" + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "outerRadius": { + "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", + "type": "number" + }, + "overlayOnPreviousTrack": { + "type": "boolean" + }, + "overrideTemplate": { + "type": "boolean" + }, + "prerelease": { + "additionalProperties": false, + "description": "internal", + "type": "object" + }, + "row": { + "anyOf": [ + { + "$ref": "#/definitions/Row" }, - "visibility": { - "items": { - "$ref": "#/definitions/VisibilityCondition" - }, - "type": "array" + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "size": { + "anyOf": [ + { + "$ref": "#/definitions/Size" }, - "width": { - "description": "Specify the track width in pixels.", - "type": "number" + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "startAngle": { + "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "stretch": { + "type": "boolean" + }, + "stroke": { + "anyOf": [ + { + "$ref": "#/definitions/Stroke" }, - "x": { - "anyOf": [ - { - "$ref": "#/definitions/X" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "strokeWidth": { + "anyOf": [ + { + "$ref": "#/definitions/StrokeWidth" }, - "x1": { - "anyOf": [ - { - "$ref": "#/definitions/X" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "subtitle": { + "type": "string" + }, + "text": { + "anyOf": [ + { + "$ref": "#/definitions/Text" }, - "x1e": { - "anyOf": [ - { - "$ref": "#/definitions/X" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "title": { + "description": "If defined, will show the textual label on the left-top corner of a track.", + "type": "string" + }, + "tooltip": { + "items": { + "$ref": "#/definitions/Tooltip" + }, + "type": "array" + }, + "visibility": { + "items": { + "$ref": "#/definitions/VisibilityCondition" + }, + "type": "array" + }, + "width": { + "description": "Specify the track width in pixels.", + "type": "number" + }, + "x": { + "anyOf": [ + { + "$ref": "#/definitions/X" }, - "xAxis": { - "$ref": "#/definitions/AxisPosition", - "description": "not supported" + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1": { + "anyOf": [ + { + "$ref": "#/definitions/X" }, - "xDomain": { - "anyOf": [ - { - "$ref": "#/definitions/DomainInterval" - }, - { - "$ref": "#/definitions/DomainChrInterval" - }, - { - "$ref": "#/definitions/DomainChr" - } - ] + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1e": { + "anyOf": [ + { + "$ref": "#/definitions/X" }, - "xOffset": { - "description": "Specify the x offset of views in the unit of pixels", - "type": "number" + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" }, - "xe": { - "anyOf": [ - { - "$ref": "#/definitions/X" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] + { + "$ref": "#/definitions/DomainChrInterval" }, - "y": { - "anyOf": [ - { - "$ref": "#/definitions/Y" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "xe": { + "anyOf": [ + { + "$ref": "#/definitions/X" }, - "y1": { - "anyOf": [ - { - "$ref": "#/definitions/Y" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y": { + "anyOf": [ + { + "$ref": "#/definitions/Y" }, - "y1e": { - "anyOf": [ - { - "$ref": "#/definitions/Y" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1": { + "anyOf": [ + { + "$ref": "#/definitions/Y" }, - "yOffset": { - "description": "Specify the y offset of views in the unit of pixels", - "type": "number" + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1e": { + "anyOf": [ + { + "$ref": "#/definitions/Y" }, - "ye": { - "anyOf": [ - { - "$ref": "#/definitions/Y" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" }, - "zoomLimits": { - "$ref": "#/definitions/ZoomLimits" + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" } - }, - "required": [ - "alignment", - "height", - "tracks", - "width" ], - "type": "object" + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "ye": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" + } + }, + "required": [ + "data", + "mark" + ], + "type": "object" + }, + "SingleView": { + "anyOf": [ { "additionalProperties": false, "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, "_invalidTrack": { "description": "internal", "type": "boolean" @@ -3515,13 +6434,16 @@ "type": "string" }, "alignment": { - "const": "stack", + "const": "overlay", "type": "string" }, "assembly": { "$ref": "#/definitions/Assembly", "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." }, + "baselineY": { + "type": "number" + }, "centerRadius": { "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", "type": "number" @@ -3545,9 +6467,6 @@ }, "type": "array" }, - "description": { - "type": "string" - }, "displacement": { "$ref": "#/definitions/Displacement" }, @@ -3555,6 +6474,26 @@ "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", "type": "number" }, + "experimental": { + "additionalProperties": false, + "properties": { + "performanceMode": { + "default": false, + "description": "Render visual marks with less smooth curves to increase rendering performance. Only supported for `elliptical` `linkStyle` `withinLink` currently.", + "type": "boolean" + }, + "stretchGraphics": { + "description": "Performance rendering option. By default, certain marks ('bar', 'line', 'rect', 'area') are stretched when zooming in/out to improve rendering performance. No marks will be stretched in circular layouts.\n\nWhen this option is set to true, all marks will be stretched when zooming in/out. When this option is set to false, all marks will be rerendered when zooming in/out.", + "type": "boolean" + }, + "stretchGraphicsThreshold": { + "default": 1.5, + "description": "Threshold for stretching graphics. If the graphics are scaled larger than the threshold, then the graphic will be rerendered. If the graphics are scaled smaller than 1/threshold (e.g., 1/2), then the graphic will be rerendered. This is to prevent the graphics from being stretched too much.", + "type": "number" + } + }, + "type": "object" + }, "flipY": { "type": "boolean" }, @@ -3563,6 +6502,7 @@ "type": "number" }, "id": { + "description": "The ID of a view that is maintained for the use of JS API functions, e.g., positions of a view", "type": "string" }, "innerRadius": { @@ -3580,6 +6520,16 @@ "mark": { "$ref": "#/definitions/Mark" }, + "mouseEvents": { + "anyOf": [ + { + "type": "boolean" + }, + { + "$ref": "#/definitions/MouseEventsDeep" + } + ] + }, "opacity": { "anyOf": [ { @@ -3609,6 +6559,413 @@ "description": "internal", "type": "object" }, + "responsiveSpec": { + "items": { + "additionalProperties": false, + "properties": { + "selectivity": { + "items": { + "$ref": "#/definitions/SelectivityCondition" + }, + "type": "array" + }, + "spec": { + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "_invalidTrack": { + "description": "internal", + "type": "boolean" + }, + "_renderingId": { + "description": "internal", + "type": "string" + }, + "alignment": { + "enum": [ + "overlay", + "stack" + ], + "type": "string" + }, + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + }, + "baselineY": { + "type": "number" + }, + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" + }, + "color": { + "anyOf": [ + { + "$ref": "#/definitions/Color" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "data": { + "$ref": "#/definitions/DataDeep" + }, + "dataTransform": { + "items": { + "$ref": "#/definitions/DataTransform" + }, + "type": "array" + }, + "displacement": { + "$ref": "#/definitions/Displacement" + }, + "endAngle": { + "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "experimental": { + "additionalProperties": false, + "properties": { + "performanceMode": { + "default": false, + "description": "Render visual marks with less smooth curves to increase rendering performance. Only supported for `elliptical` `linkStyle` `withinLink` currently.", + "type": "boolean" + }, + "stretchGraphics": { + "description": "Performance rendering option. By default, certain marks ('bar', 'line', 'rect', 'area') are stretched when zooming in/out to improve rendering performance. No marks will be stretched in circular layouts.\n\nWhen this option is set to true, all marks will be stretched when zooming in/out. When this option is set to false, all marks will be rerendered when zooming in/out.", + "type": "boolean" + }, + "stretchGraphicsThreshold": { + "default": 1.5, + "description": "Threshold for stretching graphics. If the graphics are scaled larger than the threshold, then the graphic will be rerendered. If the graphics are scaled smaller than 1/threshold (e.g., 1/2), then the graphic will be rerendered. This is to prevent the graphics from being stretched too much.", + "type": "number" + } + }, + "type": "object" + }, + "flipY": { + "type": "boolean" + }, + "height": { + "description": "Specify the track height in pixels.", + "type": "number" + }, + "id": { + "description": "The ID of a view that is maintained for the use of JS API functions, e.g., positions of a view", + "type": "string" + }, + "innerRadius": { + "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "layout": { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "mark": { + "$ref": "#/definitions/Mark" + }, + "mouseEvents": { + "anyOf": [ + { + "type": "boolean" + }, + { + "$ref": "#/definitions/MouseEventsDeep" + } + ] + }, + "opacity": { + "anyOf": [ + { + "$ref": "#/definitions/Opacity" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "outerRadius": { + "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", + "type": "number" + }, + "overlayOnPreviousTrack": { + "type": "boolean" + }, + "overrideTemplate": { + "type": "boolean" + }, + "prerelease": { + "additionalProperties": false, + "description": "internal", + "type": "object" + }, + "row": { + "anyOf": [ + { + "$ref": "#/definitions/Row" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "size": { + "anyOf": [ + { + "$ref": "#/definitions/Size" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "startAngle": { + "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "stretch": { + "type": "boolean" + }, + "stroke": { + "anyOf": [ + { + "$ref": "#/definitions/Stroke" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "strokeWidth": { + "anyOf": [ + { + "$ref": "#/definitions/StrokeWidth" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "subtitle": { + "type": "string" + }, + "text": { + "anyOf": [ + { + "$ref": "#/definitions/Text" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "title": { + "description": "If defined, will show the textual label on the left-top corner of a track.", + "type": "string" + }, + "tooltip": { + "items": { + "$ref": "#/definitions/Tooltip" + }, + "type": "array" + }, + "tracks": { + "anyOf": [ + { + "items": { + "$ref": "#/definitions/PartialTrack" + }, + "type": "array" + }, + { + "items": { + "anyOf": [ + { + "$ref": "#/definitions/PartialTrack" + }, + { + "$ref": "#/definitions/OverlaidTracks" + } + ] + }, + "type": "array" + } + ] + }, + "visibility": { + "items": { + "$ref": "#/definitions/VisibilityCondition" + }, + "type": "array" + }, + "width": { + "description": "Specify the track width in pixels.", + "type": "number" + }, + "x": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1e": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "xe": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1e": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "ye": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" + } + }, + "type": "object" + } + }, + "required": [ + "spec", + "selectivity" + ], + "type": "object" + }, + "type": "array" + }, "row": { "anyOf": [ { @@ -3630,7 +6987,7 @@ ] }, "spacing": { - "description": "- If `{\"layout\": \"linear\"}`, specify the space between tracks in pixels;\n\n- If `{\"layout\": \"circular\"}`, specify the space between tracks in percentage ranging from 0 to 100.", + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", "type": "number" }, "startAngle": { @@ -3666,7 +7023,7 @@ }, "style": { "$ref": "#/definitions/Style", - "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overriden by the style of children elements (e.g., view, track)." + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." }, "subtitle": { "type": "string" @@ -3693,14 +7050,7 @@ }, "tracks": { "items": { - "anyOf": [ - { - "$ref": "#/definitions/PartialTrack" - }, - { - "$ref": "#/definitions/OverlaidTracks" - } - ] + "$ref": "#/definitions/PartialTrack" }, "type": "array" }, @@ -3759,7 +7109,8 @@ { "$ref": "#/definitions/DomainChr" } - ] + ], + "description": "Specify the visible region of genomic x-axis" }, "xOffset": { "description": "Specify the x offset of views in the unit of pixels", @@ -3805,6 +7156,20 @@ } ] }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, "yOffset": { "description": "Specify the y offset of views in the unit of pixels", "type": "number" @@ -3824,6 +7189,7 @@ } }, "required": [ + "alignment", "tracks" ], "type": "object" @@ -3831,846 +7197,1377 @@ { "additionalProperties": false, "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "_invalidTrack": { + "description": "internal", + "type": "boolean" + }, + "_renderingId": { + "description": "internal", + "type": "string" + }, + "alignment": { + "const": "stack", + "type": "string" + }, "assembly": { "$ref": "#/definitions/Assembly", "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." }, + "baselineY": { + "type": "number" + }, "centerRadius": { "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", "type": "number" }, - "description": { - "type": "string" + "color": { + "anyOf": [ + { + "$ref": "#/definitions/Color" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - "layout": { - "$ref": "#/definitions/Layout", - "description": "Specify the layout type of all tracks." + "data": { + "$ref": "#/definitions/DataDeep" }, - "linkingId": { - "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", - "type": "string" + "dataTransform": { + "items": { + "$ref": "#/definitions/DataTransform" + }, + "type": "array" }, - "orientation": { - "$ref": "#/definitions/Orientation", - "description": "Specify the orientation." + "displacement": { + "$ref": "#/definitions/Displacement" }, - "spacing": { - "description": "- If `{\"layout\": \"linear\"}`, specify the space between tracks in pixels;\n\n- If `{\"layout\": \"circular\"}`, specify the space between tracks in percentage ranging from 0 to 100.", + "endAngle": { + "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", "type": "number" }, - "static": { - "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "experimental": { + "additionalProperties": false, + "properties": { + "performanceMode": { + "default": false, + "description": "Render visual marks with less smooth curves to increase rendering performance. Only supported for `elliptical` `linkStyle` `withinLink` currently.", + "type": "boolean" + }, + "stretchGraphics": { + "description": "Performance rendering option. By default, certain marks ('bar', 'line', 'rect', 'area') are stretched when zooming in/out to improve rendering performance. No marks will be stretched in circular layouts.\n\nWhen this option is set to true, all marks will be stretched when zooming in/out. When this option is set to false, all marks will be rerendered when zooming in/out.", + "type": "boolean" + }, + "stretchGraphicsThreshold": { + "default": 1.5, + "description": "Threshold for stretching graphics. If the graphics are scaled larger than the threshold, then the graphic will be rerendered. If the graphics are scaled smaller than 1/threshold (e.g., 1/2), then the graphic will be rerendered. This is to prevent the graphics from being stretched too much.", + "type": "number" + } + }, + "type": "object" + }, + "flipY": { "type": "boolean" }, - "style": { - "$ref": "#/definitions/Style", - "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overriden by the style of children elements (e.g., view, track)." + "height": { + "description": "Specify the track height in pixels.", + "type": "number" }, - "subtitle": { + "id": { + "description": "The ID of a view that is maintained for the use of JS API functions, e.g., positions of a view", "type": "string" }, - "title": { - "type": "string" + "innerRadius": { + "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", + "type": "number" }, - "tracks": { - "items": { - "$ref": "#/definitions/Track" - }, - "type": "array" + "layout": { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." }, - "xAxis": { - "$ref": "#/definitions/AxisPosition", - "description": "not supported" + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "mark": { + "$ref": "#/definitions/Mark" }, - "xDomain": { + "mouseEvents": { "anyOf": [ { - "$ref": "#/definitions/DomainInterval" + "type": "boolean" }, { - "$ref": "#/definitions/DomainChrInterval" + "$ref": "#/definitions/MouseEventsDeep" + } + ] + }, + "opacity": { + "anyOf": [ + { + "$ref": "#/definitions/Opacity" }, { - "$ref": "#/definitions/DomainChr" + "$ref": "#/definitions/ChannelValue" } ] }, - "xOffset": { - "description": "Specify the x offset of views in the unit of pixels", - "type": "number" + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." }, - "yOffset": { - "description": "Specify the y offset of views in the unit of pixels", + "outerRadius": { + "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", "type": "number" }, - "zoomLimits": { - "$ref": "#/definitions/ZoomLimits" - } - }, - "required": [ - "tracks" - ], - "type": "object" - } - ] - }, - "Row": { - "additionalProperties": false, - "properties": { - "domain": { - "$ref": "#/definitions/ValueExtent", - "description": "Values of the data" - }, - "field": { - "description": "Name of the data field", - "type": "string" - }, - "grid": { - "description": "Whether to display grid. __Default__: `false`", - "type": "boolean" - }, - "legend": { - "description": "Whether to display legend. __Default__: `false`", - "type": "boolean" - }, - "padding": { - "description": "Determines the size of inner white spaces on the top and bottom of individiual rows. __Default__: `0`", - "type": "number" - }, - "range": { - "$ref": "#/definitions/ValueExtent", - "description": "Determine the start and end position of rendering area of this track along vertical axis. __Default__: `[0, height]`" - }, - "type": { - "const": "nominal", - "description": "Specify the data type", - "type": "string" - } - }, - "type": "object" - }, - "SingleTrack": { - "additionalProperties": false, - "properties": { - "_invalidTrack": { - "description": "internal", - "type": "boolean" - }, - "_renderingId": { - "description": "internal", - "type": "string" - }, - "assembly": { - "$ref": "#/definitions/Assembly", - "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." - }, - "centerRadius": { - "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", - "type": "number" - }, - "color": { - "anyOf": [ - { - "$ref": "#/definitions/Color" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "data": { - "$ref": "#/definitions/DataDeep" - }, - "dataTransform": { - "items": { - "$ref": "#/definitions/DataTransform" - }, - "type": "array" - }, - "displacement": { - "$ref": "#/definitions/Displacement" - }, - "endAngle": { - "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "flipY": { - "type": "boolean" - }, - "height": { - "description": "Specify the track height in pixels.", - "type": "number" - }, - "id": { - "type": "string" - }, - "innerRadius": { - "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "layout": { - "$ref": "#/definitions/Layout", - "description": "Specify the layout type of all tracks." - }, - "linkingId": { - "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", - "type": "string" - }, - "mark": { - "$ref": "#/definitions/Mark" - }, - "opacity": { - "anyOf": [ - { - "$ref": "#/definitions/Opacity" + "overlayOnPreviousTrack": { + "type": "boolean" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "orientation": { - "$ref": "#/definitions/Orientation", - "description": "Specify the orientation." - }, - "outerRadius": { - "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", - "type": "number" - }, - "overlayOnPreviousTrack": { - "type": "boolean" - }, - "overrideTemplate": { - "type": "boolean" - }, - "prerelease": { - "additionalProperties": false, - "description": "internal", - "type": "object" - }, - "row": { - "anyOf": [ - { - "$ref": "#/definitions/Row" + "overrideTemplate": { + "type": "boolean" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "size": { - "anyOf": [ - { - "$ref": "#/definitions/Size" + "prerelease": { + "additionalProperties": false, + "description": "internal", + "type": "object" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "spacing": { - "description": "- If `{\"layout\": \"linear\"}`, specify the space between tracks in pixels;\n\n- If `{\"layout\": \"circular\"}`, specify the space between tracks in percentage ranging from 0 to 100.", - "type": "number" - }, - "startAngle": { - "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "static": { - "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", - "type": "boolean" - }, - "stretch": { - "type": "boolean" - }, - "stroke": { - "anyOf": [ - { - "$ref": "#/definitions/Stroke" + "responsiveSpec": { + "items": { + "additionalProperties": false, + "properties": { + "selectivity": { + "items": { + "$ref": "#/definitions/SelectivityCondition" + }, + "type": "array" + }, + "spec": { + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "_invalidTrack": { + "description": "internal", + "type": "boolean" + }, + "_renderingId": { + "description": "internal", + "type": "string" + }, + "alignment": { + "enum": [ + "overlay", + "stack" + ], + "type": "string" + }, + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + }, + "baselineY": { + "type": "number" + }, + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" + }, + "color": { + "anyOf": [ + { + "$ref": "#/definitions/Color" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "data": { + "$ref": "#/definitions/DataDeep" + }, + "dataTransform": { + "items": { + "$ref": "#/definitions/DataTransform" + }, + "type": "array" + }, + "displacement": { + "$ref": "#/definitions/Displacement" + }, + "endAngle": { + "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "experimental": { + "additionalProperties": false, + "properties": { + "performanceMode": { + "default": false, + "description": "Render visual marks with less smooth curves to increase rendering performance. Only supported for `elliptical` `linkStyle` `withinLink` currently.", + "type": "boolean" + }, + "stretchGraphics": { + "description": "Performance rendering option. By default, certain marks ('bar', 'line', 'rect', 'area') are stretched when zooming in/out to improve rendering performance. No marks will be stretched in circular layouts.\n\nWhen this option is set to true, all marks will be stretched when zooming in/out. When this option is set to false, all marks will be rerendered when zooming in/out.", + "type": "boolean" + }, + "stretchGraphicsThreshold": { + "default": 1.5, + "description": "Threshold for stretching graphics. If the graphics are scaled larger than the threshold, then the graphic will be rerendered. If the graphics are scaled smaller than 1/threshold (e.g., 1/2), then the graphic will be rerendered. This is to prevent the graphics from being stretched too much.", + "type": "number" + } + }, + "type": "object" + }, + "flipY": { + "type": "boolean" + }, + "height": { + "description": "Specify the track height in pixels.", + "type": "number" + }, + "id": { + "description": "The ID of a view that is maintained for the use of JS API functions, e.g., positions of a view", + "type": "string" + }, + "innerRadius": { + "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "layout": { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "mark": { + "$ref": "#/definitions/Mark" + }, + "mouseEvents": { + "anyOf": [ + { + "type": "boolean" + }, + { + "$ref": "#/definitions/MouseEventsDeep" + } + ] + }, + "opacity": { + "anyOf": [ + { + "$ref": "#/definitions/Opacity" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "outerRadius": { + "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", + "type": "number" + }, + "overlayOnPreviousTrack": { + "type": "boolean" + }, + "overrideTemplate": { + "type": "boolean" + }, + "prerelease": { + "additionalProperties": false, + "description": "internal", + "type": "object" + }, + "row": { + "anyOf": [ + { + "$ref": "#/definitions/Row" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "size": { + "anyOf": [ + { + "$ref": "#/definitions/Size" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "startAngle": { + "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "stretch": { + "type": "boolean" + }, + "stroke": { + "anyOf": [ + { + "$ref": "#/definitions/Stroke" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "strokeWidth": { + "anyOf": [ + { + "$ref": "#/definitions/StrokeWidth" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "subtitle": { + "type": "string" + }, + "text": { + "anyOf": [ + { + "$ref": "#/definitions/Text" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "title": { + "description": "If defined, will show the textual label on the left-top corner of a track.", + "type": "string" + }, + "tooltip": { + "items": { + "$ref": "#/definitions/Tooltip" + }, + "type": "array" + }, + "tracks": { + "anyOf": [ + { + "items": { + "$ref": "#/definitions/PartialTrack" + }, + "type": "array" + }, + { + "items": { + "anyOf": [ + { + "$ref": "#/definitions/PartialTrack" + }, + { + "$ref": "#/definitions/OverlaidTracks" + } + ] + }, + "type": "array" + } + ] + }, + "visibility": { + "items": { + "$ref": "#/definitions/VisibilityCondition" + }, + "type": "array" + }, + "width": { + "description": "Specify the track width in pixels.", + "type": "number" + }, + "x": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1e": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "xe": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1e": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "ye": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" + } + }, + "type": "object" + } + }, + "required": [ + "spec", + "selectivity" + ], + "type": "object" + }, + "type": "array" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "strokeWidth": { - "anyOf": [ - { - "$ref": "#/definitions/StrokeWidth" + "row": { + "anyOf": [ + { + "$ref": "#/definitions/Row" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "style": { - "$ref": "#/definitions/Style", - "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overriden by the style of children elements (e.g., view, track)." - }, - "subtitle": { - "type": "string" - }, - "text": { - "anyOf": [ - { - "$ref": "#/definitions/Text" + "size": { + "anyOf": [ + { + "$ref": "#/definitions/Size" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "title": { - "description": "If defined, will show the textual label on the left-top corner of a track.", - "type": "string" - }, - "tooltip": { - "items": { - "$ref": "#/definitions/Tooltip" - }, - "type": "array" - }, - "visibility": { - "items": { - "$ref": "#/definitions/VisibilityCondition" - }, - "type": "array" - }, - "width": { - "description": "Specify the track width in pixels.", - "type": "number" - }, - "x": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "x1": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "startAngle": { + "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "x1e": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "xAxis": { - "$ref": "#/definitions/AxisPosition", - "description": "not supported" - }, - "xDomain": { - "anyOf": [ - { - "$ref": "#/definitions/DomainInterval" + "stretch": { + "type": "boolean" }, - { - "$ref": "#/definitions/DomainChrInterval" + "stroke": { + "anyOf": [ + { + "$ref": "#/definitions/Stroke" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/DomainChr" - } - ] - }, - "xOffset": { - "description": "Specify the x offset of views in the unit of pixels", - "type": "number" - }, - "xe": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "strokeWidth": { + "anyOf": [ + { + "$ref": "#/definitions/StrokeWidth" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "y": { - "anyOf": [ - { - "$ref": "#/definitions/Y" + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "y1": { - "anyOf": [ - { - "$ref": "#/definitions/Y" + "subtitle": { + "type": "string" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "y1e": { - "anyOf": [ - { - "$ref": "#/definitions/Y" + "text": { + "anyOf": [ + { + "$ref": "#/definitions/Text" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "yOffset": { - "description": "Specify the y offset of views in the unit of pixels", - "type": "number" - }, - "ye": { - "anyOf": [ - { - "$ref": "#/definitions/Y" + "title": { + "description": "If defined, will show the textual label on the left-top corner of a track.", + "type": "string" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "zoomLimits": { - "$ref": "#/definitions/ZoomLimits" - } - }, - "required": [ - "data", - "height", - "mark", - "width" - ], - "type": "object" - }, - "SingleView": { - "anyOf": [ - { - "$ref": "#/definitions/OverlaidTracks" - }, - { - "$ref": "#/definitions/StackedTracks" - }, - { - "$ref": "#/definitions/FlatTracks" - } - ] - }, - "Size": { - "additionalProperties": false, - "properties": { - "domain": { - "$ref": "#/definitions/ValueExtent", - "description": "Values of the data" - }, - "field": { - "description": "Name of the data field", - "type": "string" - }, - "legend": { - "description": "not supported: Whether to display legend. __Default__: `false`", - "type": "boolean" - }, - "range": { - "$ref": "#/definitions/ValueExtent", - "description": "Ranges of visual channel values" - }, - "type": { - "description": "Specify the data type", - "enum": [ - "quantitative", - "nominal" - ], - "type": "string" - } - }, - "type": "object" - }, - "SizeVisibilityCondition": { - "additionalProperties": false, - "properties": { - "conditionPadding": { - "description": "Specify the buffer size (in pixel) of width or height when calculating the visibility.\n\n__Default__: `0`", - "type": "number" - }, - "measure": { - "description": "Specify which aspect of the `target` will be compared to the `threshold`.", - "enum": [ - "width", - "height" - ], - "type": "string" - }, - "operation": { - "$ref": "#/definitions/LogicalOperation", - "description": "A string that pecifies the logical operation to conduct between `threshold` and the `measure` of `target`. Support\n\n- greater than : \"greater-than\", \"gt\", \"GT\"\n\n- less than : \"less-than\", \"lt\", \"LT\"\n\n- greater than or equal to : \"greater-than-or-equal-to\", \"gtet\", \"GTET\"\n\n- less than or equal to : \"less-than-or-equal-to\", \"ltet\", \"LTET\"" - }, - "target": { - "description": "Target specifies the object that you want to compare with the threshold.", - "enum": [ - "track", - "mark" - ], - "type": "string" - }, - "threshold": { - "anyOf": [ - { + "tooltip": { + "items": { + "$ref": "#/definitions/Tooltip" + }, + "type": "array" + }, + "tracks": { + "items": { + "anyOf": [ + { + "$ref": "#/definitions/PartialTrack" + }, + { + "$ref": "#/definitions/OverlaidTracks" + } + ] + }, + "type": "array" + }, + "visibility": { + "items": { + "$ref": "#/definitions/VisibilityCondition" + }, + "type": "array" + }, + "width": { + "description": "Specify the track width in pixels.", "type": "number" }, - { - "const": "|xe-x|", - "type": "string" - } - ], - "description": "Specify the threshold as one of:\n\n- A number representing a fixed threshold in the unit of pixels;\n\n- `\"|xe-x|\"`, using the distance between `xe` and `x` as threshold" - }, - "transitionPadding": { - "description": "Specify the buffer size (in pixel) of width or height for smooth transition.\n\n__Default__: `0`", - "type": "number" - } - }, - "required": [ - "measure", - "operation", - "target", - "threshold" - ], - "type": "object" - }, - "StackedTracks": { - "additionalProperties": false, - "properties": { - "_invalidTrack": { - "description": "internal", - "type": "boolean" - }, - "_renderingId": { - "description": "internal", - "type": "string" - }, - "alignment": { - "const": "stack", - "type": "string" - }, - "assembly": { - "$ref": "#/definitions/Assembly", - "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." - }, - "centerRadius": { - "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", - "type": "number" - }, - "color": { - "anyOf": [ - { - "$ref": "#/definitions/Color" + "x": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "data": { - "$ref": "#/definitions/DataDeep" - }, - "dataTransform": { - "items": { - "$ref": "#/definitions/DataTransform" - }, - "type": "array" - }, - "displacement": { - "$ref": "#/definitions/Displacement" - }, - "endAngle": { - "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "flipY": { - "type": "boolean" - }, - "height": { - "description": "Specify the track height in pixels.", - "type": "number" - }, - "id": { - "type": "string" - }, - "innerRadius": { - "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "layout": { - "$ref": "#/definitions/Layout", - "description": "Specify the layout type of all tracks." - }, - "linkingId": { - "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", - "type": "string" - }, - "mark": { - "$ref": "#/definitions/Mark" - }, - "opacity": { - "anyOf": [ - { - "$ref": "#/definitions/Opacity" + "x1": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "orientation": { - "$ref": "#/definitions/Orientation", - "description": "Specify the orientation." - }, - "outerRadius": { - "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", - "type": "number" - }, - "overlayOnPreviousTrack": { - "type": "boolean" - }, - "overrideTemplate": { - "type": "boolean" - }, - "prerelease": { - "additionalProperties": false, - "description": "internal", - "type": "object" - }, - "row": { - "anyOf": [ - { - "$ref": "#/definitions/Row" + "x1e": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "xe": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1e": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "ye": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] }, - { - "$ref": "#/definitions/ChannelValue" + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" } - ] + }, + "required": [ + "tracks" + ], + "type": "object" }, - "size": { - "anyOf": [ - { - "$ref": "#/definitions/Size" + { + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "spacing": { - "description": "- If `{\"layout\": \"linear\"}`, specify the space between tracks in pixels;\n\n- If `{\"layout\": \"circular\"}`, specify the space between tracks in percentage ranging from 0 to 100.", - "type": "number" - }, - "startAngle": { - "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", - "type": "number" - }, - "static": { - "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", - "type": "boolean" - }, - "stretch": { - "type": "boolean" - }, - "stroke": { - "anyOf": [ - { - "$ref": "#/definitions/Stroke" + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "strokeWidth": { - "anyOf": [ - { - "$ref": "#/definitions/StrokeWidth" + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "style": { - "$ref": "#/definitions/Style", - "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overriden by the style of children elements (e.g., view, track)." - }, - "subtitle": { - "type": "string" - }, - "text": { - "anyOf": [ - { - "$ref": "#/definitions/Text" + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "title": { - "description": "If defined, will show the textual label on the left-top corner of a track.", - "type": "string" - }, - "tooltip": { - "items": { - "$ref": "#/definitions/Tooltip" - }, - "type": "array" - }, - "tracks": { - "items": { - "anyOf": [ - { - "$ref": "#/definitions/PartialTrack" + "id": { + "description": "The ID of a view that is maintained for the use of JS API functions, e.g., positions of a view", + "type": "string" + }, + "layout": { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "responsiveSpec": { + "items": { + "additionalProperties": false, + "properties": { + "selectivity": { + "items": { + "$ref": "#/definitions/SelectivityCondition" + }, + "type": "array" + }, + "spec": { + "additionalProperties": false, + "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, + "_invalidTrack": { + "description": "internal", + "type": "boolean" + }, + "_renderingId": { + "description": "internal", + "type": "string" + }, + "alignment": { + "enum": [ + "overlay", + "stack" + ], + "type": "string" + }, + "assembly": { + "$ref": "#/definitions/Assembly", + "description": "A string that specifies the genome builds to use. Currently support `\"hg38\"`, `\"hg19\"`, `\"hg18\"`, `\"hg17\"`, `\"hg16\"`, `\"mm10\"`, `\"mm9\"`, and `\"unknown\"`.\n\n__Note:__: with `\"unknown\"` assembly, genomic axes do not show chrN: in labels." + }, + "baselineY": { + "type": "number" + }, + "centerRadius": { + "description": "Proportion of the radius of the center white space.\n\n__Default:__ `0.3`", + "type": "number" + }, + "color": { + "anyOf": [ + { + "$ref": "#/definitions/Color" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "data": { + "$ref": "#/definitions/DataDeep" + }, + "dataTransform": { + "items": { + "$ref": "#/definitions/DataTransform" + }, + "type": "array" + }, + "displacement": { + "$ref": "#/definitions/Displacement" + }, + "endAngle": { + "description": "Specify the end angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "experimental": { + "additionalProperties": false, + "properties": { + "performanceMode": { + "default": false, + "description": "Render visual marks with less smooth curves to increase rendering performance. Only supported for `elliptical` `linkStyle` `withinLink` currently.", + "type": "boolean" + }, + "stretchGraphics": { + "description": "Performance rendering option. By default, certain marks ('bar', 'line', 'rect', 'area') are stretched when zooming in/out to improve rendering performance. No marks will be stretched in circular layouts.\n\nWhen this option is set to true, all marks will be stretched when zooming in/out. When this option is set to false, all marks will be rerendered when zooming in/out.", + "type": "boolean" + }, + "stretchGraphicsThreshold": { + "default": 1.5, + "description": "Threshold for stretching graphics. If the graphics are scaled larger than the threshold, then the graphic will be rerendered. If the graphics are scaled smaller than 1/threshold (e.g., 1/2), then the graphic will be rerendered. This is to prevent the graphics from being stretched too much.", + "type": "number" + } + }, + "type": "object" + }, + "flipY": { + "type": "boolean" + }, + "height": { + "description": "Specify the track height in pixels.", + "type": "number" + }, + "id": { + "description": "The ID of a view that is maintained for the use of JS API functions, e.g., positions of a view", + "type": "string" + }, + "innerRadius": { + "description": "Specify the inner radius of tracks when (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "layout": { + "$ref": "#/definitions/Layout", + "description": "Specify the layout type of all tracks." + }, + "linkingId": { + "description": "Specify an ID for [linking multiple views](http://gosling-lang.org/docs/user-interaction#linking-views)", + "type": "string" + }, + "mark": { + "$ref": "#/definitions/Mark" + }, + "mouseEvents": { + "anyOf": [ + { + "type": "boolean" + }, + { + "$ref": "#/definitions/MouseEventsDeep" + } + ] + }, + "opacity": { + "anyOf": [ + { + "$ref": "#/definitions/Opacity" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "orientation": { + "$ref": "#/definitions/Orientation", + "description": "Specify the orientation." + }, + "outerRadius": { + "description": "Specify the outer radius of tracks when `{\"layout\": \"circular\"}`.", + "type": "number" + }, + "overlayOnPreviousTrack": { + "type": "boolean" + }, + "overrideTemplate": { + "type": "boolean" + }, + "prerelease": { + "additionalProperties": false, + "description": "internal", + "type": "object" + }, + "row": { + "anyOf": [ + { + "$ref": "#/definitions/Row" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "size": { + "anyOf": [ + { + "$ref": "#/definitions/Size" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" + }, + "startAngle": { + "description": "Specify the start angle (in the range of [0, 360]) of circular tracks (`{\"layout\": \"circular\"}`).", + "type": "number" + }, + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" + }, + "stretch": { + "type": "boolean" + }, + "stroke": { + "anyOf": [ + { + "$ref": "#/definitions/Stroke" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "strokeWidth": { + "anyOf": [ + { + "$ref": "#/definitions/StrokeWidth" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." + }, + "subtitle": { + "type": "string" + }, + "text": { + "anyOf": [ + { + "$ref": "#/definitions/Text" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "title": { + "description": "If defined, will show the textual label on the left-top corner of a track.", + "type": "string" + }, + "tooltip": { + "items": { + "$ref": "#/definitions/Tooltip" + }, + "type": "array" + }, + "tracks": { + "anyOf": [ + { + "items": { + "$ref": "#/definitions/PartialTrack" + }, + "type": "array" + }, + { + "items": { + "anyOf": [ + { + "$ref": "#/definitions/PartialTrack" + }, + { + "$ref": "#/definitions/OverlaidTracks" + } + ] + }, + "type": "array" + } + ] + }, + "visibility": { + "items": { + "$ref": "#/definitions/VisibilityCondition" + }, + "type": "array" + }, + "width": { + "description": "Specify the track width in pixels.", + "type": "number" + }, + "x": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "x1e": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "xe": { + "anyOf": [ + { + "$ref": "#/definitions/X" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "y1e": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "ye": { + "anyOf": [ + { + "$ref": "#/definitions/Y" + }, + { + "$ref": "#/definitions/ChannelValue" + } + ] + }, + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" + } + }, + "type": "object" + } + }, + "required": [ + "spec", + "selectivity" + ], + "type": "object" }, - { - "$ref": "#/definitions/OverlaidTracks" - } - ] - }, - "type": "array" - }, - "visibility": { - "items": { - "$ref": "#/definitions/VisibilityCondition" - }, - "type": "array" - }, - "width": { - "description": "Specify the track width in pixels.", - "type": "number" - }, - "x": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "type": "array" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "x1": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "spacing": { + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", + "type": "number" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "x1e": { - "anyOf": [ - { - "$ref": "#/definitions/X" + "static": { + "description": "Whether to disable [Zooming and Panning](http://gosling-lang.org/docs/user-interaction#zooming-and-panning), __Default:__ `false`.", + "type": "boolean" }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "xAxis": { - "$ref": "#/definitions/AxisPosition", - "description": "not supported" - }, - "xDomain": { - "anyOf": [ - { - "$ref": "#/definitions/DomainInterval" + "style": { + "$ref": "#/definitions/Style", + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." }, - { - "$ref": "#/definitions/DomainChrInterval" + "tracks": { + "items": { + "$ref": "#/definitions/Track" + }, + "type": "array" }, - { - "$ref": "#/definitions/DomainChr" + "xAxis": { + "$ref": "#/definitions/AxisPosition", + "description": "not supported" + }, + "xDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic x-axis" + }, + "xOffset": { + "description": "Specify the x offset of views in the unit of pixels", + "type": "number" + }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, + "yOffset": { + "description": "Specify the y offset of views in the unit of pixels", + "type": "number" + }, + "zoomLimits": { + "$ref": "#/definitions/ZoomLimits" } - ] + }, + "required": [ + "tracks" + ], + "type": "object" + } + ] + }, + "Size": { + "additionalProperties": false, + "properties": { + "domain": { + "$ref": "#/definitions/ValueExtent", + "description": "Values of the data" }, - "xOffset": { - "description": "Specify the x offset of views in the unit of pixels", + "field": { + "description": "Name of the data field", + "type": "string" + }, + "legend": { + "description": "not supported: Whether to display legend. __Default__: `false`", + "type": "boolean" + }, + "range": { + "$ref": "#/definitions/ValueExtent", + "description": "Ranges of visual channel values" + }, + "type": { + "description": "Specify the data type", + "enum": [ + "quantitative", + "nominal" + ], + "type": "string" + } + }, + "type": "object" + }, + "SizeVisibilityCondition": { + "additionalProperties": false, + "properties": { + "conditionPadding": { + "description": "Specify the buffer size (in pixel) of width or height when calculating the visibility.\n\n__Default__: `0`", "type": "number" }, - "xe": { - "anyOf": [ - { - "$ref": "#/definitions/X" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] + "measure": { + "description": "Specify which aspect of the `target` will be compared to the `threshold`.", + "enum": [ + "width", + "height" + ], + "type": "string" }, - "y": { - "anyOf": [ - { - "$ref": "#/definitions/Y" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] + "operation": { + "$ref": "#/definitions/LogicalOperation", + "description": "A string that specifies the logical operation to conduct between `threshold` and the `measure` of `target`. Support\n\n- greater than : \"greater-than\", \"gt\", \"GT\"\n\n- less than : \"less-than\", \"lt\", \"LT\"\n\n- greater than or equal to : \"greater-than-or-equal-to\", \"gtet\", \"GTET\"\n\n- less than or equal to : \"less-than-or-equal-to\", \"ltet\", \"LTET\"" }, - "y1": { - "anyOf": [ - { - "$ref": "#/definitions/Y" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] + "target": { + "description": "Target specifies the object that you want to compare with the threshold.", + "enum": [ + "track", + "mark" + ], + "type": "string" }, - "y1e": { + "threshold": { "anyOf": [ { - "$ref": "#/definitions/Y" + "type": "number" }, { - "$ref": "#/definitions/ChannelValue" + "const": "|xe-x|", + "type": "string" } - ] + ], + "description": "Specify the threshold as one of:\n\n- A number representing a fixed threshold in the unit of pixels;\n\n- `\"|xe-x|\"`, using the distance between `xe` and `x` as threshold" }, - "yOffset": { - "description": "Specify the y offset of views in the unit of pixels", + "transitionPadding": { + "description": "Specify the buffer size (in pixel) of width or height for smooth transition.\n\n__Default__: `0`", "type": "number" - }, - "ye": { - "anyOf": [ - { - "$ref": "#/definitions/Y" - }, - { - "$ref": "#/definitions/ChannelValue" - } - ] - }, - "zoomLimits": { - "$ref": "#/definitions/ZoomLimits" } }, "required": [ - "tracks" + "measure", + "operation", + "target", + "threshold" ], "type": "object" }, @@ -4754,10 +8651,27 @@ "description": "Name of the data field", "type": "string" }, + "legend": { + "description": "Whether to display legend. __Default__: `false`", + "type": "boolean" + }, "range": { "$ref": "#/definitions/Range", "description": "Ranges of visual channel values" }, + "scaleOffset": { + "description": "Whether to use offset of the domain proportionally. This is bound to brushes on the color legend. __Default__: `[0, 1]`", + "items": { + "type": "number" + }, + "maxItems": 2, + "minItems": 2, + "type": "array" + }, + "title": { + "description": "Title of the legend. __Default__: `undefined`", + "type": "string" + }, "type": { "description": "Specify the data type", "enum": [ @@ -4812,13 +8726,31 @@ "backgroundOpacity": { "type": "number" }, - "bazierLink": { - "description": "Specify whether to use bazier curves for the `link` marks.", - "type": "boolean" - }, - "circularLink": { - "description": "Deprecated: draw arc instead of bazier curve?", - "type": "boolean" + "brush": { + "additionalProperties": false, + "description": "Customize the style of the brush mark in the `rangeSelect` mouse event.", + "properties": { + "color": { + "description": "color of the marks when mouse events are triggered", + "type": "string" + }, + "opacity": { + "description": "opacity of the marks when mouse events are triggered", + "type": "number" + }, + "stroke": { + "description": "stroke color of the marks when mouse events are triggered", + "type": "string" + }, + "strokeOpacity": { + "type": "number" + }, + "strokeWidth": { + "description": "stroke width of the marks when mouse events are triggered", + "type": "number" + } + }, + "type": "object" }, "curve": { "description": "Specify the curve of `rule` marks.", @@ -4832,14 +8764,9 @@ }, "dashed": { "description": "Specify the pattern of dashes and gaps for `rule` marks.", - "items": [ - { - "type": "number" - }, - { - "type": "number" - } - ], + "items": { + "type": "number" + }, "maxItems": 2, "minItems": 2, "type": "array" @@ -4894,12 +8821,42 @@ ], "type": "string" }, + "linkMinHeight": { + "description": "The minimum height of `withinLink` and `betweenLink` marks. Unit is a percentagle. __Default__: `0.5`", + "type": "number" + }, + "linkStyle": { + "description": "The style of `withinLink` and `betweenLink` marks. __Default__: `'circular'` `'elliptical'` will be used as a default option.", + "enum": [ + "elliptical", + "circular", + "straight" + ], + "type": "string" + }, + "matrixExtent": { + "description": "Determine to show only one side of the diagonal in a HiGlass matrix. __Default__: `\"full\"`", + "enum": [ + "full", + "upper-right", + "lower-left" + ], + "type": "string" + }, + "mouseOver": { + "$ref": "#/definitions/EventStyle", + "description": "Customize visual effects of `mouseOver` events on marks." + }, "outline": { "type": "string" }, "outlineWidth": { "type": "number" }, + "select": { + "$ref": "#/definitions/EventStyle", + "description": "Customize visual effects of `rangeSelect` events on marks ." + }, "textAnchor": { "description": "Specify the alignment of `text` marks to a given point.", "enum": [ @@ -4928,14 +8885,86 @@ "textStrokeWidth": { "description": "Specify the stroke width of `text` marks. Can also be specified using the `strokeWidth` channel option of `text` marks.", "type": "number" + }, + "withinLinkVerticalLines": { + "description": "Whether to show vertical lines that connect to the baseline (axis) when `y` and `ye` are both used. __Default__: `false`", + "type": "boolean" + } + }, + "type": "object" + }, + "SvTypeTransform": { + "additionalProperties": false, + "properties": { + "firstBp": { + "additionalProperties": false, + "description": "Based on the BEDPE, infer SV types. SV types are specified as one of the following strings: DUP, TRA, DEL, t2tINV, h2hINV.", + "properties": { + "chrField": { + "type": "string" + }, + "posField": { + "type": "string" + }, + "strandField": { + "type": "string" + } + }, + "required": [ + "chrField", + "posField", + "strandField" + ], + "type": "object" + }, + "newField": { + "type": "string" + }, + "secondBp": { + "additionalProperties": false, + "description": "Based on the BEDPE, infer SV types. SV types are specified as one of the following strings: DUP, TRA, DEL, t2tINV, h2hINV.", + "properties": { + "chrField": { + "type": "string" + }, + "posField": { + "type": "string" + }, + "strandField": { + "type": "string" + } + }, + "required": [ + "chrField", + "posField", + "strandField" + ], + "type": "object" + }, + "type": { + "const": "svType", + "type": "string" } }, + "required": [ + "type", + "firstBp", + "secondBp", + "newField" + ], "type": "object" }, "TemplateTrack": { "additionalProperties": false, "description": "Template specification that will be internally converted into `SingleTrack` for rendering.", "properties": { + "_assignedHeight": { + "type": "number" + }, + "_assignedWidth": { + "description": "Internal: Used for responsive spec", + "type": "number" + }, "_invalidTrack": { "description": "internal", "type": "boolean" @@ -4970,6 +8999,7 @@ "type": "number" }, "id": { + "description": "Assigned to `uid` in a HiGlass view config, used for API and caching.", "type": "string" }, "innerRadius": { @@ -5001,7 +9031,7 @@ "type": "object" }, "spacing": { - "description": "- If `{\"layout\": \"linear\"}`, specify the space between tracks in pixels;\n\n- If `{\"layout\": \"circular\"}`, specify the space between tracks in percentage ranging from 0 to 100.", + "description": "The size of the gap (1) between tracks, (2) between views, and (3) of the origin of circular tracks. The effect of this property depends on where on the spec you specify the `spacing`.\n\nIn a linear layout, this value is used in pixels, while in a circular layout, this value is used relative to the height of the tracks or views.", "type": "number" }, "startAngle": { @@ -5014,7 +9044,7 @@ }, "style": { "$ref": "#/definitions/Style", - "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overriden by the style of children elements (e.g., view, track)." + "description": "Define the [style](http://gosling-lang.org/docs/visual-channel#style-related-properties) of multive views. Will be overwritten by the style of children elements (e.g., view, track)." }, "subtitle": { "type": "string" @@ -5045,12 +9075,27 @@ { "$ref": "#/definitions/DomainChr" } - ] + ], + "description": "Specify the visible region of genomic x-axis" }, "xOffset": { "description": "Specify the x offset of views in the unit of pixels", "type": "number" }, + "yDomain": { + "anyOf": [ + { + "$ref": "#/definitions/DomainInterval" + }, + { + "$ref": "#/definitions/DomainChrInterval" + }, + { + "$ref": "#/definitions/DomainChr" + } + ], + "description": "Specify the visible region of genomic y-axis" + }, "yOffset": { "description": "Specify the y offset of views in the unit of pixels", "type": "number" @@ -5060,10 +9105,8 @@ } }, "required": [ - "data", - "height", "template", - "width" + "data" ], "type": "object" }, @@ -5103,16 +9146,20 @@ "additionalProperties": false, "properties": { "alt": { + "description": "Name of the data field for showing in the tooltip. Will use the field name if not specified.", "type": "string" }, "field": { + "description": "Specifiy a data field whose value will show in the tooltip.", "type": "string" }, "format": { + "description": "format of the data value.", "type": "string" }, "type": { - "$ref": "#/definitions/FieldType" + "$ref": "#/definitions/FieldType", + "description": "Type of the data field." } }, "required": [ @@ -5134,6 +9181,9 @@ }, { "$ref": "#/definitions/TemplateTrack" + }, + { + "$ref": "#/definitions/DummyTrack" } ] }, @@ -5153,24 +9203,56 @@ } ] }, + "VcfData": { + "additionalProperties": false, + "description": "The Variant Call Format (VCF).", + "properties": { + "indexUrl": { + "description": "URL link to the tabix index file", + "type": "string" + }, + "sampleLength": { + "description": "The maximum number of rows to be loaded from the URL. __Default:__ `1000`", + "type": "number" + }, + "type": { + "const": "vcf", + "type": "string" + }, + "url": { + "description": "URL link to the VCF file", + "type": "string" + } + }, + "required": [ + "type", + "url", + "indexUrl" + ], + "type": "object" + }, "VectorData": { "additionalProperties": false, "description": "One-dimensional quantitative values along genomic position (e.g., bigwig) can be converted into HiGlass' `\"vector\"` format data. Find out more about this format at [HiGlass Docs](https://docs.higlass.io/data_preparation.html#bigwig-files).", "properties": { + "aggregation": { + "$ref": "#/definitions/BinAggregate", + "description": "Determine aggregation function to apply within bins. __Default__: `\"mean\"`" + }, "binSize": { "description": "Binning the genomic interval in tiles (unit size: 256).", "type": "number" }, "column": { - "description": "Assign a field name of the middle position of genomic intervals.", + "description": "Assign a field name of the middle position of genomic intervals. __Default__: `\"position\"`", "type": "string" }, "end": { - "description": "Assign a field name of the end position of genomic intervals.", + "description": "Assign a field name of the end position of genomic intervals. __Default__: `\"end\"`", "type": "string" }, "start": { - "description": "Assign a field name of the start position of genomic intervals.", + "description": "Assign a field name of the start position of genomic intervals. __Default__: `\"start\"`", "type": "string" }, "type": { @@ -5182,15 +9264,13 @@ "type": "string" }, "value": { - "description": "Assign a field name of quantitative values.", + "description": "Assign a field name of quantitative values. __Default__: `\"value\"`", "type": "string" } }, "required": [ "type", - "url", - "column", - "value" + "url" ], "type": "object" }, @@ -5266,7 +9346,14 @@ ] }, "domain": { - "$ref": "#/definitions/ValueExtent", + "anyOf": [ + { + "$ref": "#/definitions/ValueExtent" + }, + { + "$ref": "#/definitions/GenomicDomain" + } + ], "description": "Values of the data" }, "field": { @@ -5323,7 +9410,7 @@ }, "operation": { "$ref": "#/definitions/LogicalOperation", - "description": "A string that pecifies the logical operation to conduct between `threshold` and the `measure` of `target`. Support\n\n- greater than : \"greater-than\", \"gt\", \"GT\"\n\n- less than : \"less-than\", \"lt\", \"LT\"\n\n- greater than or equal to : \"greater-than-or-equal-to\", \"gtet\", \"GTET\"\n\n- less than or equal to : \"less-than-or-equal-to\", \"ltet\", \"LTET\"" + "description": "A string that specifies the logical operation to conduct between `threshold` and the `measure` of `target`. Support\n\n- greater than : \"greater-than\", \"gt\", \"GT\"\n\n- less than : \"less-than\", \"lt\", \"LT\"\n\n- greater than or equal to : \"greater-than-or-equal-to\", \"gtet\", \"GTET\"\n\n- less than or equal to : \"less-than-or-equal-to\", \"ltet\", \"LTET\"" }, "target": { "description": "Target specifies the object that you want to compare with the threshold.", @@ -5351,20 +9438,12 @@ "type": "object" }, "ZoomLimits": { - "items": [ - { - "type": [ - "number", - "null" - ] - }, - { - "type": [ - "number", - "null" - ] - } - ], + "items": { + "type": [ + "number", + "null" + ] + }, "maxItems": 2, "minItems": 2, "type": "array" diff --git a/docs/user-interaction.mdx b/docs/user-interaction.mdx index baacccc..df261db 100644 --- a/docs/user-interaction.mdx +++ b/docs/user-interaction.mdx @@ -1,5 +1,6 @@ --- title: User Interaction +description: Zooming, panning, brushing, tooltip, mouse interactions --- import {TableWrapper} from '@site/react-components/DocComponments/table' import GoslingSchema from './assets/gosling.schema.json' @@ -168,3 +169,38 @@ Corresponding specification: ] ``` + +## Mouse Interactions +[Try in the editor](https://gosling.js.org/?example=MOUSE_EVENT) + +Mouse events can be enabled in Gosling by defining a `MouseEvents` object in the track definition. + +You can use the [JavaScript API](js-api#subscribe) to subscribe to the mouse-related events, i.e., "mouseOver", "rangeSelect", and "click", to create custom interactions with the visualization. +Refer to [gosling-react-example](https://github.com/gosling-lang/gosling-react-example) to see how mouse events can be used in various use cases. +Here is an example of a track with a range selection enabled that enables selecting a genomic range using the click-and-drag interaction after pressing the Alt key: + + + +```javascript +"tracks": [ + { + ..., + // highlight-start + "mouseEvents": {"mouseOver": true, "rangeSelect": true}, + // highlight-end + // You can also specify the visual properties associated with the mouse events + // highlight-start + "style": { + "mouseOver": {"color": "blue", "opacity": 0.5, "strokeWidth": 0}, + "select": {"color": "red", "opacity": 0.5}, + "brush": {"color": "purple", "stroke": "purple"} + } + // highlight-end + } +] + +``` + +The `MouseEvents` object can have the following properties: + + \ No newline at end of file diff --git a/static/img/doc_images/mouse_interaction.png b/static/img/doc_images/mouse_interaction.png new file mode 100644 index 0000000000000000000000000000000000000000..9bbae38b5ad6d66848e23fc9391adaed09127601 GIT binary patch literal 27598 zcmeFYg;!k7mIq3LyC%51yEooA!QC}jfZ&ZgGz51iSb#v#-~{d9k^sRac%X52UX$?O#W$tIA`dk)XlB!C@*Y05##@;MZaI`6x)R?WVTlRO)UnZ|&dNz`-d*r|BW&@r{61R@=3Qt^Xg$a4cjX<5FHEk|j`EIj{GRS6 zvYv8TIY`hExO63lZY-~&V6Tx*Pv*PW*OQxQ_ojR4(#322F*M~rD zO80%&&6xRng~#Y0m%;=T%L;MY3*@}>F8fbdj&4G`efr{rSgB#Yjtl*Hy$nLgtbNP*K9> z;MS=uynrpCYH#on>Zl`G5!eYf8#btBB0#tjoLstV4YIkU#o&mU(r5z}#GoYF^zUi? zzH~z|wk+qX*2nW`0V<75v>dpWXpn8h&~Oy64z<_dNDQXdbu9a^xh%#Fn4Wv`evCSP z4L$5(>sDVXTZl<+%`7`bkk9O$a%3=hVK?#_@4EEnMNf7snZe_Gjye9$L}H1Oz6nxF zaXvx{2`Y7Q@2VWm*aV$F{sdch1A_zW1R7qcy_AAmw#dppT40k?G|N|3C*l4rR9m;8 zY$gd7)qFa01Y}IOb9tVJcR*O`HC`$dkuM%4E&J$Di zL(*0Xq9?)=SkS|^G;P$q%5~rMp5|y|hfrztXK)&8HplA{+s&!0;}6|s4H3ps8Xk=D zjD&C{tAsaDsMFW|_K-hc{dcyXUIbrN^z`&tt+xKqf+Kq$mGJcQD3>2TP$cz53n-Np zmvB(n*q5riIh@3Q@;n%q3x4LkxN0{h=!FChinJ6R7+%qwXH*=%+MPQS>20XbM}*Xn zEpyB{IDs%HbHX`vtWe+gWVtVPdS1Q9TzYx6wzvC|Q;HIVjf8_hO|2as`G>k6jA$7p zM2!JKMg{gJ5z(P4N=@QY(@4FgIZNWPrmuf7AEQl+oLD?ayoom%xg;x+M6ro^O8i~@ zl{Pv*kp1URCU~173p+9q)Hm{FMY4ZhdN8+PeUZNU==q2E9L*Q~K+>$}fv7u`n|u_Z zVStDT{R1Sqj!z|atY4|ltqQI3JIPu=XNafyw>idK@YH(|XKcOqC=?0qCl%N4{82k! ztVYbPja_4Q;2-sM;g%!7hm!ZCbTh;G8ixvU07K!@5 zP61~@h#~ZlI7k3w3L>zMZz&NCoTQyk>QGFg!(uMbmNrydkP(q>Q{AHp(AL!D(RI^A z(^S&MV|m4z#(JPDQsH5;+d2tnkoQjNl1@I^XLEPcX7gZE?o`K(&?mS^s;&s6wa%24 z>XYi3YB(%B3_omSV`HObgS};E6LM<2wK%5~TT4yH3ZVLPa~NoK0uG!p(52 zdf131%|Y>^m_h5TLb>ACbi=g#bi!vo9b}y*7B$a!hX{wfJCxY52LF&F%no$gwc8@cV_;=-z-o z=k(Q)RF-IqTS@4%gLeD37_q6&?#}+sDX9VKrNX(wm9<}XXFrFE^jc$@-+|}0F z9=+_a?7K9!thL0tyhv;q%hZq8FN+--)ipqtut8A(SO%PlVf#LA*&L;9H7-{ARsGU` zoI9{80Ok0)cQpHYU;hZu^l!TMxX!+I^RM)$yvw>dx%avjvt8ig&GO5vxhH@4{wRMh zQ426=&@Y3p4gMWG89XC7)_vWL8IlmH5;hs;5PBPG5@w4~fJGf19#Ms2Z%bO=y6@m+ zR_^zw>c=)$TJ2mdrbR-ZQ{VTsxQ!pKg&VqYemEAm)Uo9W2ub^cI!V~YRYjlV$UiX1 z$;;{iB|Z@2^YU&>v$1e+|v2M8+(GYiW{WcRXJxL0d9TR7(os%q2hW$p=kj!lcZ zW`g7?k_DM-sLjwH2b&eD=(`j|(EZU^(8N`hGrh{yi`Dh#c$U3x*LNpAgvJEsgiQP% zx68KYabFo7HyAZAvZZa%vK1WT&S@}Lon89f+P z2^bVQ4;E(womkEB_<1k#*b}TMSA%*3PEYMurZ`Q|^EC?6Bm@IZmk*``IvC4$7CxYI zwwcD5Vx6boSDe^xu|oBto=)#7OI`fUW*twUJ%Y+Bd*7CC#P z?^>Yv8&eSz(FFzADtFSi^@o*Xv;8g>s}va97+5hvmht;~aABBll;MAmslt^j!u|OD z7|SEo`IJITv)V9>bFHS|DW94}3fFl2B-Tdwxcn8qHb`_SP%5A?8V;!O0(=Hn-f;Gw zbfI$SGEI}VH=sLxu%<$|;`eH%|HO^VibO$(_AkVH|3|_}RDX?%d?Fw$qKL84SA6^C z4IB&X9t95J1qmD??Cu5Z5`RJZU-xn^nBd_5K7R=Z7iABJ@UM4NVde8D5q3S({8Pdw zN5Ub)e&N9`(8rhmej9%MBmBSb;qqa1a8g<_ii)sO%gW8h#@XG@#lzjNB@Xrg^}T|D zI~?3=`seF~q9)xjto<2#ZG8{@H!31lE>0X4)-IMd93ZFn&+WhgKq9bPCmRn7Dv;AV zXLk{h7|q`|L}2&Nk2z_m{=VYjC`P0IMx9E=#m$CFfP;&Ji$)xcii!&0X8l$~6DapD za@a318aoe<_adB}-rn9E-n<+xZnm7|LCxp4+vsbn)~MqoH~3=)XSyjMD~W|KB}1yZ>uiunBTL*Kl%kaB==u z+b~kV^HULZdyvgL1E9SVjAyVu#JTx}0Ds^AUp4>T<9|@<|2L(uFyDVt{zuLKq||Y@ zag%Xzf_3R3{@>#I7x8~q{)-U6`8@Og;KV;{{`(ZhXK^$D=YPpe9PJI46E94RWcENc zZCD9gWPd+uux}>V^<2U(@eh)R#Wk=}PZ21k4SKPkhnT6OGdn;?zr36m`XV$0T=el{ zCJ`qR3mU^q8YPsX)VW~GFrtovBiwg_+JGT3(6)h4aKY6FZloW3*FS_z$FTV|GSbZ z289SWfo5(djoKWA=w)Q^|15w@`TuVn|No@_&8`10vMB^iUF*CoaN3W11V?_#Q?d_G26d#e8|j{I zjbxNKD^ad*Y}gDX)1UTXOQ0OJHu;=wYj%K6tbbh{F0)EJ-8YODNUSyntw%E|Ew_1= zn)ieb?N#g7^{zEJ&T`DI)D2LumMWzw>2j8G;^EZl~oooooT8y#;oyPb&IC^p2yQu>BR1 zNn2~thjg=@PW68>AJl#!@cuX`4ypc_ez$6t&)%{|K z>J&M=^Kf@Hq9*aMX&u<=wzavLqLyyh=upaJCg{Ax#QSzM5yl?HV!61@aC}u1qisrY z|G6>DtS;LL3j6u`QZn~ZZp|WKwDlPRdjI*NOIPcvn#e94;~DxZmei`ly9p`t=cVi&1pa>(9dXSU8e`F_<`(3&m=;uI3o z4pQfqp0OO)ipiZcPO}wK5s&h+7zay1^UGn@8j#Wt6Qfwg=(axl+w)zDtN9q19whTY zq0&k$b&x!N&1ssug-UfceZ0qP;Kf5}kUL+5qp{T)$}?;`%;;;0Q_!@!~WG059d>2{4ePY22%A!vnGV@xiy-Do*wf_4Dkola;oA6 z{V5q|sNdh-LTkw5qw#A6|0?`V3j{jsiRDie76>$okYD&v0*cfZuivM}RN=W^h=a`h zPa=2;J_1UCkYAMtse*&92^386>t#AxeVzX=N6`J%%*^bpG>R8N7WnoB|ZdPJP9cQ^TV4k@`8DzC@3M(545{LZ= zC-PD{2?<)JJ<;4ZLaqm)i0G4KDGzoq3n+{qqJZbR$s0M#J1*2WA^Hd`iu)EZ_Gtsf3&bMrQ0&ikkRICbreLr^mZI|AXcBX2%A{+3Img zJi6;b_hc-yFIRt*T%WVjJdDHua?|Zw;N33 zDZ~~wC?+%Hz^(kGVH}YLl#JW+)h41*TE22?KU^1V|GErrv@hi#?i(g?y}6pFm!E); zii~u;ZuJ|n7A8lcHt(H0Z;=QYnI17r-XR{`SsbM@>yPgw_w5DgX&z^cT!bw#3nA{R zJsZcPyc0s-w_ywK>iDZ9@Thf%VyE=?uPZp2e2sE-Np;Q8Gq<>hGfE0fz$&O(!|pgW zxNm>HA@7QW=jmjCvi(S1m00j6Qs*fc4@oidd=hIIFJRSeggrkJPXzD4Z#YX7!K|<6 z8%!073B}SK@mnuJ=Nrn-5G?#9Pm0(KzYdxt3~a^;uDrLpykgP^zGc_ntI%uEBkh-Pn1?Us^b?4QJUp#pI*Q}F(>RZ|mNi{@VNm_&6 z3JfcDfcZq1O_qowZZ?{;Xa=P>+f!FI87A9O*W4Yqr=Gi$r4-gVtsCs0j&>b3zZ0R^ z+nQW(%g&rG(`Oj3#}?sSzJNz+;kFREun~8=TK~Z5b=KRRV>pfLcKs>G*$pJw8*nqa z#D!DaX})BmLe%TYn!(#?`QvhN({F}xu+>-HnpOl3{y0x@@Y{vUSM zfAoMSLM(Xaf{_aT%r+@VL5c;LrH&Kv)D)kjXPWxfohzvFDlIS#T{Ar|gcu|Sp%w%r#p^0}4rgd_i zDc2~@wFH7n4&l95$O?|NGPr*qNO6b3;fr8hnk(9Mm}L^8 z(OA7y>(A8867{Y=)0HgIFxBW}Y7<;$jt|dY4Y*pSK->Dj+4*OXAF_OvtVKwRnD5;W z5$i7xO-8jCaK~p0uiW_FdeTp-MXpub`3+_+L;ldf)%6KQQ)6eTDG2aPX2^)+M)BdT zVElxLqE(O!IvZPxZPG@{&R}hdQf~|rKVEXv1j6hT2Omi*c68qv`Yt-=n*sA^y&R~_ zY#0>}j=?4tG)zJ_(3UI#a0*T_0ewxf!BOw6Omf1}?~+Uu_1xQ>5#Cnh!>y0QaYd=) zJgZ1}7p7oUUOJYF=2V*=LR~+TQA6Z=65n8hoHfxFc9rwPrQ^1TKfEa*bd0R$FxP$D zRZh2eFzh?F;J|Tk9aU+OusT`DCl~8Z2}alqC~8^~(0`hTLmNyRE^i~a&M8R5B1g-x zO8lOyV7g|gMwsm|C=nPfn1b=eKx2_lIKD4am=(M<06R2dHHF=kv>FcUCc zTzzwrMSqX_A<>io`EoM?&oz~+13ng&p3bh$c0ynn9)b8fK`CNs42}#zmARCZ<)KNN zhieN$(AlchkB?Yr)s(jbE=;ye7Uy9ZHfy~R<7Zg7j7y~0@n&* zWIgX)79jePc4BB+>f9HL>#t<9L_h+61ocrW5C{PzOfE~59ZKQSNLT7^K^jZyy4;}m z68t9#vz-BV))qNSw)wOeB%R!hb7g;*!W=amHC+{vTWr;p*w_7=gQeDn6x>7!Yc36; z`!U)ea7Re@Nfv*Y7Z(zq4#FC30zy4P)=`QRm{~(8(G0`y>(SF|Ae^*f5Ygpi%1saS z{wmRsCOs2ANoX)n^suFG$VlAE;~d?Sn@^K)esCd#%nFLNf%$rq9Z9`E?u5H^{fJ$@ zvpydIT~2XE>J~l>msYN&Q9yg!svJ?PR+ho491a}=$(WF>N`q(wwb}NILPf1Eb=Z8$ z1PKKj5h>RSUVeOt|2ic4&_HtgF5i2vA)nVYAAd&w{f5EXV?^X$82%lkhxywVqn^4s zzkjR%>$4Sr=EeQ)psHrl0HsWbK-sX5c<%P}At!iN^tKZuGcK1Cg>;g0DA+*eHN#Yb z*XGrjc&>nLkbZ5+nNgx04^+?QUM#6k(~kpK**}uA=qJV1KBrnw^ymjFSS4QHIh_oPb?3;E6V#YXMFU$IhF|o- z`+eIbbO})Rk(H9s=)(z<$Ec56SE_GTm&HyVKMR#-{Mu!{dbt9Nw~G?slEen_H#zHx zeLmE^q8VBhr#pcuPB#eAP52Tu9#adZa?p6g5$wM=A-6USH5y)UvepX4A( zLxcXYX;Q?5SRz%TKnDvp^Binzl43dtS!?{L?Uyt3NCRt5U@p7xDEtO{v<&w?5;`4` z^vL7RM_fLAWPrgDS0_?2xLoG0b3fv^VL6&VxDhU))vP<_0`F$nrK)a|sYjV&fdNU& zT0H4R1u^pRrp%1NtPB(ZbNH*Qr8))^k$#w*!y!8qF7nlCW^X!NEPNqPf!~J{l48F< zZMzdcO);ON`$1*cDZqrXw`hv{cQiE=>il@~b&}WSuiakTp%7YQTSi1s6b&B{5HM8j z(T!7Es3wAoJ0c8E!}?S{fRUj#n*k0$GTDB$+`dk!p!=_Jy^&EQ5tv836nNXwSHjxN zv?>&`*b|t3omwnR;lHJX0=do;+nBlpsOY zpAklk#_$9gK-c~02py1&rXYP(?E~1>OD^14COk=&D3$tbklmWIUwyN!OW-D;w#?^u zcSt-=$~%nKs4~JnV0lOHwdC|`Ix)W76&Gx>q#GiA8L?>~8@1WILwHCq8FQ|#6j4_K z^MPcrVoapJ4Q2=%{@!@oD-xaX+yR_WTt5B|?iI_-;HoGRI|DzeY1@3CPrOVGHo;(| zWH%%m@i|K(3+GtO(70;JqLv?xNGd0tR<+$Yj^Cfpf3Xy zjwe73i=+r+#GwjG=`k8reeXnYgRL-#K>5%6B1H)GB9l#`Mn|6%B3Sr3A3v2RRo#pk z{qW@NJrh?&gw@?yn6^x|J+C(Nh9H1~sh-IuoJJbLScx1imK-QGk0=2a(s+?*lgg6Z zTu5|_m>`5ks>HOCIn7hHaUrK@Qz^w{FQ-Vaf=iQ-k*^M1g~K_YGyf`OVRa9Zzb{c_ zvMC(?n12Ax&-mIa{2)A62@A4-*e|U4tWo<|1d|T-2QG_2$G%p7!ojp>VF)R!b5>Z?Z(3aa| zfY|ztvp+7T0qaEiJ<;r{quly)qH+7*x#F&f;aMqMF_5IPCR&E5L;VAGOEZ=-xzed- z!|s~wbNGp*V@I*lb^=#B3sar6d-%gvx$A!j0P~yXR3l#m|Ec^qy0c=5f@HQQ`N!ZX z5n70Z9*YQq48>BmIp12<>;2W0r+6@3c{aH`zG+OYzJJxrLqRuJI3@+r5|Ib6)5Op6 zwG0S-9kau8?Pz5(1$nExg$^Srq2*hma4X>}5wCfU3i8?Gl+0dHL`81joZbB?PRLCT zpA}Vzr57=(Kq0Uwe9dV`uvZgx9s>XJ<`Vr*>Lk6Gsi@ZVN!`@POZpY(YM-?qB;b7i7tSCt z3KcC^`Dt^GE{#e7I4YkuUS%M7u&Gp?h9X;!#-l%pZhbV&`dxT{OlXo3$mSsw@E!UF z3kxtKm6c$TexQJ3Nz+BOIw*%xTWA!29e1Gjt^xJpd|~m{BDkIfOSAf%cNmc#a#$lJt8gUZdJV|RLX`C5P4Cbf_k~F z6Z6DcA~1?EuTod%iXzu20;o%m-TOyK;8hDBZvGGcqptRa#%cDiQ?Ml};3Zgy*>?R- zQi0U%Z$z78TOBhIZGX6W{rzPEZ}=nvv?l4b2 zBE*sIzW}<1gEtHq?#U*23WU*+I9tpVykr!p(HMZFTZxy)az8p@UZ+Luw3V9AkG}QU zwKO|q0w#$Uwp1yw==_DhBl?Q?th|#5Igv znutE&CI-+iDftzyp3;gTJlzvzlKdU^jT!_mfLiTDyg>{ti@XgpW{@4PawYKYKry)z zaUk+4?~4=>3sHdt!wg1jJCF~@Q`Q3x3ec~A!`@Pj>nce{e1njrnBz81))A5pi11P9s18<}4bkoMvXX{svF#b8G?X;>b+6)T*G0Sju~FkS@C z(O$tNAes^-uS;%g#QS3l69)(MVh+hl0X0Gs%XHP@Dxx$64ElZtxTy@%%0mi?+{CO- zc{hvUki_0Hxrf`~bt>wMMIzwwuJuqCCKPN&our_ks`N}e9|~=@Ca-4q{1;IYYUGj z9EpA%P$t>%@#1To(>Ew0R;Q>ED;WJ!LQDw6^jRk|9^6Hea}VF*m?A(XgNdp|R6#Cu zktiM0`xmx>qeETdnVDF!m23mME8Q?&-apWyQ-#r4%A`}>p;|G#Be_Aeh-JWyvZFaW8IJS~4(qO~$>VxI$Sw!$ zXr~iLf219bzN9K1e7pHtPP?}@8bpH@dxU}w6NAB8(w9Lyp1v?tB&|&$o|IK)BK{$c z__|lI{xqZfgJMO6*A!uFr=)5PYS*n4$!Jmxd*D_c3cz{zM_z_ljLuQHaayxzY3X!c zh8fZYV5fAp0V!8#y*REzyvpSOMC^NQs73}f>1H&GAHFwXHn;ZzNQ5IMNea41x~ZbB zg0FhhDU}Uos~@x)l=7C`w(4Hvy^6Tou-YSOe)^jr8Z3Tx=!yl!i>Kb!kn1`R63o|Y zAfaS1@R63n)n~0xxPs|`*rAc$sqT<@E3$L8@OaiQV(TCTl#4Kw25j!7CQ6}OEhWshHxr@jJE{EpyR_d~Hm=lRgvcM)io z7>FWDfzVY;AB^L&7a~@}6qf6!dKb7RzUCx3FJo|dgfCQxb2Cgzy%{Lrwf*}@Cj8tA zL$cy*2Pn$4$n>s4lJ$?x{(Lb7w$@NVwDsiC^Gr&H=hrLYar+PbH+*_`|-oP zpE+7MVxRy{T#7_cAmb{Pg|+kmd~8+ETqX&wZGsTw1DHaAupaxSTVx%-DfMlZuANBz zOM^%aBAzTwDLLvsB3?%oho|E|yvS%qm0a311&Muwft#$1HrGiS(=w{{Uesq5A4Ugq zFyx2?0ysIX=NKo+M0ZF0x8Jk~Lm5t!p}XjP>}ROMdbQup_ecEAyznZ1lWG&=Tj#$I zTCjeQ>U1mM`j~hP#~qs)bS){)&D1!yC>rYXlbP8b>Iw77Ag~mRgKRu`YCPt7^+SCoW5hi6N3Eycz+sY%1Q;nnX z_%te;%Pr~Je#Efw7v-D$jLD^q1+a)ALh9F!&8 zCAia@2(2u89iS1R#<#>?m(Q_XgqB*aCo_G@sU(gcqzuJ$V*dH6@wi+r~?N$6!bKIeh-_0n`S);Sy?I67dmw@b8# zX)FQN6af|MjGw!seT{)>a)N4s+I?VB{Mj>8OvEBnE{&tE_U35vT~ZxQ6SKW9xbL+P ze=Ymz?1gjR%BG3`Eb+o(JY=3gzcRgYW?0{xZG3jhV1CW9cO}Be5Z*;kjlDWL;jc-uj8(9>5qzV#Z?2TNvD!;1{s!bX}4crR?upAZBy0eib+9##6u#ck{W#WLiBN z*hzC{;1`fZZXD&Gg`MA)Hx!5JQ-d@G%LjmdeK@F|we~8KLupHO^IGKn@o!2{xMlCvUfk;o4q=|^oj;MLhXf?=OADw% zFux3Dss}Qy#WR-*?4r|D`;o}@Vam#^$+WwjDLSe43}+E*DG4DietkAEiS9U(rc~Z; zcdJfv)&_=|$2s{w*|X2J_~6^@#$&Ao@c|VX$^KZnYYt_gw%ntB)RcLQTKxV-MW^&74uqQvDv$>sWrbHjIkM z*~EF~J}i=o|Gtj`p@B*NVf4AhXA5rV+44QIQ9ND;r}ydUk8K*340_dS(+;)cgS!;0IIVh{0GckL?H@`WqN8g~J+I@(^_55Pk`x7hV^bqxx$Z z!D!FjzHIQc{M&7{46NJg_ELdD{pX|28Sn0Y$=COJuoN>hDSt)OiVAC_b=P^p*bMZ@0$J!ZG$%c9O1>gEd@r6nx?Gx1Vzu7bwK4zA*mfnH&Cd zBU8&?TQ^ajJuvX1dDvf3!N44_ZqY_(qW|d@E94#ZdWMOYK{fm^gEdO{hwjUR#pj&6 zX0aTm{Yr;VONN2izr;X`69UVaj>Ho4mRR&f9}hVb_$G4(J!YO$#;M}3<85wG z7kuy*BKc-ODbMpVU!2b6+eJE=-+rAEgoK=1Yp5)!b0=Qd=#+5qThM^~=vZw?KS9WW zvfyC7+FRxOP8khK`MQ|W%}fe%x}cty8b^yFd@%F9iSpIqm(t_?*~F%Vb)Vq8Gz2 z-`BT3$QCO@H&A4MAFuVDE;vq==v1apezl(hkG~94_ey8e3%_h_O=}^3_zxxwaa9G zRbwn?c%d1ViF?9@+u#7>grDHUmdBj_XyN;;bitHK!Dcl zYYp|uA0>N|vR=e!XzVSGQT)~rpQ6dn8txOJ^Wk~b(uNc@TA-99bYpLCyuS^+G(29HtBOC)RV$Cz#0~!JF5teP3AHfjsX@=~(bn`ZJl4plG&g z*Bkov)g?jp2j6-1V*Q)s$<3maIIt~zlRdvZ5Ww!SFDOIh23z}TF*Z$p5XLvzbbeQd zX)u7vGjJsD>y=8NVZC*_OQQeLwgDr9h&Y?c?tE6pGtgy4hHSag(}Tes4+ z7gfAmNzBMZJQT#A?%i*;GR#U~sdmkd7GlcDU{<3*9-4giS_b=RFbGd*Uxox_Q^3hxBio6Vber<>V;ndNQ^&c&4wh9}Qp}N8eKyaNqNxYK+^V0Xg3bgeH?UlJ z_VfI2Vdp@b&pFBPSJEVul$*?vngmM^5W1oZ1NeumD&?wIQH}3@hy9LGy z(~aH7E=JRAIyIF5!<8JqH}Uq#ZVdZXcqi;eO$spR%qA=`oyM3C>P^~7MY@2&AfDqq z#G-&nMaH4&3N5YCX%X*3}%}S*ss-oHt<{JiZk6{Q4Re^VN zR63uvqvry#k7^mC@OhdVKL-0c%}r!x#K2Zd*PeH~hKM^rEAFa?zGY-yK;9+OMiUgHlia~ zqN$8;wPj9YS_DMR5^&1S^X-02wQf~RlL5@lD?(V)nK?yg-z9~k?2k#bxOeRv zH1p3JYu*)^|12(5jccQ`s(73n^wD?&^K=Pbpu1lM;%9o!l2(D>B_GxC-$5y7@I=6@ABiN zBa)-McsaZQDKj5R#o4C!Icn`I>ZX}y4&xz!F#!rWU zVMr5xorLS2Fl3WKU&HGup{rn#LW+}9`r*M(H-UIeZ%6_Vg8Bu1t_FK$X34x1T)>IHZvS`C~r zw%}s_%FI(KRjJYG{+GnNc_z;f8L1B6X_|F*cARobK|k>(&(57StF7m??zc*9GKEUV9p|zUFAo0kftdz#Yyz^C53+cSWL@A9ePe`d_2H!N$ zaOH7bX1+P7!1(=k>twB0fX~U7j8fT+w>(=tWhP8#V|{lc7AAnGWfAqj+Y4KtjTG-v zr^=Mgct_{Sji^UVqx{E>X5Rx=Uni~QqvbaYDgkm>6e3jkkrMm2;rmZ~E={q1kFHtG z?>ncfO|>`xP{4s-7vSnP74qYJ{%ohsQFJ%62Jpn={e?0chLOrpwz-JKAQzdA$dc(OhH5)-O?2E{ zVl5nh$@H*D_5%a;It;^-5=G&w(0PBVY*1$zLBOmD6!G{&g$+0kM!zW|@3h4hTH8NI zoOfAjsax{d$#YIBe!{88;V>8u6_XbH9BMk-sFL z;~a3%f3nHrOh*^>O0twqVXY#jUw`zsx>z`kjL+6Cvz%@hq{)9sgzc=r*uGthuHh9J z#9=V95n2*Fd>T~hBcx~hB|gSEdWyH#@f9mId^UN8gB7Y_-NgRU=6bg0)+h_V=9i40 zl=)^&lDd28thDRIvK${SE&}^m42)jO=WmU~f#oG~8pzGkw+3cNghHSF(et<8gTa22 z8bdeLV(r#XA@G`Ax+csOO5=NRjy7Yro|D^|>8JbUCz_gK=48J^Qd0_DoN{J zY~3v2Dejz7RKG3Hy>O{=vtS+HRe_bl?$Rwq{jjVcFquNkcMvA+5`%`f(n7)|IVFxZ z!>LJxX8sy&UI%-fBZCwtupRcNweia)%!Z~B^S%|bJVGjZ5`%&E#y>L`be&@dkGBG_l)lxnYS%CxD3%kmX1e$gyC^A zTsm*${Ao-()HSkrP7H`ouJwhLXwi{YKvB7?g$-=C?iI%TzvY+{yFT){Oi#4-GY6e^KA|=tsm3V(1*SS77w-JHyl$e3G%H+1d*<}_TR$VuWnV%^X zIxZJ3$t1Wg+RY)xK0BE8*Aq58MH5u5l41*~TMIkndvQ;Wvu3CBAC3kW;-JYmC%>Sx z!zLS%Xe*0RNa9p^3!d+R_YK5mLq7&Qu-jOyU<)0FGxf+n;kN1*>h;fJI1BNI`QEC} z@Ui-WtAj;7iok1&`8H3-$mGUGm(`Vsf)vb$XVeCyz(=}ms6&#0+jV75%H07w)6Gq}V>%%=qn&n|58)`zSf1UyS_? zRM3l-#>lIAu_nE=GGpXVVBcm3?|9Osp6AbpG1t>Szkj-&o;W>Lc-Px9&wh3jQz7YqjGHq2bs;)ko7Nc%b&tBA`l^g^$B+wVKp}A2|>l*1f@BqIBHQ=?jUM-w#+KP7T z|Fxr(7NcW*nyIK+ytlfxHBIa9-#tgIw4Ys~1i^;7@;KG}p?h^PdUPT)(E4o!o}xof zJomApLwJpTnRW$0j2rZ@;cY#KPn%Y5#`#eFEv?#^+B#spasm~?!wV!!Mn8$5!jJEK zzb2g}?EYy4GU8%Dy-pc;U3liub-P!2dOE^6qN8WB1z66Ne}usY+pU(5)9-+}$8IY% zW?ka00GQ*I2*ZI0bMtbUdH}A)aT)8Dstg*8w>{xd@lLvM@q`P%pPc>?D=vN87<47i zVbW^cb_Hc#^gehGY1jQllFj%r#Y1Sz!(O*5=>YetX9QA-d!iDY-lH4~w#BJ^_t_b^ z1O^F+8CD270s)@y>Q6GRAEG8zZnNV|M&h?fZN3wBDdfgeFVNQ<;!cbJ0nV#ZH;+Bd zMGxhzk4oActZ|%n#nF+pIdFVSL-*%{qHYR1lpiMl0QftkE+MjcU1_FzbhB71qH^A3*N~seEo>{beT9m$WEPB_1{?;=t4O{WZhw1$n zB%hQZ_UCm&_*=X7DQRGda$sHQ;hQc=Lx{OFC)7F7+-`vMr@*_a2w}cQDIvy^c=I2g}1}>wfd~ zT%+_G^gdcSNG`RB0K0#>g@M!$#_hUbCql;3EwE6no$G2f@NO)k8#!8t;ysGU%2BCu zhKSqP&$qdVon8lqSz>-oi$>yJ`*T1VRWI*x8b)q1dIbn6zr*H&`2^@_q$Z`^?_x^j z?CF!1VavOu`>Wz+o9N`zv^GKijhQzjdFsHFL(inUBciIcGsOf&?u3>wq2;Goa2dKr zIx8&S!4r;a-wkeoZ4rP1u{{I~lKT;(zr0m2n#3=`9_rFpDVTRGr(8mKF$6YQ_b<< zf-m!fMrQtz+Dt~e`98lXm;9im|OwpY0IY_lbHBPPjyoNsQMHAw06v=2&;-IG{48Yj=WoJ(co_q%I=scb0a zBjZCq#>@lM)=}=-qM8HPAvsiBVm*}1!AC}ewR<>O`a$`V+@RpvZlY;&y%d;wO>hNN zjQ(b|)!jByW{P@!f6;laws2&6rQO@b2NpL+j2_Ur_EnP8t;2#|cj{f^z7>xk0BE>k z!e`%FmQkkd2$zvm)L?a}N)@(kVAy}{ls{=H6tl*(m1%<#0(M_>J@<%%W~UImjrgqs zZ|b-BgjXq=8G|0zSGRs)uX>c+KjmjuEuyQw_k4iK9kD?PVwZ~H`UPU1LAjCb9tO^uhRg==QF_I{b9D?sMeRF_F~K94Non|a+8QLnGs z*@;2!rnS^ODO^zmA@`Y9@ve7OC+S*3JMBiz&K$xdia+LP+ z%+b-msm2q})M?@e?k1HvJ&{6pr^-Yp0JAASA7FnXNr%a$5BGe4!jFxOrW5wh5@xNc z)Y$f*D!}z-ABnT6%1XhxS;a@AmmF=4?eDaDC9Xd`PU?vLPK8Il8j+b$OC((NpC=Yo zm?LD9gM`_YJg$I2dvm}&LfZ8tX&%P|B3u|78yT7K^nM|B!38Su=Zgf{H~jw{~vaH|vD;&SW+66 zZY899mz3_d=#pN#VQCa_r9(m*r8`_gN$C<{`3PB3y6=mA_ul8;`_KJj*?k`7ojG&n z%=!J!nfFXWG9Hm6PwF?rw+TO5z6m@S3VhwKY&U=YN-TFBrQvt;AnkaOCN%0CHM~CX zzGWAopn7WR;mC~eY%|*FaQ|pc!JmqGzefVajiNrn~RhJuR=2tEBn+gryXnTS^fVl?J*L6-HZN{3(}3M$4x@ z{3;L}>?hzIXVc~zDv%~+K93;~S6JaPj|GE(I2YuTBrpaf%i?m$KQ-TyRHd!w_dhT( zqn-z+43z$33~q-?jWb_7NaZWe*;eLShr6?#t|-tyl}DZ@((_neKQc!zaKUpASEG zJ8MF)NE=9leipCCY6hLT2FJpupMwRKC{Zg{CEaXirW;ABJrOi&V+>wT=t8M%;9_wW}Fh_?p$zx8# zLcNOnZUzl}&J5?L`zu*dnGEvLqJ0RtPNqd#M6ZRXMTU?as`VH)Q}X5dcPh7`YOzMv zHQ|aTt5Cprk-Cn76e{BoH)i%=t^ep`VRJLF@nur2^P=jA69cQvVAkqzJilpa+}6aw zii2Spt6?d7>$;WHTlEn*Oh8%ZvKtPIsfHY?0ZSAiI37=RyL)~`vDZ)ndxXc$xOwWO_}w6W zQz$8B^`?@hINW$WEPReYKZ8`OS|6KV3Wcbl@(&f{2Q?Hx@XRoKd(mG%v<=@?V)hPJ+ zJWHpiYK8~;zj>AwPJZuGjz$HM{)2swsK0wP*6Qe7__NCmW{GiK^Ny(t7h1$+V)Q^^ z46<%$M4C*em46e(#%ub?I(2Kd#k5qvl*`k8;_cl!w1nHp**xuv0fZD0AmUy0_9*7u zREo9s&J`1@PsAzzcfm2Spf(@otd4h|J-NP?n$z4N61IUGmK%K!=oMhyZZCv8(yeMCV zLKGqR9w{v-QRa33kWJNMvG}Be3hz*E`^$Ag<68fca-BH1C}T=TBx)kp;0Mde;sb*l zLGTXqn_~b~YWJg&Kt#wK@?vWK5!e|biPqGbxlXX|kK2XpmsDAX^<68aiHYHj8ZpHO?}dF`^2OEO}HHvay3m_rqLEycyOO zfasF&`5xeF<%B-3w*l$QF5wRq)VD_S-G*)8=-?5^#drU!PJzchkHY)3y9WMZnqHN& z>1k?-8xA}U=ilBhbZq)Y!dQp4$zn;o_mVEJ=Ndk3h-;nzS#Qms*IQZs3GArn8b9GM zm@E~Dh^V-H0>~SaAA-FrZr#Wmzw~ZLP9jp^z~Qq!2*Nl8$=q7~!~xN+Jaw#ew5VpI z_+gskLk#5RefEl!9KHcZTM-^(K)z~JTXpi%k4ARP^7BbDAa)O83J4TrdY2D@VqiE- zbVLP$22PqdGN+8@aB20+tM%-RHGltl(qoho7PK7?ZEzEnmh-Ck!FSKAr|9PW(>d{Y zPT&aP<^7s6zdGDVJENiuH{cN7MG8@^%7-XiW4^>2d`NGLv2LSw?wtjPm z+p+%1E_!4t0H$ZtG8p=ENXC3GB;QI^IgbQ7Mz?ns=GQ;ROEXqM8GZjulJ|`*$Bbg# z=hW4(Pr8M`NmN(Wb{kU?A29TIM87_8hDNVpTw(>0tL7+=`JDW~E?n;V zGFGQZ$4LgQ`pzd+xI(T@(X45CPe_7ql8SvpV9w^)+s$>T+08nYx@2l#gJ^``l#!bV zpc)*`#+5D*$pK;$>_6v?v?aJ63_mrec4x>^mudbS#;G&{sRbe;PG;2da!RU+BJu{B z`0{>7n)KCA{`^xuX(qY$^G$9swxH*LS3w4#)1^LpuQS>GC@fOG?q??++SEdOi(A;& zJEc!r3wQ%oG`Q@AV_B!L9mh@bTP2h7sw3jX*&#AV-eRUHB=OmMr;W%?P>8Hh^yv+7 z!@6upNc-htSmIT50o)sM;^QK8^(%0P-w)C5MUE zTiOdPFYkc^WzxGr6`nPL`H{(Zj%bq@@8e2{a;n_)ljjBdmQlwq6|b%qdexl1SnE;A zw4q%WS{=#jJx}I}xKBDeIzCh0du!*|vW9KzV9R;3a%a5wF8doQ&Acv)W)CY?_^@DLc+ouSBHgQ$ah{jd4_wvk!3NQ4qi4{fk<472%n~68|J-$E%_3?Z( zvBf}&tj~@D;q}#PmIyTk`L=;BUuA16Yk_KHL$5V{4^}5y;xZ|OGdJA_+k5F((X@B zJI@By`uE=%-A6>kh`h!#*4HN~>lKV?Ly}hpiwBh(-u%u{G$8N&eBZ&m6lVJ*xOm)` z-)o5c_i;l-PhZ0k6IoKz206UZ(k159%mLd5;%_74Y+6U?Vn6A(%vr)W9N@VtI5Rqd zG6wB7{Z_!86yru!s3Otq$ul*cbrtZD6O5~>9p7n+g?fG9kUqw* z^1kZ=F|VoFUwYAdLN^mzCf@8C-R!mQF^!e&);%RSAeo}bC^aW1&j&Nj-vTE+95@b$PNWlJ zTMYB6DyBcZxW4YUpcNs|j5+nR*Us`*iXB;XCpZp`D~~;!XV1q!hOMvKpp!QW;SNr( zE7L2GawD5@AvBFPzE^W&k^fc$jM4YFz zygx)0DT1`Wi~%io6s@deLHziLm(iT4^Xs5A2cfE%Mo;*<7%=YI4B;<4F+@F3((Sb@buw$%umVldFkOSIT8gb7Zb<0SVwr#EF@Z3aFu1h8FbpbHJt; zszXncY1tjQ?i+d$R8hR`@5crYOUu3J`VDDRk#ajdC!x1WUH=ffC|t66y;{uWoO8TJGeM3f~FHLpUMJX|0y2_s@Z3x=L3A? z&FBf@R^;jVR=Q~L&i1i)-7%S~;r^Vp2B-nLvWXefSO(+o&ji|ZZ(+ zK^N}E#kO#w1i;SmFXHjyU)0gRu^mcXD?(sE&G=n3p*0XQH{0`$p~xhmwv(LuP_s1$ z#s3~3rer4K(wofuEc*0kuWpjBTN`Tx$$V}4IrOHojuuFk)P?ueUu~J@bRTZu@kRhf z-!;fsry30A8~+R#&;ln4_$!s*jr2UQmLy@sBw-Ax!O6ZkW`7>1i=1Up&PCyAA+6Hk zfSpM|Gr^S&ecJz{DFS2EWhtyGCP%E36wOFWn{qJCI-dUzq^_RfJVoeP&d{-W>qU&`A~s>i@mJ+z`? zd=!xv7yEr`hRo z%Vgf6Ra=8#vB+YvXo+LSz5Zmf~ zz~Fmeox8jE%DH5>=_0I2!VG3pK(G*m#@^UMcg_K~kPzqjewO4$U2P;ZFw$3!o9xA< z^>n>?x#3`{3i3{pgf7q*H6MpE>J zeI)x?65goK*`6Ct_BpqVKs=+XicrdZ4U7?0Byq2G3@TYfzh29h8+7#`wwe{iPc66p zOpyKWx|TA@f~wMsUdXA)#so)eIo=IJ z8I$tTx{+qQ*cYim%YpLE$O7+3ff}w8qlFT{ANfvI9Dn^%WMR)>krynwhi4Sf_WT#d zWmoO-oDIq2INAjQUE6*AZE|Z_O;TLN3741=YVU%en)a7zdgZpyVqn^kW4y~Qvd}l- z0a%oY4>x6W(cjoaNM2_Id%iXMDF$yIUU824mT`0VmHsKwi4IVrRnnG4<|+n~2{Arw zyQqK*_0Vk_?Hl^Tvvf2qPj#{HbPIXvnIy%P&tbSCaqF5(zZdrn zFOo7xFKihQWqKyZn~BLJUOa0ds?n!;ewlZbYqk>y)4_|A5 zG*>psO&#CZOpfgk?fPM5NEkkgH_;m|ahm>)a2+GrKQXJg&T+Rue)tkd+synx*M71G zE4KjJ>OPQsM|FLX$zg8f@Too@{=ABcg^vCfEuf3)JFv)NagZ#d}j_c^QkQkF&u$ozs!VDRP|< zMwXi1M15t4!%Cz&3-=S~LjI$Uv!``K9iD6YjUVoq?q0jw2$bcUwQ`~IX2{YFXoF=^ zO7o}OiarA1&|@X4w2*dfYR{L-h{9uzuzggn7?xtP*;71Vtv*Pt@^F^NWOI8Jc@Cn> zFrZ}lA_tKluBexKoDt4X{{hb5&N(nBr-2;c`MB~`>DZEh+1Q`3a3v%{umCU3P?ZOWd zU{pV>zN>J{A@hoICL)d&IfW*}%Gqq*evA#@ujegu6f;p6586Xom^FW<36QcsdKp#E zZXq4IViyM9As!j4$%7+?zkN;FeEY5!-w9uhUO%?3$B!_UAnj=Lh0_$rw_esLkeygt zHD_&GHjnH3&op;FQ{1Ty*LzVjRg+F@7VpvB^xbrILct>e7VTtlJe$lSN%X?Z$aX;ihzC}`~IG}SA3G%$O8{WO7B}j$mdnnY78u>1>Z^8`qci zs=;+H+L08yv=Bx%cS0N9iM5`HK-Rgm$7<|*W&Hl6CC`P!Exz>j%n8X_!{=BZ?QfbK zoeJ3G?3&)^&GGf}3+U5^%)g3!qMozWb@-Z}Q3xv>Y@y2U%J%>O+8r|&E?)K+m|f=k zm_JzAX$s_@-Nu zlIy@{(O*I3JI-q_oCv*&PPwHaQCFfKO4LPz@r|K%d2mYPm#|xyl*Qr$w9$g|ZuTt( zo~S}Fc!!|R{%a4(zMuCNG4GD}kfGJwIKuQe_I$Q2>|mB?_!V=QP<^-0l+Pr_YFphT zHhuWje(XBYa}{@B#*AmGl>2FU^n(drrN8(I4Vov)Cnj?0JxAW9r~kU83&A+{a13Z` zBz3Yr6DG;)?9LHs--d&mZpB@*Q32W2o z=BI~608f4t0#w!0fLA1OVI>SfEP9QO;Eb;*g^!WPb_IW9mQHkAc@uoC_a# zZKDTpBrX6;r{}e9ZR`(N{?Q-{BcM0FFIn0u!8oPi0M~F)xV0T$KiUs(0P=9l9|!<# z5qK-I0z#173i04}3jn0(|0Bc(+q3Sd@*UtXB@H*zZ-^3*`ZFN%=S!+AoYLUnXxyTS z4&yhU*|eg_HuW8Il>K8GEw%t}NcZ4qW@a9fg zw@;I$EuN@~9fVeeivzE*?3lcN1Z{o9F#jR&p%I!!mWa)1ywPWgXpL(yw`YiWFau|p zc#kP;z@LA)s1uI+Cg;^$b>Bj+2JNft12sVVw{x3yq!{wlKJ`BzP7&l<>z^o(F-|;= zlm|Pa`hTsI`p4VC$yE(4TH-ZEz-07&P9jyZ3ho81M3gF0%^l>?%i@lgGc~1wlrfE^ z!hz}LA*36;Z*{lnj!SN4rGMRIDfdKzx|wICv(;>ifZ&H9b6HaDncq@_?chPi2kd@@ zH0LeBiGGA7j2&a;=?09lIk4=o7btkKK`PjOra|h zih_YI&PDLp(P@TS5{P7`dLC1OX7@Trjw3A%rM zx8gkL+X(S>`Z5S)IY!kLaC2$B{evsNvifk9>P2xGqXqdsoH}Gr5^~`ZfRPnIXXH0TJ-wpu7OYCV&pm$$+byLC7a~;8 zd1?c^VQKwHG=O)pnZ4VaqRO`nk5E)K3;EQlYp$>e2R-2Y@9rmqctJri{*sXXivwo>_Ed1QbKK=nZvh7jxv=f)PHR z35~4zY7=*oQrorPJPGPGD=G>WZ75O_ORY9oYV2-k$V?PX_tL9S$YYZhOSdUWyRv$w z^^c!*>WH8>vW*M%Q#k$gOv;%~V!qrK*Ar-_H&X42Xr{!2%(Yng-Md6q)YaA1hUr+$ zv0|Hobw$LO1ugB}UHCjvJbwkbyDm9RdUl4%jYLdi;F3jYy#pO`trNz-?=T}3L_<)b24A#Yu zBC&T2nUGDsF^IL1vT`QrQoeOmJ21d!Apwi}-hqu-r7fVj>XuWsD=LXav)B zi64k)@)5xA(u0R-M{yz5%{093iNo#u8=~?c1ZbbZdUOAkfwg(@$7bC9!ciu=AF+=q zfHC=lyAZ=9Fit5QM zI(pl^;b!5eI+IyC@pN$1gB4}y74-?cvz0Y_#&Kp@IPq;&hWdSPec|I6SRkaz;a0Q^ z1au+$eqtkZN%+X`{AiHP6BDv#j1oCLdD+DO%i!q#+I-%W*JhGfJckh`S20uddOvamc-ttqam1D@zEtL zz*OKRiXlfjf!C>(d57f)05>Ip$Cpo9#=dePG7+pOOT2AvF)302Zvkk~lg4y7{HjuO z+L*DO6GXxubr?613pWhxc#a34$uP4lNQMYL;KGSAD<4|r^O8H(wTIUpoeGrEwP0TKa;;f@Vx`_C45wvtrl{=sE?+Ls|%MDUsZ!3lcn7tpCQDvRLFAz(1BB zAW;B1^#l1o^s46nAB}F|?0-Sx5)>5VJ3T%F+|j9w-?oRs7j=UL$JWh`j+FMa(Mw+j zI6AlCI8aZ|7H|cfR5CGAU5WwjOwmJFqQxYjkblZRnl~`?57`OEp#b8`c39+K2!O_s zcra}wga4kK|E?cVme0F}ouay_!TTTk247DeUj75*K$>3j|G`&4k2FBIUsv~VKn;r} zH#Hamz1)4$rp@iZJ#+ol^%Azn2wjK-qVBr{-pPLF(;42u*wQBQyoo;+*J_*b&hIDkofqmJtVKzvlKa{$PU9QxNLF_7*1(27-Y zpu|K^BmcAMJD{n3M#3F-ps5_t^m_Qna6>kebfxYS(-xgL1T>N-a1#lZ9to}bOH-6{ z(}8?TS<{h`7r?HjZ^bc>av%-%Mt*qm3L~bGmzw@IM{}E|DFp-JeCgVY=YV~9knVkk zThB@JqyK@{Xl++exBV{~=5+b7DJW$lE50bBFhQvwzQ)Et4hdK9jim;5m*Ekh%pe zr9Q?MR1^_MW8I0dNA*vXmBv-r;)+lx8!qOJ-!-ur8X!RvT>ZSZNOfJR@ng@Xqw7{C(j5WkNz+tKL7cRT8eYJRoz!!n0t@BADW z%(Px;E4R_gfA22g^QBRYN)wV{zlEVJc54EHr|%m-eoahxzu0V(LLejZBA0bb7fc^M z?7(OzOt#e7s2L4IknHF3zR)%2d6+34w+3fL4Xe{tLnJ>y{8#QXu7$!)$G&x z{A*spIAkGxIXT_6=U0=T&L;4}SKhF(v3aCqJ^rr-|NW!$F;;y1aJ)0O9)}^MRZEth z`LF3=lEAKT%o+o)&+)%#-ny?&EG+5x@hFP$RW*{2s#s+ErH)T1(*JCNTmw9NV-su>KhZ|;05Biz4D_(^hu z{XR_^+WX!6({Sv zrbapPeH2A24!5%yRnJX=nD!0J1YTb>{hr&-kr@8JgY}U1vybARSk=tBdsZLwOM2~K zSl+r>S#lCl%kHbdn)(yU9JMvfK