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,104 @@
1
+ /*
2
+ * @Author : Lihao leolihao@arizona.edu
3
+ * @Date : 2023-12-01 22:17:15
4
+ * @FilePath : /visualifyjs/src/core/modules/codeEditorWithPreview.js
5
+ * @Description :
6
+ * Copyright (c) 2023 by Lihao (leolihao@arizona.edu), All Rights Reserved.
7
+ */
8
+ import React, { useState } from 'react';
9
+ import AceEditor from 'react-ace';
10
+ import EChartSwitcher from './echartswitcher';
11
+ import 'ace-builds/src-noconflict/mode-javascript';
12
+ import 'ace-builds/src-noconflict/theme-monokai';
13
+
14
+ const CodeEditorWithPreview = ({ config }) => {
15
+ const supportedThemes = ['', 'monokai'];
16
+ const supportedMode = ['javascript'];
17
+
18
+ const {
19
+ theme = '',
20
+ mode = 'javascript',
21
+ width,
22
+ height = '400px',
23
+ title = 'Rechart Preview',
24
+ editorProps = { $blockScrolling: true },
25
+ } = config;
26
+
27
+ if (!supportedThemes.includes(theme)) {
28
+ throw new Error(
29
+ `Theme '${theme}' not supported. Supported themes are: ${supportedThemes.join(
30
+ ', ',
31
+ )}`,
32
+ );
33
+ }
34
+
35
+ if (!supportedMode.includes(mode)) {
36
+ throw new Error(
37
+ `Mode '${mode}' not supported. Supported modes are: ${supportedMode.join(
38
+ ', ',
39
+ )}`,
40
+ );
41
+ }
42
+
43
+ const [code, setCode] = useState(config.code);
44
+
45
+ // Function to evaluate the code and return the chart options
46
+ const getChartOptions = () => {
47
+ try {
48
+ // eslint-disable-next-line no-new-func
49
+ const func = new Function(code);
50
+ return func()();
51
+ } catch (error) {
52
+ console.error('Error evaluating chart options:', error);
53
+ return {};
54
+ }
55
+ };
56
+
57
+ const blockStyles = {
58
+ display: 'flex',
59
+ justifyContent: 'space-between',
60
+ };
61
+ if (width) blockStyles.width = width;
62
+
63
+ const editorStyles = {
64
+ flexGrow: 1,
65
+ border: '1px solid #ddd',
66
+ borderRadius: '4px',
67
+ marginBottom: '10px',
68
+ width: '50%',
69
+ };
70
+
71
+ const editorTitleStyles = {
72
+ backgroundColor: '#f4f4f4',
73
+ padding: '10px',
74
+ borderBottom: '1px solid #ddd',
75
+ width: '100%',
76
+ };
77
+
78
+ return (
79
+ <div style={blockStyles}>
80
+ <div style={editorStyles}>
81
+ <div style={editorTitleStyles}>{title}</div>
82
+ <AceEditor
83
+ mode={mode}
84
+ theme={theme}
85
+ value={code}
86
+ onChange={setCode}
87
+ name={title}
88
+ editorProps={editorProps}
89
+ width='100%'
90
+ height={height}
91
+ setOptions={{
92
+ wrap: true,
93
+ useWorker: false,
94
+ }}
95
+ />
96
+ </div>
97
+ <div style={{ width: '50%' }}>
98
+ <EChartSwitcher props={{ config: getChartOptions() }} />
99
+ </div>
100
+ </div>
101
+ );
102
+ };
103
+
104
+ export default CodeEditorWithPreview;
@@ -0,0 +1,20 @@
1
+ /*
2
+ * @Author : Lihao leolihao@arizona.edu
3
+ * @Date : 2023-12-01 21:43:02
4
+ * @FilePath : /visualifyjs/src/core/modules/echarts/common.js
5
+ * @Description :
6
+ * Copyright (c) 2023 by Lihao (leolihao@arizona.edu), All Rights Reserved.
7
+ */
8
+ const minimumPreset = {
9
+ title: {},
10
+ tooltip: {},
11
+ legend: {
12
+ top: 25,
13
+ },
14
+ xAxis: {},
15
+ yAxis: {},
16
+ series: [],
17
+ // ... other default settings for charts
18
+ };
19
+
20
+ export default minimumPreset;
@@ -0,0 +1,41 @@
1
+ /*
2
+ * @Author : Lihao leolihao@arizona.edu
3
+ * @Date : 2023-12-02 21:36:01
4
+ * @FilePath : /visualifyjs/src/core/modules/echarts/presetHandler.js
5
+ * @Description :
6
+ * Copyright (c) 2023 by Lihao (leolihao@arizona.edu), All Rights Reserved.
7
+ */
8
+ // presetHandler.js
9
+ import minimumPreset from './common';
10
+ import mmtrbc from './presets/mmtrbc';
11
+ import esodev_chromium from './presets/esodev.chromium';
12
+ import esodev_codex from './presets/esodev.codex';
13
+ import esodev_visium from './presets/esodev.visium';
14
+
15
+ // Example embedded presets
16
+ const embeddedPresets = {
17
+ mmtrbc: mmtrbc,
18
+ esodev_chromium: esodev_chromium,
19
+ esodev_codex: esodev_codex,
20
+ esodev_visium: esodev_visium,
21
+ // 'presetName': { ...preset data... }
22
+ // Define embedded presets here
23
+ };
24
+
25
+ // Function to fetch preset data from a URL
26
+ export const fetchPresetFromURL = async (url) => {
27
+ try {
28
+ const response = await fetch(url);
29
+ const data = await response.json();
30
+ return data;
31
+ } catch (error) {
32
+ console.error('Error fetching preset from URL:', error);
33
+ return null; // Return null or appropriate error handling
34
+ }
35
+ };
36
+
37
+ // Function to get an embedded preset based on a string key
38
+ export const getEmbeddedPreset = (presetKey) => {
39
+ // Return minimumPreset if preset not found
40
+ return embeddedPresets[presetKey] || minimumPreset;
41
+ };
@@ -0,0 +1,172 @@
1
+ /*
2
+ * @Author : Lihao leolihao@arizona.edu
3
+ * @Date : 2023-12-22 22:37:23
4
+ * @FilePath : /visualifyjs/src/core/modules/echarts/presets/esodev.chromium.js
5
+ * @Description :
6
+ * Copyright (c) 2023 by Lihao (leolihao@arizona.edu), All Rights Reserved.
7
+ */
8
+ const esodev_chromium = {
9
+ title: {
10
+ textStyle: {
11
+ fontSize: 20,
12
+ },
13
+ left: 'center',
14
+ top: 0,
15
+ },
16
+ animation: false,
17
+ legend: {
18
+ textStyle: {
19
+ fontSize: 18,
20
+ },
21
+ orient: 'horizontal',
22
+ right: 'center', // "top" | "bottom" | "center"
23
+ itemWidth: 20,
24
+ width: 600,
25
+ top: 25,
26
+ },
27
+ xAxis: {
28
+ name: 'UMAP 1',
29
+ type: 'value',
30
+ nameLocation: 'middle',
31
+ nameGap: 10,
32
+ nameTextStyle: {
33
+ fontSize: 18, // Set font size
34
+ fontWeight: 'bold', // Set font weight to bold
35
+ },
36
+ axisLine: { show: false },
37
+ axisTick: { show: false },
38
+ splitLine: { show: false },
39
+ axisLabel: { show: false },
40
+ //min: -20,
41
+ //max: 20,
42
+ },
43
+ yAxis: {
44
+ name: 'UMAP 2',
45
+ type: 'value',
46
+ nameLocation: 'middle',
47
+ nameGap: 10,
48
+ nameTextStyle: {
49
+ fontSize: 18, // Set font size
50
+ fontWeight: 'bold', // Set font weight to bold
51
+ },
52
+ //min: -20,
53
+ //max: 20,
54
+ axisLine: { show: false },
55
+ axisTick: { show: false },
56
+ splitLine: { show: false },
57
+ axisLabel: { show: false },
58
+ },
59
+ series: [],
60
+ grid: {
61
+ top: '20%',
62
+ bottom: '12%',
63
+ left: '10%',
64
+ right: '10%',
65
+ },
66
+ // ... other default settings for charts
67
+ toolbox: {
68
+ feature: {
69
+ saveAsImage: {
70
+ show: true,
71
+ icon: `path://M30 20.75c-0.69 0.001-1.249 0.56-1.25 1.25v6.75h-25.5v-6.75c0-0.69-0.56-1.25-1.25-1.25s-1.25 0.56-1.25 1.25v0 8c0 0.69 0.56 1.25 1.25 1.25h28c0.69-0.001 1.249-0.56 1.25-1.25v-8c-0.001-0.69-0.56-1.249-1.25-1.25h-0zM15.116 24.885c0.012 0.012 0.029 0.016 0.041 0.027 0.103 0.099 0.223 0.18 0.356 0.239l0.008 0.003 0.001 0c0.141 0.060 0.306 0.095 0.478 0.095 0.345 0 0.657-0.139 0.883-0.365l5.001-5c0.226-0.226 0.366-0.539 0.366-0.884 0-0.691-0.56-1.251-1.251-1.251-0.345 0-0.658 0.14-0.884 0.366l-2.865 2.867v-18.982c0-0.69-0.56-1.25-1.25-1.25s-1.25 0.56-1.25 1.25v0 18.981l-2.866-2.866c-0.226-0.226-0.539-0.366-0.884-0.366-0.691 0-1.251 0.56-1.251 1.251 0 0.346 0.14 0.658 0.367 0.885v0z`,
72
+ },
73
+ },
74
+ },
75
+ dataZoom: [
76
+ // Inside type for X-axis
77
+ {
78
+ type: 'inside',
79
+ xAxisIndex: 0,
80
+ filterMode: 'filter',
81
+ },
82
+ // Inside type for Y-axis
83
+ {
84
+ type: 'inside',
85
+ yAxisIndex: 0,
86
+ filterMode: 'filter',
87
+ orient: 'vertical',
88
+ },
89
+ ],
90
+ visualMap: {
91
+ min: 0,
92
+ max: 3,
93
+ dimension: 2,
94
+ orient: 'vertical',
95
+ top: 'center',
96
+ left: 0,
97
+ text: ['log2\n(tpm+1)', ''],
98
+ textGap: 10,
99
+ calculable: true,
100
+ inRange: {
101
+ color: ['#808080', '#FFA500', '#FF0000'],
102
+ },
103
+ textStyle: {
104
+ writingMode: 'vertical-lr',
105
+ },
106
+ },
107
+ tooltip: {
108
+ trigger: 'item',
109
+ axisPointer: {
110
+ type: 'cross',
111
+ },
112
+ formatter: (params) => {
113
+ let express = params.data.value[2];
114
+ let round_epxress = express
115
+ ? Math.round(express * 10000) / 10000
116
+ : 0;
117
+ return `
118
+ <div style="text-align: center;">
119
+ ${params.data.Cell_ID}
120
+ <br/> Type: <strong>${params.data.Cell_Type} </strong>
121
+ <br/> Stage: <strong>${params.data.Stage}</strong>
122
+ <br/> #UMI: <strong>${params.data.UMI}</strong>
123
+ <br/> #Gene: <strong>${params.data.Gene}</strong>
124
+ <br/> MT%: <strong>${params.data.MT}</strong>
125
+ ${
126
+ express !== undefined
127
+ ? '<br/> Expression: <strong>' +
128
+ round_epxress +
129
+ '</strong>'
130
+ : ''
131
+ }
132
+ </div>
133
+ `;
134
+ },
135
+ },
136
+ visualify: {
137
+ mapping: {
138
+ x: '2D_UMAP_1',
139
+ y: '2D_UMAP_2',
140
+ extra: {
141
+ Stage: 'Stage',
142
+ UMI: 'n_UMIs',
143
+ MT: 'percent_MT',
144
+ Gene: 'n_Genes',
145
+ Cell_Type: 'Cell_Type',
146
+ Cell_ID: 'Cell_ID',
147
+ },
148
+ },
149
+ seriesBy: 'Cell_Type',
150
+ symbolSize: 5,
151
+ symbol: 'circle',
152
+ merger: {
153
+ gene: {
154
+ item: 'Cell_ID',
155
+ label: 'Expression',
156
+ visualMap: true,
157
+ },
158
+ },
159
+ api_mapping: {
160
+ 'ENS (S)': 'ens_iter_2',
161
+ 'IM (S)': 'im_iter_2',
162
+ 'MES (S)': 'mes_iter_2',
163
+ 'SKM (S)': 'skm_iter_2',
164
+ 'ENDO (S)': 'endo_iter_2',
165
+ 'EPI (E)': 'epi_iter_2',
166
+ Stroma: 'stroma_iter_1',
167
+ Epithelium: 'epi_iter_1',
168
+ },
169
+ },
170
+ };
171
+
172
+ export default esodev_chromium;
@@ -0,0 +1,130 @@
1
+ const esodev_codex = {
2
+ title: {
3
+ textStyle: {
4
+ fontSize: 20,
5
+ },
6
+ left: 'center',
7
+ top: 0,
8
+ },
9
+ animation: false,
10
+ legend: {
11
+ textStyle: {
12
+ fontSize: 18,
13
+ },
14
+ orient: 'horizontal',
15
+ right: 'center', // "top" | "bottom" | "center"
16
+ itemWidth: 20,
17
+ width: 600,
18
+ top: 25,
19
+ },
20
+ xAxis: {
21
+ show: false,
22
+ },
23
+ yAxis: {
24
+ show: false,
25
+ },
26
+ series: [],
27
+ grid: {
28
+ top: '15%',
29
+ bottom: '12%',
30
+ left: '5%',
31
+ right: '10%',
32
+ },
33
+ // ... other default settings for charts
34
+ toolbox: {
35
+ feature: {
36
+ saveAsImage: {
37
+ show: true,
38
+ icon: `path://M30 20.75c-0.69 0.001-1.249 0.56-1.25 1.25v6.75h-25.5v-6.75c0-0.69-0.56-1.25-1.25-1.25s-1.25 0.56-1.25 1.25v0 8c0 0.69 0.56 1.25 1.25 1.25h28c0.69-0.001 1.249-0.56 1.25-1.25v-8c-0.001-0.69-0.56-1.249-1.25-1.25h-0zM15.116 24.885c0.012 0.012 0.029 0.016 0.041 0.027 0.103 0.099 0.223 0.18 0.356 0.239l0.008 0.003 0.001 0c0.141 0.060 0.306 0.095 0.478 0.095 0.345 0 0.657-0.139 0.883-0.365l5.001-5c0.226-0.226 0.366-0.539 0.366-0.884 0-0.691-0.56-1.251-1.251-1.251-0.345 0-0.658 0.14-0.884 0.366l-2.865 2.867v-18.982c0-0.69-0.56-1.25-1.25-1.25s-1.25 0.56-1.25 1.25v0 18.981l-2.866-2.866c-0.226-0.226-0.539-0.366-0.884-0.366-0.691 0-1.251 0.56-1.251 1.251 0 0.346 0.14 0.658 0.367 0.885v0z`,
39
+ },
40
+ },
41
+ },
42
+ dataZoom: [
43
+ // Inside type for X-axis
44
+ {
45
+ type: 'inside',
46
+ xAxisIndex: 0,
47
+ filterMode: 'filter',
48
+ },
49
+ // Inside type for Y-axis
50
+ {
51
+ type: 'inside',
52
+ yAxisIndex: 0,
53
+ filterMode: 'filter',
54
+ orient: 'vertical',
55
+ },
56
+ {
57
+ type: 'slider',
58
+ xAxisIndex: 0,
59
+ filterMode: 'filter',
60
+ },
61
+ {
62
+ type: 'slider',
63
+ yAxisIndex: 0,
64
+ filterMode: 'filter',
65
+ orient: 'vertical',
66
+ },
67
+ ],
68
+ visualMap: {
69
+ min: 0,
70
+ max: 10,
71
+ dimension: 2,
72
+ orient: 'vertical',
73
+ top: 'center',
74
+ left: 0,
75
+ text: ['log2\n(tpm+1)', ''],
76
+ textGap: 10,
77
+ calculable: true,
78
+ inRange: {
79
+ color: ['#808080', '#FFA500', '#FF0000'],
80
+ },
81
+ textStyle: {
82
+ writingMode: 'vertical-lr',
83
+ },
84
+ },
85
+ tooltip: {
86
+ trigger: 'item',
87
+ axisPointer: {
88
+ type: 'cross',
89
+ },
90
+ formatter: (params) => {
91
+ let express = params.data.value[2];
92
+ let round_epxress = express
93
+ ? Math.round(express * 10000) / 10000
94
+ : 0;
95
+ return `
96
+ <div style="text-align: center;">
97
+ ${params.data.Cell_ID}
98
+ <br/> Type: <strong>${params.data.Celltype} </strong>
99
+ ${
100
+ express !== undefined
101
+ ? '<br/> Expression: <strong>' + round_epxress + '</strong>'
102
+ : ''
103
+ }
104
+ </div>
105
+ `;
106
+ },
107
+ },
108
+ visualify: {
109
+ mapping: {
110
+ x: 'X_Coord',
111
+ y: 'Y_Coord',
112
+ extra: {
113
+ Cell_ID: 'Cell_ID',
114
+ Celltype: 'Cell_Type',
115
+ },
116
+ },
117
+ seriesBy: 'Cell_Type',
118
+ symbolSize: 5,
119
+ symbol: 'circle',
120
+ merger: {
121
+ gene: {
122
+ item: 'Cell_ID',
123
+ label: 'Expression',
124
+ visualMap: true,
125
+ },
126
+ },
127
+ },
128
+ };
129
+
130
+ export default esodev_codex;
@@ -0,0 +1,123 @@
1
+ const esodev_visium = {
2
+ title: {
3
+ textStyle: {
4
+ fontSize: 20,
5
+ },
6
+ left: 'center',
7
+ top: 0,
8
+ },
9
+ animation: false,
10
+ legend: {
11
+ show: false,
12
+ },
13
+ xAxis: {
14
+ show: false,
15
+ },
16
+ yAxis: {
17
+ show: false,
18
+ },
19
+ series: [],
20
+ grid: {
21
+ top: '15%',
22
+ bottom: '12%',
23
+ left: '5%',
24
+ right: '10%',
25
+ },
26
+ // ... other default settings for charts
27
+ toolbox: {
28
+ feature: {
29
+ saveAsImage: {
30
+ show: true,
31
+ icon: `path://M30 20.75c-0.69 0.001-1.249 0.56-1.25 1.25v6.75h-25.5v-6.75c0-0.69-0.56-1.25-1.25-1.25s-1.25 0.56-1.25 1.25v0 8c0 0.69 0.56 1.25 1.25 1.25h28c0.69-0.001 1.249-0.56 1.25-1.25v-8c-0.001-0.69-0.56-1.249-1.25-1.25h-0zM15.116 24.885c0.012 0.012 0.029 0.016 0.041 0.027 0.103 0.099 0.223 0.18 0.356 0.239l0.008 0.003 0.001 0c0.141 0.060 0.306 0.095 0.478 0.095 0.345 0 0.657-0.139 0.883-0.365l5.001-5c0.226-0.226 0.366-0.539 0.366-0.884 0-0.691-0.56-1.251-1.251-1.251-0.345 0-0.658 0.14-0.884 0.366l-2.865 2.867v-18.982c0-0.69-0.56-1.25-1.25-1.25s-1.25 0.56-1.25 1.25v0 18.981l-2.866-2.866c-0.226-0.226-0.539-0.366-0.884-0.366-0.691 0-1.251 0.56-1.251 1.251 0 0.346 0.14 0.658 0.367 0.885v0z`,
32
+ },
33
+ },
34
+ },
35
+ dataZoom: [],
36
+ visualMap: {
37
+ min: 0,
38
+ max: 10,
39
+ dimension: 2,
40
+ orient: 'horizontal',
41
+ top: 'bottom',
42
+ right: 'center',
43
+ text: ['log2\n(tpm+1)', ''],
44
+ textGap: 10,
45
+ calculable: true,
46
+ inRange: {
47
+ color: ['#808080', '#FFA500', '#FF0000'],
48
+ },
49
+ textStyle: {
50
+ writingMode: 'vertical-lr',
51
+ },
52
+ },
53
+ tooltip: {
54
+ trigger: 'item',
55
+ axisPointer: {
56
+ type: 'cross',
57
+ },
58
+ formatter: (params) => {
59
+ let resultHtml = '';
60
+ for (const [key, value] of Object.entries(params.data)) {
61
+ if (key === 'Expression') {
62
+ continue;
63
+ }
64
+ if (value > 0.5) {
65
+ // Only show the cell type with likelihood >= 0.5
66
+ resultHtml += `<br>${key}: ${value.toFixed(3)}`;
67
+ }
68
+ }
69
+ return `
70
+ <div style="text-align: center;">
71
+ ${params.name}
72
+ <br> Cell2Location Cell Type Likelihood
73
+ <br> (Likelihood >= 0.5)
74
+ ${resultHtml}
75
+ </div>
76
+ `;
77
+ },
78
+ },
79
+ visualify: {
80
+ mapping: {
81
+ x: 'X_Coord',
82
+ y: 'Y_Coord',
83
+ extra: {
84
+ BC: 'BC',
85
+ 'SB-1': 'SB-1',
86
+ 'SB-2': 'SB-2',
87
+ 'SB-3': 'SB-3',
88
+ 'SB-4': 'SB-4',
89
+ 'SB-5': 'SB-5',
90
+ 'Cil-1': 'Cil-1',
91
+ 'Cil-2': 'Cil-2',
92
+ 'Cy.Epi': 'Cy.Epi',
93
+ Fib_PG: 'Fib_PG',
94
+ Fib_1: 'Fib_1',
95
+ Fib_2: 'Fib_2',
96
+ Fib_3: 'Fib_3',
97
+ Fib_4: 'Fib_4',
98
+ Fib_5: 'Fib_5',
99
+ MF: 'MF',
100
+ Fib_ICC: 'Fib_ICC',
101
+ 'Cy.Fib': 'Cy.Fib',
102
+ ENS_PG: 'ENS_PG',
103
+ Neu: 'Neu',
104
+ Glia: 'Glia',
105
+ 'Cy.ENS': 'Cy.ENS',
106
+ Ven: 'Ven',
107
+ Art: 'Art',
108
+ Lym: 'Lym',
109
+ Peri: 'Peri',
110
+ 'Cy.Peri': 'Cy.Peri',
111
+ SM: 'SM',
112
+ 'Cy.SM': 'Cy.SM',
113
+ MS: 'MS',
114
+ SkM: 'SkM',
115
+ },
116
+ },
117
+ merger: {},
118
+ symbolSize: 2,
119
+ symbol: 'circle',
120
+ },
121
+ };
122
+
123
+ export default esodev_visium;