visualifyjs 2.5.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (147) hide show
  1. package/.github/workflows/static.yml.bak +51 -0
  2. package/LICENSE +674 -0
  3. package/README.md +59 -0
  4. package/config-overrides.js +31 -0
  5. package/dist/visualify.js +188 -0
  6. package/docs/.nojekyll +0 -0
  7. package/docs/docs/CLI.md +34 -0
  8. package/docs/docs/README.md +65 -0
  9. package/docs/docs/Rechart/bar.md +190 -0
  10. package/docs/docs/Rechart/funnel.md +193 -0
  11. package/docs/docs/Rechart/geo.md +0 -0
  12. package/docs/docs/Rechart/line.md +355 -0
  13. package/docs/docs/Rechart/liquidfill.md +0 -0
  14. package/docs/docs/Rechart/pie.md +225 -0
  15. package/docs/docs/Rechart/polar.md +0 -0
  16. package/docs/docs/Rechart/radar.md +253 -0
  17. package/docs/docs/Rechart/sankey.md +0 -0
  18. package/docs/docs/Rechart/scatter.md +0 -0
  19. package/docs/docs/Rechart/sunburst.md +0 -0
  20. package/docs/docs/Rechart/tree.md +0 -0
  21. package/docs/docs/Rechart/wordcloud.md +0 -0
  22. package/docs/docs/_404.md +52 -0
  23. package/docs/docs/_coverpage.md +11 -0
  24. package/docs/docs/_sidebar.md +43 -0
  25. package/docs/docs/components/dotBio.md +34 -0
  26. package/docs/docs/components/echart.md +82 -0
  27. package/docs/docs/components/html.md +34 -0
  28. package/docs/docs/components/macaron.md +145 -0
  29. package/docs/docs/components/markdown.md +0 -0
  30. package/docs/docs/components/more.md +142 -0
  31. package/docs/docs/components/plotly.md +62 -0
  32. package/docs/docs/components/scatterL.md +70 -0
  33. package/docs/docs/components/visium.md +57 -0
  34. package/docs/docs/configuration.md +123 -0
  35. package/docs/docs/deploy.md +31 -0
  36. package/docs/docs/log.md +1 -0
  37. package/docs/docs/more-pages.md +23 -0
  38. package/docs/docs/quickstart.md +119 -0
  39. package/docs/docs/rechart-attributes.md +74 -0
  40. package/docs/docs/rechart-basic-usage.md +162 -0
  41. package/docs/docs/static/_images/deploy-github-pages.png +0 -0
  42. package/docs/docs/static/logo/favicon.ico +0 -0
  43. package/docs/docs/static/logo/logo_128x128.png +0 -0
  44. package/docs/docs/static/logo/logo_192x192.png +0 -0
  45. package/docs/docs/static/logo/logo_256x256.png +0 -0
  46. package/docs/docs/static/logo/logo_512x512.png +0 -0
  47. package/docs/docs/static/logo/logo_64x64.png +0 -0
  48. package/docs/docs/theme.md +5 -0
  49. package/docs/index.html +71 -0
  50. package/docs/manifest.json +24 -0
  51. package/docs/static/css/fluff-stuff.css +170 -0
  52. package/docs/static/css/font-awesome.min.css +4 -0
  53. package/docs/static/css/visualify.css +25 -0
  54. package/docs/static/fonts/fontawesome-webfont.woff2 +0 -0
  55. package/docs/static/images/star.png +0 -0
  56. package/docs/static/js/configuration.js +448 -0
  57. package/docs/static/js/fluff.js +1 -0
  58. package/docs/static/js/visualify.js +188 -0
  59. package/docs/static/logo/favicon.ico +0 -0
  60. package/docs/static/logo/logo_128x128.png +0 -0
  61. package/docs/static/logo/logo_192x192.png +0 -0
  62. package/docs/static/logo/logo_256x256.png +0 -0
  63. package/docs/static/logo/logo_512x512.png +0 -0
  64. package/docs/static/logo/logo_64x64.png +0 -0
  65. package/package.json +84 -0
  66. package/rollup.config.mjs +76 -0
  67. package/src/_css/404.css +116 -0
  68. package/src/_css/App.css +38 -0
  69. package/src/_css/autoSuggestion.css +27 -0
  70. package/src/_css/circular-progress.css +33 -0
  71. package/src/_css/index.css +37 -0
  72. package/src/_css/modern.css +25 -0
  73. package/src/_media/404.png +0 -0
  74. package/src/_media/corner.svg +8 -0
  75. package/src/_media/download.svg +3 -0
  76. package/src/_media/icon.svg +1 -0
  77. package/src/_media/logo.svg +14 -0
  78. package/src/_test/App.test.js +15 -0
  79. package/src/_utils/reportWebVitals.js +13 -0
  80. package/src/core/appContext.js +27 -0
  81. package/src/core/components/Scatter.js +188 -0
  82. package/src/core/components/ScatterBio.js +572 -0
  83. package/src/core/components/VisiumPlot.js +165 -0
  84. package/src/core/components/browser.js +42 -0
  85. package/src/core/components/dotplot.js +413 -0
  86. package/src/core/components/html.js +29 -0
  87. package/src/core/components/list.js +178 -0
  88. package/src/core/components/macaron.js +201 -0
  89. package/src/core/components/markdown.js +56 -0
  90. package/src/core/components/parser.scatterBio.js +579 -0
  91. package/src/core/components/ratio.js +80 -0
  92. package/src/core/components/scatterL.js +173 -0
  93. package/src/core/components/searchbar.js +131 -0
  94. package/src/core/components/selection.js +193 -0
  95. package/src/core/components/timeline.js +281 -0
  96. package/src/core/components/visium.js +97 -0
  97. package/src/core/fetch/condfetch.js +82 -0
  98. package/src/core/fetch/fetch.js +92 -0
  99. package/src/core/fetch/json.js +29 -0
  100. package/src/core/fetch/vfetch.js +42 -0
  101. package/src/core/liveEditor.js +44 -0
  102. package/src/core/modules/codeEditorWithPreview.js +104 -0
  103. package/src/core/modules/echarts/common.js +20 -0
  104. package/src/core/modules/echarts/presetHandler.js +41 -0
  105. package/src/core/modules/echarts/presets/esodev.chromium.js +172 -0
  106. package/src/core/modules/echarts/presets/esodev.codex.js +130 -0
  107. package/src/core/modules/echarts/presets/esodev.visium.js +123 -0
  108. package/src/core/modules/echarts/presets/mmtrbc.js +186 -0
  109. package/src/core/modules/echarts.js +71 -0
  110. package/src/core/modules/echartsUtils.js +43 -0
  111. package/src/core/modules/echartswitcher.js +152 -0
  112. package/src/core/modules/replotly/presetHandler.js +24 -0
  113. package/src/core/modules/replotly/presets/minimum.js +18 -0
  114. package/src/core/modules/replotly/presets/mmtrbc.dot.js +114 -0
  115. package/src/core/modules/replotly/presets/mmtrbc.violin.js +100 -0
  116. package/src/core/modules/replotly.js +71 -0
  117. package/src/core/pages/404.js +50 -0
  118. package/src/core/pages/error.js +27 -0
  119. package/src/core/pages/jsonPage.js +62 -0
  120. package/src/core/pages/loading.js +44 -0
  121. package/src/core/parser/echart.data.js +183 -0
  122. package/src/core/parser/echart.features.js +125 -0
  123. package/src/core/parser/echart.general.js +143 -0
  124. package/src/core/parser/echart.hilbert.js +57 -0
  125. package/src/core/parser/echart.parser.js +210 -0
  126. package/src/core/parser/echart.series.js +67 -0
  127. package/src/core/parser/echart.types.js +76 -0
  128. package/src/core/parser/plotly.config.js +10 -0
  129. package/src/core/parser/plotly.data.js +132 -0
  130. package/src/core/parser/plotly.layout.js +10 -0
  131. package/src/core/parser/plotly.violin.js +18 -0
  132. package/src/core/recharts.js +62 -0
  133. package/src/core/router/alias.js +49 -0
  134. package/src/core/router/jsonRouter.js +31 -0
  135. package/src/core/themes/modern.js +32 -0
  136. package/src/core/themes/themeSelector.js +33 -0
  137. package/src/core/visualify.js +47 -0
  138. package/src/core/widgets/circularProgress.js +24 -0
  139. package/src/core/widgets/controller.js +83 -0
  140. package/src/core/widgets/errorBoundary.js +36 -0
  141. package/src/core/widgets/footer.js +177 -0
  142. package/src/core/widgets/header.js +234 -0
  143. package/src/core/widgets/layout/Grid.js +31 -0
  144. package/src/core/widgets/layout.js +36 -0
  145. package/src/core/widgets/mapping.js +42 -0
  146. package/src/index.js +62 -0
  147. package/src/setupTests.js +5 -0
@@ -0,0 +1,253 @@
1
+ <script defers>
2
+
3
+ const Basic_Radar = {
4
+ code: `const getOption = () => {
5
+ return {
6
+ type: 'radar',
7
+ data: {
8
+ 'Referer of a Websit': [
9
+ {
10
+ name: '2018',
11
+ value: [5000, 7000, 12000, 11000, 15000, 14000]
12
+ }
13
+ ],
14
+ },
15
+ radar:{
16
+ indicator: [
17
+ { name: 'APP', max: 6000 },
18
+ { name: 'PC', max: 16000 },
19
+ { name: 'Mobile', max: 30000 },
20
+ { name: 'Wechat', max: 35000 },
21
+ { name: 'Mobile QQ', max: 50000 },
22
+ { name: 'Mini App', max: 25000 }
23
+ ]
24
+ },
25
+ }
26
+ };
27
+ return getOption;`
28
+ };
29
+
30
+ const Circular_radar = {
31
+ code: `const getOption = () => {
32
+ return {
33
+ type: 'radar',
34
+ data: {
35
+ 'Referer of a Websit': [
36
+ {
37
+ name: '2018',
38
+ value: [5000, 7000, 12000, 11000, 15000, 14000]
39
+ }
40
+ ],
41
+ },
42
+ radar:{
43
+ indicator: [
44
+ { name: 'APP', max: 6000 },
45
+ { name: 'PC', max: 16000 },
46
+ { name: 'Mobile', max: 30000 },
47
+ { name: 'Wechat', max: 35000 },
48
+ { name: 'Mobile QQ', max: 50000 },
49
+ { name: 'Mini App', max: 25000 }
50
+ ],
51
+ radius: 120,
52
+ splitNumber: 3,
53
+ shape: 'circle',
54
+ splitArea: {
55
+ areaStyle: {
56
+ color: ['rgba(114, 172, 209, 0.2)','rgba(114, 172, 209, 0.4)', 'rgba(114, 172, 209, 0.6)','rgba(114, 172, 209, 0.8)', 'rgba(114, 172, 209, 1)'],
57
+ shadowColor: 'rgba(0, 0, 0, 0.3)',
58
+ shadowBlur: 10
59
+ }
60
+ }
61
+ },
62
+ }
63
+ };
64
+ return getOption;`
65
+ };
66
+
67
+
68
+ const Indicator_radar = {
69
+ code: `const getOption = () => {
70
+ return {
71
+ type: 'radar',
72
+ data: {
73
+ 'Referer of a Websit': [
74
+ {
75
+ name: '2018',
76
+ value: [5000, 7000, 12000, 11000, 15000, 14000]
77
+ },
78
+ {
79
+ name: '2019',
80
+ value: [4000, 9000, 15000, 15000, 13000, 11000],
81
+ symbol: 'rect',
82
+ symbolSize: 12,
83
+ lineStyle: {
84
+ type: 'dashed'
85
+ },
86
+ label: {
87
+ show: true,
88
+ formatter: function (params) {
89
+ return params.value;
90
+ }
91
+ }
92
+ }
93
+ ],
94
+ },
95
+ radar:{
96
+ indicator: [
97
+ { name: 'APP', max: 6000 },
98
+ { name: 'PC', max: 16000 },
99
+ { name: 'Mobile', max: 30000 },
100
+ { name: 'Wechat', max: 35000 },
101
+ { name: 'Mobile QQ', max: 50000 },
102
+ { name: 'Mini App', max: 25000 }
103
+ ],
104
+ radius: 120,
105
+ splitNumber: 3,
106
+ shape: 'circle',
107
+ name: {
108
+ fontSize: 20,
109
+ color: 'rgba(185, 11, 220, 1)'
110
+ }
111
+ },
112
+ }
113
+ };
114
+ return getOption;`
115
+ };
116
+
117
+ const Multiple_radar = {
118
+ code: `const getOption = () => {
119
+ return {
120
+ type: 'radar',
121
+ data: {
122
+ 'First': [
123
+ {
124
+ value: [60, 73, 85, 40],
125
+ name: 'A Software'
126
+ }
127
+ ],
128
+ "Second": [
129
+ {
130
+ value: [85, 90, 90, 95, 95],
131
+ name: 'A Phone'
132
+ },
133
+ {
134
+ value: [95, 80, 95, 90, 93],
135
+ name: 'Another Phone'
136
+ }
137
+ ],
138
+ 'Third': [
139
+ {
140
+ name: 'Precipitation',
141
+ value: [2.6, 5.9, 9.0, 26.4, 28.7, 70.7, 75.6, 82.2, 48.7, 18.8, 6.0, 2.3]
142
+ },
143
+ {
144
+ name: 'Evaporation',
145
+ value: [2.0, 4.9, 7.0, 23.2, 25.6, 76.7, 35.6, 62.2, 32.6, 20.0, 6.4, 3.3]
146
+ }
147
+ ],
148
+ },
149
+ radar: [
150
+ {
151
+ indicator: [
152
+ { text: 'Brand', max: 100 },
153
+ { text: 'Content', max: 100 },
154
+ { text: 'Usability', max: 100 },
155
+ { text: 'Function', max: 100 }
156
+ ],
157
+ center: ['25%', '40%'],
158
+ radius: 80
159
+ },
160
+ {
161
+ indicator: [
162
+ { text: 'Look', max: 100 },
163
+ { text: 'Photo', max: 100 },
164
+ { text: 'System', max: 100 },
165
+ { text: 'Performance', max: 100 },
166
+ { text: 'Screen', max: 100 }
167
+ ],
168
+ radius: 80,
169
+ center: ['50%', '60%']
170
+ },
171
+ {
172
+ indicator: (function () {
173
+ var res = [];
174
+ for (var i = 1; i <= 12; i++) {
175
+ res.push({ text: i + '月', max: 100 });
176
+ }
177
+ return res;
178
+ })(),
179
+ center: ['75%', '40%'],
180
+ radius: 80
181
+ }
182
+ ],
183
+ }
184
+ };
185
+ return getOption;`
186
+ };
187
+
188
+ const ex1 = new $visualify.LiveEditor(Basic_Radar).mount('#ex1');
189
+ const ex2 = new $visualify.LiveEditor(Circular_radar).mount('#ex2');
190
+ const ex3 = new $visualify.LiveEditor(Indicator_radar).mount('#ex3');
191
+ const ex4 = new $visualify.LiveEditor(Multiple_radar).mount('#ex4');
192
+ </script>
193
+
194
+ # Radar Chart
195
+
196
+ ## Basic Radar Chart
197
+
198
+ <div id="ex1"></div>
199
+
200
+ ## Circular Radar Chart
201
+
202
+ <div id="ex2"></div>
203
+
204
+ ## Indicator Radar Chart
205
+
206
+ <div id="ex3"></div>
207
+
208
+ ## Multiple Radar Chart
209
+
210
+ <div id="ex4"></div>
211
+
212
+ ## Overall Configuration
213
+
214
+ ### Basic Configuration
215
+
216
+ The basic configuration includes:
217
+
218
+ | Attribute | Type | Description | Choice | Default |
219
+ | --------------- | ----------- | ----------------------- | -------------------------- | ------- |
220
+ | title | string | The main title | User-defined title | - |
221
+ | subtitle | string | A secondary title | User-defined subtitle | - |
222
+ | width | string | The width dimension | Any valid CSS width value | - |
223
+ | height | string | The height dimension | Any valid CSS height value | 400px |
224
+ | legend | bool/object | show or hide legend | False, User-defined legend | {} |
225
+ | xAxis | array/false | The xAxis | User-defined xAxis Data | [] |
226
+ | yAxis | array/false | The yAxis | User-defined yAxis Data | [] |
227
+ | label | object | The label | User-defined label | {} |
228
+ | labelLine | object | The labelLine | User-defined labelLine | {} |
229
+ | tooltip | object | The tooltip | User-defined tooltip | {} |
230
+ | xAxisLineshow | bool | show or hide xAxisLines | True, False | true |
231
+ | yAxisLineshow | bool | show or hide yAxisLines | True, False | true |
232
+ | xAxisLabelShow | bool | show or hide xAxisLabel | True, False | true |
233
+ | yAxisLabelShow | bool | show or hide yAxisLabel | True, False | true |
234
+ | xAxisLabelColor | string | The xAxisLabelColor | Any valid CSS color value | - |
235
+ | yAxisLabelColor | string | The yAxisLabelColor | Any valid CSS color value | - |
236
+
237
+ ### Data Configuration
238
+
239
+ | Attribute | Type | Description | Choice | Default |
240
+ | --------- | ------------ | ----------- | ----------------- | --------- |
241
+ | data | string | The data | User-defined data | {} |
242
+ | type | string/array | The type | 'line', 'bar' | undefined |
243
+ | radar | object | The radar | User-defined data | {} |
244
+
245
+ ### Radar Configuration
246
+
247
+ | Attribute | Type | Description | Choice | Default |
248
+ | ----------- | ------ | --------------- | ------------------------ | --------- |
249
+ | indicator | array | The indicator | User-defined indicator | [] |
250
+ | radius | number | The radius | User-defined radius | 75 |
251
+ | splitNumber | number | The splitNumber | User-defined splitNumber | 5 |
252
+ | shape | string | The shape | 'polygon', 'circle' | 'polygon' |
253
+ | splitArea | object | The splitArea | User-defined splitArea | {} |
File without changes
File without changes
File without changes
File without changes
File without changes
@@ -0,0 +1,52 @@
1
+ <style>
2
+ body {
3
+ font-family: Arial, sans-serif;
4
+ display: flex;
5
+ justify-content: center;
6
+ align-items: center;
7
+ height: 100vh;
8
+ margin: 0;
9
+ }
10
+
11
+ .container {
12
+ text-align: center;
13
+ background-color: #ffffff;
14
+ padding: 50px;
15
+ margin-top: 5vh;
16
+ border-radius: 10px;
17
+ box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1);
18
+ }
19
+
20
+ .container h1 {
21
+ font-size: 72px;
22
+ margin-bottom: 20px;
23
+ color: #ff5252;
24
+ }
25
+
26
+ .container p {
27
+ font-size: 24px;
28
+ margin-bottom: 30px;
29
+ }
30
+
31
+ .container a {
32
+ font-size: 18px;
33
+ text-decoration: none;
34
+ color: #2196f3;
35
+ border: 1px solid #2196f3;
36
+ padding: 10px 15px;
37
+ border-radius: 5px;
38
+ transition: background-color 0.3s, color 0.3s;
39
+ }
40
+
41
+ .container a:hover {
42
+ background-color: #2196f3;
43
+ color: #ffffff;
44
+ }
45
+
46
+ </style>
47
+
48
+ <div class="container">
49
+ <h1>404</h1>
50
+ <p>Oops! The page you're looking for doesn't exist.</p>
51
+ <a href="/">Go Home</a>
52
+ </div>
@@ -0,0 +1,11 @@
1
+ <!-- _coverpage.md -->
2
+
3
+ ![logo](./static/logo/logo_256x256.png)
4
+
5
+ # visualify.js <small>2.5.3</small>
6
+
7
+ > A magical data portal generator
8
+
9
+ [GitHub](https://github.com/usleolihao)
10
+ [Getting Started](#visualify)
11
+
@@ -0,0 +1,43 @@
1
+ - Getting started
2
+
3
+ - [Introduction](/README.md)
4
+ - [Quick start](/quickstart.md)
5
+ - [More pages](/more-pages.md)
6
+
7
+ - Visualify.Recharts
8
+
9
+ - [Usage](/rechart-basic-usage.md)
10
+ - [Attributes](/rechart-attributes.md)
11
+ - [Line Chart](/Rechart/line.md)
12
+ - [Bar Chart](/Rechart/bar.md)
13
+ - [Pie Chart](/Rechart/pie.md)
14
+ - [Radar Chart](/Rechart/radar.md)
15
+ - [Funnel Chart](/Rechart/funnel.md)
16
+
17
+
18
+ - Page Mode
19
+
20
+ - [ScatterL](/components/scatterL.md)
21
+ - [Visium](/components/visium.md)
22
+ - [DotBio](/components/dotBio.md)
23
+ - [Echart](/components/echart.md)
24
+ - [Plotly](/components/plotly.md)
25
+ - [Macaron](/components/macaron.md)
26
+ - [More...](/components/more.md)
27
+
28
+ - Customization
29
+
30
+ - [Configuration](/configuration.md)
31
+ - [Theme](/theme.md)
32
+
33
+ - Guide
34
+
35
+ - [CLI](/CLI.md)
36
+ - [Deploy](/deploy.md)
37
+
38
+ - Showcase
39
+
40
+ - [MmTrBC](https://visualify.pharmacy.arizona.edu/MmTrBC/)
41
+ - [EsoDev](https://visualify.pharmacy.arizona.edu/EsoDev/)
42
+
43
+ - [UpdateLog](/log.md)
@@ -0,0 +1,34 @@
1
+ # DotBio Component
2
+
3
+ The DotBio component is a dot plot that
4
+ displays the expression of genes in different cell types.
5
+
6
+
7
+ ## Properties
8
+
9
+ The DotBio component has the following properties:
10
+
11
+ - `type` (string): The type of the component, in this case `DotBio`.
12
+ - `id` (string): The unique identifier of the component.
13
+ - `row` (int): The row in which the component is to be displayed.
14
+ - `col` (int): The column in which the component is to be displayed.
15
+ - `rowspan` (int): The number of rows the component is to span.
16
+ - `colspan` (int): The number of columns the component is to span.
17
+ - `settings` (object): The settings of the component.
18
+ - `meta` (object): The metadata API of the component.
19
+ - `name` (string): The name of the metadata.
20
+ - `url` (string): The URL of the metadata.
21
+ - `exclude_celltype` (array): The cell types to be excluded.
22
+ - `gene` (string): The gene API.
23
+ - `genelist` (string): The genelist variable name we want to use.
24
+
25
+ ### settings Properties
26
+
27
+ The `settings` object has the following properties:
28
+
29
+ - `preset` (string): The preset of the component.
30
+ - `ignoreEmptyData` (boolean): Whether to ignore empty data or not.
31
+ - `showscale` (boolean): Whether to show the scale or not.
32
+ - `showlegend` (boolean): Whether to show the legend or not.
33
+
34
+
@@ -0,0 +1,82 @@
1
+ # Echart Component
2
+
3
+ The Echart component is a wrapper around the
4
+ [Apache ECharts](https://echarts.apache.org/en/index.html) library. It is used
5
+ to create a variety of visualizations including scatter plots, line charts, bar
6
+ charts, and more.
7
+
8
+ This Echart Component is same as the Rechart Component, but it is used for the
9
+ page mode, which enable the user to create a page with multiple components. And
10
+ it also **support the API to fetch the data**.
11
+
12
+ ## Properties
13
+
14
+ The Echart component has the following properties:
15
+
16
+ - `type` (string): The type of the component, in this case `Echart`.
17
+ - `id` (string): The unique identifier of the component.
18
+ - `row` (int): The row in which the component is to be displayed.
19
+ - `col` (int): The column in which the component is to be displayed.
20
+ - `rowspan` (int): The number of rows the component is to span.
21
+ - `colspan` (int): The number of columns the component is to span.
22
+ - `config` (object): The configuration of the component.
23
+ - `parser` (object): The parser of the component.
24
+ - `trigger` (object): The trigger of the component.
25
+
26
+ ### config Properties
27
+
28
+ The `config` object has the following properties:
29
+
30
+ - `width` (int): The width of the component.
31
+ - `height` (int): The height of the component.
32
+ - `preset` (string): The preset of the component.
33
+ - `title` (string): The title of the component.
34
+ - `xAxis` (string): The x-axis of the component.
35
+ - `yAxis` (string): The y-axis of the component.
36
+ - `legend` (string): The legend of the component.
37
+ - `tooltip` (string): The tooltip of the component.
38
+ - `data` (string): The data of the component.
39
+
40
+ ### parser Properties
41
+
42
+ The `parser` object has the following properties:
43
+
44
+ - `sources` (array): The sources of the component.
45
+ - `name` (string): The name of the trigger.
46
+ - `url` (string): The URL of the data.
47
+ - `type` (string): The type of the component.
48
+ - `responseKey` (string): The response key of the component.
49
+ - `trigger` (object): The trigger of the component.
50
+ - `title` (boolean): set the title to the triiger value.
51
+
52
+ ### Example
53
+
54
+ ```json
55
+ {
56
+ "id": "mmtrbc_tsne",
57
+ "type": "Echart",
58
+ "col": 2,
59
+ "rowspan": 3,
60
+ "config": {
61
+ "width": 600,
62
+ "height": 600,
63
+ "preset": "mmtrbc",
64
+ "title": " "
65
+ },
66
+ "parser": {
67
+ "sources": [{
68
+ "name": "metadata",
69
+ "url": "<your-backend-url>"
70
+ }, {
71
+ "name": "gene",
72
+ "url": "<your-backend-url>",
73
+ "responseKey": "gene",
74
+ "trigger": {
75
+ "name": "mmtrbc_gene",
76
+ "title": true
77
+ }
78
+ }],
79
+ "type": "scatter"
80
+ }
81
+ }
82
+ ```
@@ -0,0 +1,34 @@
1
+ # HTML Component
2
+
3
+ The HTML component is used to display HTML content on the page.
4
+
5
+ ## Properties
6
+
7
+ The HTML component has the following properties:
8
+
9
+ - `type` (string): The type of the component, in this case `HTML`.
10
+ - `id` (string): The unique identifier of the component.
11
+ - `row` (int): The row in which the component is to be displayed.
12
+ - `col` (int): The column in which the component is to be displayed.
13
+ - `colspan` (int): The number of columns the component is to span.
14
+ - `html` (string): The HTML content to be displayed.
15
+
16
+ ## Future Work
17
+
18
+ We will add the ability to fetch the HTML content from an API.
19
+
20
+ - `script` (string): The script to be executed.
21
+ - `style` (string): The style to be applied.
22
+
23
+ ### Example
24
+
25
+ ```json
26
+ {
27
+ "type": "HTML",
28
+ "row": 1,
29
+ "col": 2,
30
+ "colspan": 3,
31
+ "html": "<img style='width: 100%' src='./mainpage.png' alt='Abstract'>"
32
+ }
33
+ ```
34
+
@@ -0,0 +1,145 @@
1
+ # Macaron Component
2
+
3
+ The Macaron component is used to display a macaron plot for relation of nodes on
4
+ the page.
5
+
6
+ The Macaron component also has interactive features, such as the ability to drag
7
+ and drop nodes, and the ability to select nodes.
8
+
9
+ ## Properties
10
+
11
+ The Macaron component has the following properties:
12
+
13
+ - `type` (string): The type of the component, in this case `Macaron`.
14
+ - `id` (string): The unique identifier of the component.
15
+ - `row` (int): The row in which the component is to be displayed.
16
+ - `col` (int): The column in which the component is to be displayed.
17
+ - `config` (object): The configuration of the component.
18
+ - `data` (object): The data of the component.
19
+
20
+ ### config Properties
21
+
22
+ The `config` object has the following properties:
23
+
24
+ - `animation` (boolean): Whether to animate the component or not.
25
+ - `draggable` (boolean): Whether to make the component draggable or not.
26
+ - `height` (int): The height of the component.
27
+ - `unclickable` (array): The nodes that are unclickable.
28
+ - `symbolSize` (string): The size of the symbols in the component.
29
+ - `color` (object): The color of the component.
30
+ - `selected` (string): The color of the selected nodes.
31
+ - `unselectable` (string): The color of the unselectable nodes.
32
+
33
+ ### data Properties
34
+
35
+ The `data` object has the following properties:
36
+
37
+ - `nodes` (array): The nodes of the component.
38
+ - `name` (string): The name of the node.
39
+ - `category` (int): The category of the node.
40
+ - `value` (int): The value of the node.
41
+ - `edges` (array): The edges of the component.
42
+ - `categories` (array): The categories of the component.
43
+
44
+ ### Example
45
+
46
+ ```json
47
+ {
48
+ "id": "celltype",
49
+ "type": "Macaron",
50
+ "title": "Select Cell Type",
51
+ "style": {
52
+ "height": "350px",
53
+ "width": "350px",
54
+ "font": "Arial, sans-serif",
55
+ "border": ""
56
+ },
57
+ "data": {
58
+ "nodes": [{
59
+ "name": "Esophagus",
60
+ "category": 1,
61
+ "value": 216229
62
+ },
63
+ {
64
+ "name": "Epithelium",
65
+ "category": 2,
66
+ "value": 108800
67
+ },
68
+ {
69
+ "name": "Stroma",
70
+ "category": 2,
71
+ "value": 107429
72
+ },
73
+ {
74
+ "name": "EPI (E)",
75
+ "category": 3,
76
+ "value": 97799
77
+ },
78
+ {
79
+ "name": "ST (E)",
80
+ "category": 3,
81
+ "value": 1760
82
+ }
83
+ ],
84
+ "edges": [{
85
+ "source": "Esophagus",
86
+ "target": "Epithelium",
87
+ "level": 1
88
+ },
89
+ {
90
+ "source": "Esophagus",
91
+ "target": "Stroma",
92
+ "level": 1
93
+ },
94
+ {
95
+ "source": "Epithelium",
96
+ "target": "IM (E)",
97
+ "level": 2
98
+ },
99
+ {
100
+ "source": "Epithelium",
101
+ "target": "ERY (E)",
102
+ "level": 2
103
+ },
104
+ {
105
+ "source": "Stroma",
106
+ "target": "MES (S)",
107
+ "level": 2
108
+ },
109
+ {
110
+ "source": "Stroma",
111
+ "target": "ENS (S)",
112
+ "level": 2
113
+ },
114
+ {
115
+ "source": "Stroma",
116
+ "target": "ENDO (S)",
117
+ "level": 2
118
+ }
119
+ ],
120
+ "categories": [{
121
+ "name": "Category 1"
122
+ },
123
+ {
124
+ "name": "Category 2"
125
+ },
126
+ {
127
+ "name": "Category 3"
128
+ }
129
+ ]
130
+ },
131
+ "config": {
132
+ "animation": false,
133
+ "draggable": true,
134
+ "height": "88%",
135
+ "unclickable": ["EPI (S)", "Esophagus"],
136
+ "symbolSize": "value",
137
+ "color": {
138
+ "selected": "skyblue",
139
+ "unselectable": "black"
140
+ }
141
+ },
142
+ "row": 1,
143
+ "col": 1
144
+ }
145
+ ```
File without changes