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.
- package/.github/workflows/static.yml.bak +51 -0
- package/LICENSE +674 -0
- package/README.md +59 -0
- package/config-overrides.js +31 -0
- package/dist/visualify.js +188 -0
- package/docs/.nojekyll +0 -0
- package/docs/docs/CLI.md +34 -0
- package/docs/docs/README.md +65 -0
- package/docs/docs/Rechart/bar.md +190 -0
- package/docs/docs/Rechart/funnel.md +193 -0
- package/docs/docs/Rechart/geo.md +0 -0
- package/docs/docs/Rechart/line.md +355 -0
- package/docs/docs/Rechart/liquidfill.md +0 -0
- package/docs/docs/Rechart/pie.md +225 -0
- package/docs/docs/Rechart/polar.md +0 -0
- package/docs/docs/Rechart/radar.md +253 -0
- package/docs/docs/Rechart/sankey.md +0 -0
- package/docs/docs/Rechart/scatter.md +0 -0
- package/docs/docs/Rechart/sunburst.md +0 -0
- package/docs/docs/Rechart/tree.md +0 -0
- package/docs/docs/Rechart/wordcloud.md +0 -0
- package/docs/docs/_404.md +52 -0
- package/docs/docs/_coverpage.md +11 -0
- package/docs/docs/_sidebar.md +43 -0
- package/docs/docs/components/dotBio.md +34 -0
- package/docs/docs/components/echart.md +82 -0
- package/docs/docs/components/html.md +34 -0
- package/docs/docs/components/macaron.md +145 -0
- package/docs/docs/components/markdown.md +0 -0
- package/docs/docs/components/more.md +142 -0
- package/docs/docs/components/plotly.md +62 -0
- package/docs/docs/components/scatterL.md +70 -0
- package/docs/docs/components/visium.md +57 -0
- package/docs/docs/configuration.md +123 -0
- package/docs/docs/deploy.md +31 -0
- package/docs/docs/log.md +1 -0
- package/docs/docs/more-pages.md +23 -0
- package/docs/docs/quickstart.md +119 -0
- package/docs/docs/rechart-attributes.md +74 -0
- package/docs/docs/rechart-basic-usage.md +162 -0
- package/docs/docs/static/_images/deploy-github-pages.png +0 -0
- package/docs/docs/static/logo/favicon.ico +0 -0
- package/docs/docs/static/logo/logo_128x128.png +0 -0
- package/docs/docs/static/logo/logo_192x192.png +0 -0
- package/docs/docs/static/logo/logo_256x256.png +0 -0
- package/docs/docs/static/logo/logo_512x512.png +0 -0
- package/docs/docs/static/logo/logo_64x64.png +0 -0
- package/docs/docs/theme.md +5 -0
- package/docs/index.html +71 -0
- package/docs/manifest.json +24 -0
- package/docs/static/css/fluff-stuff.css +170 -0
- package/docs/static/css/font-awesome.min.css +4 -0
- package/docs/static/css/visualify.css +25 -0
- package/docs/static/fonts/fontawesome-webfont.woff2 +0 -0
- package/docs/static/images/star.png +0 -0
- package/docs/static/js/configuration.js +448 -0
- package/docs/static/js/fluff.js +1 -0
- package/docs/static/js/visualify.js +188 -0
- package/docs/static/logo/favicon.ico +0 -0
- package/docs/static/logo/logo_128x128.png +0 -0
- package/docs/static/logo/logo_192x192.png +0 -0
- package/docs/static/logo/logo_256x256.png +0 -0
- package/docs/static/logo/logo_512x512.png +0 -0
- package/docs/static/logo/logo_64x64.png +0 -0
- package/package.json +84 -0
- package/rollup.config.mjs +76 -0
- package/src/_css/404.css +116 -0
- package/src/_css/App.css +38 -0
- package/src/_css/autoSuggestion.css +27 -0
- package/src/_css/circular-progress.css +33 -0
- package/src/_css/index.css +37 -0
- package/src/_css/modern.css +25 -0
- package/src/_media/404.png +0 -0
- package/src/_media/corner.svg +8 -0
- package/src/_media/download.svg +3 -0
- package/src/_media/icon.svg +1 -0
- package/src/_media/logo.svg +14 -0
- package/src/_test/App.test.js +15 -0
- package/src/_utils/reportWebVitals.js +13 -0
- package/src/core/appContext.js +27 -0
- package/src/core/components/Scatter.js +188 -0
- package/src/core/components/ScatterBio.js +572 -0
- package/src/core/components/VisiumPlot.js +165 -0
- package/src/core/components/browser.js +42 -0
- package/src/core/components/dotplot.js +413 -0
- package/src/core/components/html.js +29 -0
- package/src/core/components/list.js +178 -0
- package/src/core/components/macaron.js +201 -0
- package/src/core/components/markdown.js +56 -0
- package/src/core/components/parser.scatterBio.js +579 -0
- package/src/core/components/ratio.js +80 -0
- package/src/core/components/scatterL.js +173 -0
- package/src/core/components/searchbar.js +131 -0
- package/src/core/components/selection.js +193 -0
- package/src/core/components/timeline.js +281 -0
- package/src/core/components/visium.js +97 -0
- package/src/core/fetch/condfetch.js +82 -0
- package/src/core/fetch/fetch.js +92 -0
- package/src/core/fetch/json.js +29 -0
- package/src/core/fetch/vfetch.js +42 -0
- package/src/core/liveEditor.js +44 -0
- package/src/core/modules/codeEditorWithPreview.js +104 -0
- package/src/core/modules/echarts/common.js +20 -0
- package/src/core/modules/echarts/presetHandler.js +41 -0
- package/src/core/modules/echarts/presets/esodev.chromium.js +172 -0
- package/src/core/modules/echarts/presets/esodev.codex.js +130 -0
- package/src/core/modules/echarts/presets/esodev.visium.js +123 -0
- package/src/core/modules/echarts/presets/mmtrbc.js +186 -0
- package/src/core/modules/echarts.js +71 -0
- package/src/core/modules/echartsUtils.js +43 -0
- package/src/core/modules/echartswitcher.js +152 -0
- package/src/core/modules/replotly/presetHandler.js +24 -0
- package/src/core/modules/replotly/presets/minimum.js +18 -0
- package/src/core/modules/replotly/presets/mmtrbc.dot.js +114 -0
- package/src/core/modules/replotly/presets/mmtrbc.violin.js +100 -0
- package/src/core/modules/replotly.js +71 -0
- package/src/core/pages/404.js +50 -0
- package/src/core/pages/error.js +27 -0
- package/src/core/pages/jsonPage.js +62 -0
- package/src/core/pages/loading.js +44 -0
- package/src/core/parser/echart.data.js +183 -0
- package/src/core/parser/echart.features.js +125 -0
- package/src/core/parser/echart.general.js +143 -0
- package/src/core/parser/echart.hilbert.js +57 -0
- package/src/core/parser/echart.parser.js +210 -0
- package/src/core/parser/echart.series.js +67 -0
- package/src/core/parser/echart.types.js +76 -0
- package/src/core/parser/plotly.config.js +10 -0
- package/src/core/parser/plotly.data.js +132 -0
- package/src/core/parser/plotly.layout.js +10 -0
- package/src/core/parser/plotly.violin.js +18 -0
- package/src/core/recharts.js +62 -0
- package/src/core/router/alias.js +49 -0
- package/src/core/router/jsonRouter.js +31 -0
- package/src/core/themes/modern.js +32 -0
- package/src/core/themes/themeSelector.js +33 -0
- package/src/core/visualify.js +47 -0
- package/src/core/widgets/circularProgress.js +24 -0
- package/src/core/widgets/controller.js +83 -0
- package/src/core/widgets/errorBoundary.js +36 -0
- package/src/core/widgets/footer.js +177 -0
- package/src/core/widgets/header.js +234 -0
- package/src/core/widgets/layout/Grid.js +31 -0
- package/src/core/widgets/layout.js +36 -0
- package/src/core/widgets/mapping.js +42 -0
- package/src/index.js +62 -0
- 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,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
|