mobility-toolbox-js 2.0.0-beta.1 → 2.0.0-beta.6

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 (303) hide show
  1. package/.babelrc +6 -0
  2. package/.esdoc.json +17 -0
  3. package/.eslintignore +1 -0
  4. package/.github/workflows/conventional-pr-title.yml +21 -0
  5. package/.github/workflows/cypress.yml +29 -0
  6. package/.github/workflows/nodejs.yml +28 -0
  7. package/.husky/commit-msg +4 -0
  8. package/.husky/post-checkout +4 -0
  9. package/.husky/post-merge +4 -0
  10. package/.husky/post-rebase +4 -0
  11. package/.husky/pre-commit +4 -0
  12. package/.neutrinorc.js +176 -0
  13. package/.nvmrc +1 -0
  14. package/CHANGELOG.md +10 -0
  15. package/LICENSE +21 -0
  16. package/Layer.js +2 -0
  17. package/Layer.js.map +7 -0
  18. package/README.md +7 -4
  19. package/__mocks__/mapbox-gl.js +81 -0
  20. package/__mocks__/maplibre-gl.js +81 -0
  21. package/commitlint.config.js +1 -0
  22. package/cypress/fixtures/example.json +5 -0
  23. package/cypress/integration/examples/api.spec.js +7 -0
  24. package/cypress/integration/examples/examples.spec.js +7 -0
  25. package/cypress/integration/examples/navigation.spec.js +29 -0
  26. package/cypress/plugins/index.js +21 -0
  27. package/cypress/support/commands.js +25 -0
  28. package/cypress/support/index.js +20 -0
  29. package/cypress.json +4 -0
  30. package/data/fetchRoute.json +292 -0
  31. package/data/fetchTrajectories.json +18 -0
  32. package/data/fetchTrajectoryById.json +3 -0
  33. package/data/fetchTrajectoryStations.json +18 -0
  34. package/data/stopsSearch.json +15 -0
  35. package/documentation.yml +4 -0
  36. package/esdoc/README.md +27 -0
  37. package/esdoc/plugins/MyPlugin.js +69 -0
  38. package/esdoc/plugins/dynamic-property-plugin/Plugin.js +50 -0
  39. package/esdoc/plugins/externals-plugin/Plugin.js +45 -0
  40. package/esdoc/plugins/externals-plugin/externals.js +96 -0
  41. package/global-setup.js +3 -0
  42. package/{ol/README.md → index.html} +0 -0
  43. package/indexweb.html +49 -0
  44. package/jest.config.js +5 -0
  45. package/package.json +34 -13
  46. package/pull_request_template.md +17 -0
  47. package/renovate.json +4 -0
  48. package/scripts/read-pkg-json.js +22 -0
  49. package/{api → src/api}/index.js +0 -1
  50. package/{api → src/api}/routing/RoutingAPI.js +0 -0
  51. package/{api → src/api}/routing/RoutingAPI.test.js +0 -0
  52. package/{api → src/api}/stops/StopsAPI.js +0 -0
  53. package/{api → src/api}/stops/StopsAPI.test.js +0 -0
  54. package/{api → src/api}/tralis/TralisAPI.js +1 -1
  55. package/{api → src/api}/tralis/TralisAPI.test.js +0 -0
  56. package/{api → src/api}/tralis/TralisAPIUtils.js +0 -0
  57. package/{api → src/api}/tralis/WebSocketConnector.js +0 -0
  58. package/{api → src/api}/tralis/WebSocketConnector.test.js +0 -0
  59. package/{api → src/api}/tralis/typedefs.js +0 -0
  60. package/src/assets/Lato-Black.ttf +0 -0
  61. package/src/assets/Lato-BlackItalic.ttf +0 -0
  62. package/src/assets/Lato-Bold.ttf +0 -0
  63. package/src/assets/Lato-BoldItalic.ttf +0 -0
  64. package/src/assets/Lato-Italic.ttf +0 -0
  65. package/src/assets/Lato-Light.ttf +0 -0
  66. package/src/assets/Lato-LightItalic.ttf +0 -0
  67. package/src/assets/Lato-Regular.ttf +0 -0
  68. package/src/assets/Lato-Thin.ttf +0 -0
  69. package/src/assets/Lato-ThinItalic.ttf +0 -0
  70. package/src/assets/OFL.txt +93 -0
  71. package/{common → src/common}/Tracker.js +0 -0
  72. package/{common → src/common}/api/api.js +0 -0
  73. package/{common → src/common}/api/api.test.js +0 -0
  74. package/{common → src/common}/controls/Control.js +4 -1
  75. package/{common → src/common}/controls/Control.test.js +0 -0
  76. package/{common → src/common}/layers/Layer.js +18 -49
  77. package/{common → src/common}/layers/Layer.test.js +2 -106
  78. package/{common → src/common}/mixins/CopyrightMixin.js +0 -0
  79. package/{common → src/common}/mixins/SearchMixin.js +1 -1
  80. package/{common/mixins/TrackerLayerMixin.js → src/common/mixins/TralisLayerMixin.js} +380 -195
  81. package/src/common/styles/index.js +4 -0
  82. package/{common/utils/delayTrackerStyle.js → src/common/styles/trackerDefaultStyle.js} +8 -8
  83. package/src/common/styles/trackerDelayStyle.js +17 -0
  84. package/src/common/styles/trackerSimpleStyle.js +22 -0
  85. package/{common → src/common}/trackerConfig.js +0 -0
  86. package/{common → src/common}/trackerConfig.test.js +0 -13
  87. package/{common → src/common}/typedefs.js +0 -0
  88. package/{common → src/common}/utils/createTrackerFilters.js +0 -0
  89. package/{common → src/common}/utils/createTrackerFilters.test.js +0 -0
  90. package/{common → src/common}/utils/getMapboxMapCopyrights.js +1 -0
  91. package/{common → src/common}/utils/getMapboxMapCopyrights.test.js +0 -0
  92. package/{common → src/common}/utils/getMapboxStyleUrl.js +0 -0
  93. package/{common → src/common}/utils/getVehiclePosition.js +0 -0
  94. package/{common → src/common}/utils/index.js +2 -3
  95. package/{common → src/common}/utils/removeDuplicate.js +0 -0
  96. package/{common → src/common}/utils/removeDuplicate.test.js +0 -0
  97. package/src/common/utils/sortByDelay.js +23 -0
  98. package/{common → src/common}/utils/timeUtils.js +0 -0
  99. package/{common → src/common}/utils/timeUtils.test.js +0 -0
  100. package/src/doc/App.js +116 -0
  101. package/src/doc/App.scss +51 -0
  102. package/src/doc/_redirects +2 -0
  103. package/src/doc/components/CodeSandboxButton.js +103 -0
  104. package/src/doc/components/Documentation.js +40 -0
  105. package/src/doc/components/Esdoc/Anchor.js +57 -0
  106. package/src/doc/components/Esdoc/ClassDoc.js +272 -0
  107. package/src/doc/components/Esdoc/DeprecatedHTML.js +16 -0
  108. package/src/doc/components/Esdoc/DetailDocs.js +281 -0
  109. package/src/doc/components/Esdoc/DetailHTML.js +33 -0
  110. package/src/doc/components/Esdoc/DirectSubclassHTML.js +30 -0
  111. package/src/doc/components/Esdoc/DocBuilderUtils.js +694 -0
  112. package/src/doc/components/Esdoc/DocLinkHTML.js +62 -0
  113. package/src/doc/components/Esdoc/DocsLinkHTML.js +38 -0
  114. package/src/doc/components/Esdoc/Esdoc.js +63 -0
  115. package/src/doc/components/Esdoc/EsdocContent.js +51 -0
  116. package/src/doc/components/Esdoc/EsdocNavigation.js +13 -0
  117. package/src/doc/components/Esdoc/EsdocSearch.js +81 -0
  118. package/src/doc/components/Esdoc/ExperimentalHTML.js +17 -0
  119. package/src/doc/components/Esdoc/ExtendsChainHTML.js +32 -0
  120. package/src/doc/components/Esdoc/FileDocLinkHTML.js +60 -0
  121. package/src/doc/components/Esdoc/IdentifiersDoc.js +113 -0
  122. package/src/doc/components/Esdoc/IndirectSubclassHTML.js +30 -0
  123. package/src/doc/components/Esdoc/InheritedSummaryDoc.js +70 -0
  124. package/src/doc/components/Esdoc/InheritedSummaryHTML.js +38 -0
  125. package/src/doc/components/Esdoc/MixinClassesHTML.js +29 -0
  126. package/src/doc/components/Esdoc/NavDoc.js +112 -0
  127. package/src/doc/components/Esdoc/OverrideMethod.js +44 -0
  128. package/src/doc/components/Esdoc/OverrideMethodDescription.js +35 -0
  129. package/src/doc/components/Esdoc/Properties.js +89 -0
  130. package/src/doc/components/Esdoc/README.md +45 -0
  131. package/src/doc/components/Esdoc/SignatureHTML.js +123 -0
  132. package/src/doc/components/Esdoc/SingleDoc.js +31 -0
  133. package/src/doc/components/Esdoc/SummaryDoc.js +160 -0
  134. package/src/doc/components/Esdoc/SummaryHTML.js +96 -0
  135. package/src/doc/components/Esdoc/TypeDocLinkHTML.js +249 -0
  136. package/src/doc/components/Esdoc/css/identifiers.css +38 -0
  137. package/src/doc/components/Esdoc/css/search.css +76 -0
  138. package/src/doc/components/Esdoc/css/style.css +603 -0
  139. package/src/doc/components/Esdoc/index.js +7 -0
  140. package/src/doc/components/Example.js +153 -0
  141. package/src/doc/components/Examples.js +183 -0
  142. package/src/doc/components/Home.js +106 -0
  143. package/src/doc/components/TrackerExample.js +38 -0
  144. package/src/doc/components/esm.min.js +2 -0
  145. package/src/doc/components/examples/assets/tralis-live-map/index.js +11 -0
  146. package/src/doc/components/examples/assets/tralis-live-map/s1kreis.svg +105 -0
  147. package/src/doc/components/examples/assets/tralis-live-map/s20kreis.svg +101 -0
  148. package/src/doc/components/examples/assets/tralis-live-map/s2kreis.svg +95 -0
  149. package/src/doc/components/examples/assets/tralis-live-map/s3kreis.svg +95 -0
  150. package/src/doc/components/examples/assets/tralis-live-map/s4kreis.svg +95 -0
  151. package/src/doc/components/examples/assets/tralis-live-map/s6kreis.svg +95 -0
  152. package/src/doc/components/examples/assets/tralis-live-map/s7kreis.svg +95 -0
  153. package/src/doc/components/examples/assets/tralis-live-map/s8kreis.svg +93 -0
  154. package/src/doc/components/examples/assets/tralis-live-map/unknown.svg +107 -0
  155. package/src/doc/components/examples/mb-copyright.html +26 -0
  156. package/src/doc/components/examples/mb-copyright.js +37 -0
  157. package/src/doc/components/examples/mb-tracker.html +1 -0
  158. package/src/doc/components/examples/mb-tracker.js +39 -0
  159. package/src/doc/components/examples/mb-tracker.md +1 -0
  160. package/src/doc/components/examples/mb-tralis.html +1 -0
  161. package/src/doc/components/examples/mb-tralis.js +34 -0
  162. package/src/doc/components/examples/ol-copyright.html +26 -0
  163. package/src/doc/components/examples/ol-copyright.js +43 -0
  164. package/src/doc/components/examples/ol-mapbox-layer.html +1 -0
  165. package/src/doc/components/examples/ol-mapbox-layer.js +28 -0
  166. package/src/doc/components/examples/ol-mapbox-layer.md +0 -0
  167. package/src/doc/components/examples/ol-mapbox-style-layer.html +12 -0
  168. package/src/doc/components/examples/ol-mapbox-style-layer.js +44 -0
  169. package/src/doc/components/examples/ol-query.html +32 -0
  170. package/src/doc/components/examples/ol-query.js +83 -0
  171. package/src/doc/components/examples/ol-routing.html +26 -0
  172. package/src/doc/components/examples/ol-routing.js +59 -0
  173. package/src/doc/components/examples/ol-routing.md +1 -0
  174. package/src/doc/components/examples/ol-stop-finder.html +15 -0
  175. package/src/doc/components/examples/ol-stop-finder.js +31 -0
  176. package/src/doc/components/examples/ol-stop-finder.md +1 -0
  177. package/src/doc/components/examples/ol-tracker.html +1 -0
  178. package/src/doc/components/examples/ol-tracker.js +44 -0
  179. package/src/doc/components/examples/ol-tracker.md +1 -0
  180. package/src/doc/components/examples/ol-tralis.html +5 -0
  181. package/src/doc/components/examples/ol-tralis.js +57 -0
  182. package/src/doc/components/examples/tralis-live-map.html +1 -0
  183. package/src/doc/components/examples/tralis-live-map.js +51 -0
  184. package/src/doc/components/examples/tralis-live-map.md +3 -0
  185. package/src/doc/examples/assets/tralis-live-map/index.js +11 -0
  186. package/src/doc/examples/assets/tralis-live-map/s1kreis.svg +105 -0
  187. package/src/doc/examples/assets/tralis-live-map/s20kreis.svg +101 -0
  188. package/src/doc/examples/assets/tralis-live-map/s2kreis.svg +95 -0
  189. package/src/doc/examples/assets/tralis-live-map/s3kreis.svg +95 -0
  190. package/src/doc/examples/assets/tralis-live-map/s4kreis.svg +95 -0
  191. package/src/doc/examples/assets/tralis-live-map/s6kreis.svg +95 -0
  192. package/src/doc/examples/assets/tralis-live-map/s7kreis.svg +95 -0
  193. package/src/doc/examples/assets/tralis-live-map/s8kreis.svg +93 -0
  194. package/src/doc/examples/assets/tralis-live-map/unknown.svg +107 -0
  195. package/src/doc/examples/mb-copyright.html +26 -0
  196. package/src/doc/examples/mb-copyright.js +37 -0
  197. package/src/doc/examples/mb-tracker.html +1 -0
  198. package/src/doc/examples/mb-tracker.js +39 -0
  199. package/src/doc/examples/mb-tracker.md +1 -0
  200. package/src/doc/examples/mb-tralis.html +1 -0
  201. package/src/doc/examples/mb-tralis.js +34 -0
  202. package/src/doc/examples/ol-copyright.html +26 -0
  203. package/src/doc/examples/ol-copyright.js +43 -0
  204. package/src/doc/examples/ol-mapbox-layer.html +1 -0
  205. package/src/doc/examples/ol-mapbox-layer.js +28 -0
  206. package/src/doc/examples/ol-mapbox-layer.md +0 -0
  207. package/src/doc/examples/ol-mapbox-style-layer.html +12 -0
  208. package/src/doc/examples/ol-mapbox-style-layer.js +44 -0
  209. package/src/doc/examples/ol-query.html +32 -0
  210. package/src/doc/examples/ol-query.js +83 -0
  211. package/src/doc/examples/ol-routing.html +26 -0
  212. package/src/doc/examples/ol-routing.js +59 -0
  213. package/src/doc/examples/ol-routing.md +1 -0
  214. package/src/doc/examples/ol-stop-finder.html +15 -0
  215. package/src/doc/examples/ol-stop-finder.js +31 -0
  216. package/src/doc/examples/ol-stop-finder.md +1 -0
  217. package/src/doc/examples/ol-tracker.html +1 -0
  218. package/src/doc/examples/ol-tracker.js +44 -0
  219. package/src/doc/examples/ol-tracker.md +1 -0
  220. package/src/doc/examples/ol-tralis.html +5 -0
  221. package/src/doc/examples/ol-tralis.js +57 -0
  222. package/src/doc/examples/tralis-live-map.html +1 -0
  223. package/src/doc/examples/tralis-live-map.js +51 -0
  224. package/src/doc/examples/tralis-live-map.md +3 -0
  225. package/src/doc/examples.js +107 -0
  226. package/src/doc/img/examples/live_tracker_mb.jpg +0 -0
  227. package/src/doc/img/examples/live_tracker_munich.jpg +0 -0
  228. package/src/doc/img/examples/live_tracker_ol.jpg +0 -0
  229. package/src/doc/img/examples/mapbox.jpg +0 -0
  230. package/src/doc/img/examples/mapbox_style.jpg +0 -0
  231. package/src/doc/img/examples/ol-copyright.png +0 -0
  232. package/src/doc/img/examples/query_objects.jpg +0 -0
  233. package/src/doc/img/examples/routing.jpg +0 -0
  234. package/src/doc/img/examples/simple_map.jpg +0 -0
  235. package/src/doc/img/examples/stops.jpg +0 -0
  236. package/src/doc/img/favico.ico +0 -0
  237. package/src/doc/index.js +21 -0
  238. package/src/iife.js +7 -0
  239. package/{module.js → src/index.js} +3 -9
  240. package/{mapbox → src/mapbox}/controls/CopyrightControl.js +5 -1
  241. package/{mapbox → src/mapbox}/index.js +0 -2
  242. package/{mapbox → src/mapbox}/layers/Layer.js +0 -0
  243. package/{mapbox → src/mapbox}/layers/Layer.test.js +2 -2
  244. package/{mapbox/layers/TrackerLayer.js → src/mapbox/layers/TralisLayer.js} +71 -24
  245. package/src/mapbox/layers/TralisLayer.test.js +40 -0
  246. package/{mapbox → src/mapbox}/utils.js +0 -0
  247. package/src/ol/README.md +0 -0
  248. package/{ol → src/ol}/controls/CopyrightControl.js +4 -4
  249. package/{ol → src/ol}/controls/CopyrightControl.test.js +16 -16
  250. package/{ol → src/ol}/controls/RoutingControl.js +9 -7
  251. package/{ol → src/ol}/controls/RoutingControl.test.js +1 -1
  252. package/{ol → src/ol}/controls/StopFinderControl.js +8 -6
  253. package/{ol → src/ol}/controls/StopFinderControl.test.js +1 -1
  254. package/{ol → src/ol}/controls/snapshots/RoutingControlRouteGen10.json +0 -0
  255. package/{ol → src/ol}/controls/snapshots/RoutingControlRouteGen100.json +0 -0
  256. package/{ol → src/ol}/controls/snapshots/RoutingControlRouteGen30.json +0 -0
  257. package/{ol → src/ol}/controls/snapshots/RoutingControlRouteGen5.json +0 -0
  258. package/{ol → src/ol}/controls/snapshots/RoutingControlRouteOSM.json +0 -0
  259. package/{ol → src/ol}/controls/snapshots/RoutingControlStation1.json +0 -0
  260. package/{ol → src/ol}/controls/snapshots/RoutingControlStation2.json +0 -0
  261. package/{ol → src/ol}/index.js +3 -3
  262. package/{ol → src/ol}/layers/Layer.js +9 -0
  263. package/{ol → src/ol}/layers/Layer.test.js +22 -7
  264. package/{ol → src/ol}/layers/MapboxLayer.js +39 -44
  265. package/{ol → src/ol}/layers/MapboxLayer.test.js +5 -5
  266. package/{ol → src/ol}/layers/MapboxStyleLayer.js +0 -6
  267. package/{ol → src/ol}/layers/MapboxStyleLayer.test.js +22 -6
  268. package/src/ol/layers/MaplibreLayer.js +280 -0
  269. package/{ol → src/ol}/layers/RoutingLayer.js +0 -0
  270. package/{ol → src/ol}/layers/RoutingLayer.test.js +1 -1
  271. package/{ol/layers/TrackerLayer.js → src/ol/layers/TralisLayer.js} +96 -33
  272. package/{ol → src/ol}/layers/TralisLayer.test.js +1 -49
  273. package/{ol → src/ol}/layers/VectorLayer.js +0 -0
  274. package/{ol → src/ol}/layers/VectorLayer.test.js +1 -1
  275. package/{ol → src/ol}/layers/WMSLayer.js +0 -0
  276. package/{ol → src/ol}/layers/WMSLayer.test.js +6 -2
  277. package/src/ol/styles/fullTrajectoryDelayStyle.js +35 -0
  278. package/src/ol/styles/fullTrajectoryStyle.js +51 -0
  279. package/src/ol/styles/index.js +2 -0
  280. package/src/setupTests.js +15 -0
  281. package/webpack.config.js +6 -0
  282. package/api/trajserv/TrajservAPI.js +0 -71
  283. package/api/trajserv/TrajservAPI.test.js +0 -171
  284. package/api/trajserv/TrajservAPIUtils.js +0 -191
  285. package/api/trajserv/TrajservAPIUtils.test.js +0 -40
  286. package/api/trajserv/typedefs.js +0 -44
  287. package/common/mixins/MapMixin.js +0 -103
  288. package/common/mixins/TrajservLayerMixin.js +0 -544
  289. package/common/mixins/TralisLayerMixin.js +0 -402
  290. package/common/utils/simpleTrackerStyle.js +0 -18
  291. package/index.js +0 -2
  292. package/index.js.map +0 -1
  293. package/mapbox/Map.js +0 -87
  294. package/mapbox/layers/TrackerLayer.test.js +0 -68
  295. package/mapbox/layers/TrajservLayer.js +0 -114
  296. package/mapbox/layers/TrajservLayer.test.js +0 -90
  297. package/mapbox/layers/TralisLayer.js +0 -64
  298. package/ol/Map.js +0 -109
  299. package/ol/Map.test.js +0 -34
  300. package/ol/layers/TrackerLayer.test.js +0 -70
  301. package/ol/layers/TrajservLayer.js +0 -190
  302. package/ol/layers/TrajservLayer.test.js +0 -113
  303. package/ol/layers/TralisLayer.js +0 -177
@@ -0,0 +1,272 @@
1
+ /* eslint-disable no-underscore-dangle */
2
+ /* eslint-disable react/prop-types */
3
+ import React from 'react';
4
+ import { makeStyles } from '@material-ui/core/styles';
5
+ import { Prism as SyntaxHighlighter } from 'react-syntax-highlighter';
6
+ import Markdown from 'react-markdown';
7
+ import FileDocLinkHTML from './FileDocLinkHTML';
8
+ import MixinClassesHTML from './MixinClassesHTML';
9
+ import ExtendsChainHTML from './ExtendsChainHTML';
10
+ import DirectSubclassHTML from './DirectSubclassHTML';
11
+ import IndirectSubclassHTML from './IndirectSubclassHTML';
12
+ import DocsLinkHTML from './DocsLinkHTML';
13
+ import SummaryHTML from './SummaryHTML';
14
+ import DetailHTML from './DetailHTML';
15
+ import ExperimentalHTML from './ExperimentalHTML';
16
+ import DeprecatedHTML from './DeprecatedHTML';
17
+ import { parseExample } from './DocBuilderUtils';
18
+
19
+ const useStyles = makeStyles({
20
+ root: {
21
+ height: '100%',
22
+ width: '100%',
23
+ },
24
+ });
25
+
26
+ /**
27
+ * build class output.
28
+ * https://github.com/esdoc/esdoc-plugins/blob/2de5022baa569785a189056a99acd1d7ca8284b7/esdoc-publish-html-plugin/src/Builder/ClassDocBuilder.js#L30
29
+ * @param {DocObject} doc - class doc object.
30
+ * @returns {IceCap} built output.
31
+ * @private
32
+ */
33
+ function ClassDoc({ doc }) {
34
+ const classes = useStyles();
35
+ if (!doc) {
36
+ return null;
37
+ }
38
+ const { name, access, version, since } = doc;
39
+
40
+ return (
41
+ <div className={classes.root}>
42
+ <div className="header-notice">
43
+ {/*
44
+ doc.export && importPath && importStyle && (
45
+ <div data-ice="importPath" className="import-path">
46
+ <SyntaxHighlighter language="js">
47
+ {`import ${importStyle} from '${importPath}';`}
48
+ </SyntaxHighlighter>
49
+ </div>
50
+ )
51
+ */}
52
+ <span>{access}</span>
53
+ <span>{doc.interface ? ' interface' : ' class'}</span>
54
+ {/* TODO
55
+ <span data-ice="variation"> | variation </span> */}
56
+ {version && <span> | {version}</span>}
57
+ {since && <span> | {since}</span>}
58
+ <span>
59
+ | <FileDocLinkHTML doc={doc} text="source" />
60
+ </span>
61
+ </div>
62
+
63
+ <div className="self-detail detail">
64
+ <h1>{name}</h1>
65
+ {/* TODO
66
+ <div data-ice="instanceDocs" className="instance-docs">
67
+ <span>You can directly use an instance of this class.</span>
68
+ <span data-ice="instanceDoc" />
69
+ </div> */}
70
+ {/* TODO
71
+ <div className="expression-extends" data-ice="expressionExtends">
72
+ <h4>Expression Extends:</h4>
73
+ <pre className="prettyprint">
74
+ <code data-ice="expressionExtendsCode" />
75
+ </pre>
76
+ </div> */}
77
+ <MixinClassesHTML doc={doc} />
78
+ <ExtendsChainHTML doc={doc} />
79
+ <DirectSubclassHTML doc={doc} />
80
+ <IndirectSubclassHTML doc={doc} />
81
+ {doc.implements && doc.implements.length && (
82
+ <div className="flat-list" data-ice="implements">
83
+ <h4>Implements:</h4>
84
+ <DocsLinkHTML
85
+ longnames={doc.implements}
86
+ text={null}
87
+ inner={false}
88
+ separator=", "
89
+ />
90
+ </div>
91
+ )}
92
+ {doc._custom_indirect_implements &&
93
+ doc._custom_indirect_implements.length && (
94
+ <div className="flat-list" data-ice="indirectImplements">
95
+ <h4>Indirect Implements:</h4>
96
+ <DocsLinkHTML
97
+ longnames={doc._custom_indirect_implements}
98
+ text={null}
99
+ inner={false}
100
+ separator=", "
101
+ />
102
+ </div>
103
+ )}
104
+ {doc._custom_direct_implemented &&
105
+ doc._custom_direct_implemented.length && (
106
+ <div className="flat-list" data-ice="directImplemented">
107
+ <h4>Direct Implemented:</h4>
108
+ <DocsLinkHTML
109
+ longnames={doc._custom_direct_implemented}
110
+ text={null}
111
+ inner={false}
112
+ separator=", "
113
+ />
114
+ </div>
115
+ )}
116
+ {doc._custom_indirect_implemented &&
117
+ doc._custom_indirect_implemented.length && (
118
+ <div className="flat-list" data-ice="indirectImplemented">
119
+ <h4>Indirect Implemented:</h4>
120
+ <DocsLinkHTML
121
+ longnames={doc._custom_indirect_implemented}
122
+ text={null}
123
+ inner={false}
124
+ separator=", "
125
+ />
126
+ </div>
127
+ )}
128
+ <div className="deprecated" data-ice="deprecated">
129
+ <DeprecatedHTML doc={doc} />
130
+ </div>
131
+ <div className="experimental" data-ice="experimental">
132
+ <ExperimentalHTML doc={doc} />
133
+ </div>
134
+ <div className="description">
135
+ <Markdown>{doc.description}</Markdown>
136
+ </div>
137
+ {/* TODO
138
+ <div className="decorator" data-ice="decorator">
139
+ <h4>Decorators:</h4>
140
+ </div> */}
141
+ {doc.see && doc.see.length && (
142
+ <div data-ice="see">
143
+ <h4>See:</h4>
144
+ <DocsLinkHTML longnames={doc.see} />
145
+ </div>
146
+ )}
147
+ {doc.examples && doc.examples.length && (
148
+ <div data-ice="exampleDocs">
149
+ <h4>Example:</h4>
150
+
151
+ <div className="example-doc" data-ice="exampleDoc">
152
+ {doc.examples.map((example) => {
153
+ const parsed = parseExample(example);
154
+ return (
155
+ <React.Fragment key={example}>
156
+ {parsed.caption && (
157
+ <div
158
+ className="example-caption"
159
+ data-ice="exampleCaption"
160
+ >
161
+ {parsed.caption}
162
+ </div>
163
+ )}
164
+ {/* <pre className="prettyprint source-code"> */}
165
+ {parsed.body ? (
166
+ <SyntaxHighlighter language="js">
167
+ {parsed.body}
168
+ </SyntaxHighlighter>
169
+ ) : null}
170
+ {/* </pre> */}
171
+ </React.Fragment>
172
+ );
173
+ })}
174
+ </div>
175
+ </div>
176
+ )}
177
+ {/* TODO
178
+ <div data-ice="tests">
179
+ <h4>Test:</h4>
180
+ <ul>
181
+ <li data-ice="test" />
182
+ </ul>
183
+ </div> */}
184
+ {doc.todo && doc.todo.length && (
185
+ <div data-ice="todo">
186
+ <h4>TODO:</h4>
187
+ <DocsLinkHTML longnames={doc.todo} />
188
+ </div>
189
+ )}
190
+ </div>
191
+
192
+ <div data-ice="staticMemberSummary" className="hide-no-content">
193
+ <h2>Static Member Summary</h2>
194
+ <SummaryHTML doc={doc} kind="member" title="Members" isStatic />
195
+ </div>
196
+ <div data-ice="staticMethodSummary" className="hide-no-content">
197
+ <h2>Static Method Summary</h2>
198
+ <SummaryHTML doc={doc} kind="method" title="Methods" isStatic />
199
+ </div>
200
+ <div data-ice="constructorSummary" className="hide-no-content">
201
+ <h2>Constructor Summary</h2>
202
+ <SummaryHTML
203
+ doc={doc}
204
+ kind="constructor"
205
+ title="Constructor"
206
+ isStatic={false}
207
+ />
208
+ </div>
209
+ <div data-ice="memberSummary" className="hide-no-content">
210
+ <h2>Member Summary</h2>
211
+ <SummaryHTML
212
+ doc={doc}
213
+ kind="member"
214
+ title="Members"
215
+ isStatic={false}
216
+ inherited
217
+ />
218
+ {/*
219
+ <div
220
+ className="inherited-summary hide-no-content"
221
+ data-ice="inheritedSummary"
222
+ >
223
+ <h2>Inherited Member Summary</h2>
224
+ <InheritedSummaryHTML doc={doc} kind="member" />
225
+ </div>
226
+ */}
227
+ </div>
228
+ <div data-ice="methodSummary" className="hide-no-content">
229
+ <h2>Method Summary</h2>
230
+ <SummaryHTML
231
+ doc={doc}
232
+ kind="method"
233
+ title="Methods"
234
+ isStatic={false}
235
+ inherited
236
+ />
237
+ {/*
238
+ <div
239
+ className="inherited-summary hide-no-content"
240
+ data-ice="inheritedSummary"
241
+ >
242
+ <h2>Inherited Member Summary</h2>
243
+ <InheritedSummaryHTML doc={doc} kind="method" />
244
+ </div>
245
+ */}
246
+ </div>
247
+
248
+ <div data-ice="staticMemberDetails">
249
+ <DetailHTML doc={doc} kind="member" title="Members" isStatic />
250
+ </div>
251
+ <div data-ice="staticMethodDetails">
252
+ <DetailHTML doc={doc} kind="method" title="Methods" isStatic />
253
+ </div>
254
+ <div data-ice="constructorDetails">
255
+ <DetailHTML
256
+ doc={doc}
257
+ kind="constructor"
258
+ title="Constructors"
259
+ isStatic={false}
260
+ />
261
+ </div>
262
+ <div data-ice="memberDetails">
263
+ <DetailHTML doc={doc} kind="member" title="Members" isStatic={false} />
264
+ </div>
265
+ <div data-ice="methodDetails">
266
+ <DetailHTML doc={doc} kind="method" title="Methods" isStatic={false} />
267
+ </div>
268
+ </div>
269
+ );
270
+ }
271
+
272
+ export default React.memo(ClassDoc);
@@ -0,0 +1,16 @@
1
+ /**
2
+ * build deprecated html.
3
+ * https://github.com/esdoc/esdoc-plugins/blob/2de5022baa569785a189056a99acd1d7ca8284b7/esdoc-publish-html-plugin/src/Builder/DocBuilder.js#L920
4
+ * @param {DocObject} doc - target doc object.
5
+ * @returns {string} if doc is not deprecated, returns empty.
6
+ * @private
7
+ */
8
+ const DeprecatedHTML = (doc) => {
9
+ if (doc.deprecated) {
10
+ const deprecated = [`this ${doc.kind} was deprecated.`];
11
+ if (typeof doc.deprecated === 'string') deprecated.push(doc.deprecated);
12
+ return deprecated.join(' ');
13
+ }
14
+ return '';
15
+ };
16
+ export default DeprecatedHTML;
@@ -0,0 +1,281 @@
1
+ /* eslint-disable react/no-unescaped-entities */
2
+ /* eslint-disable react/prop-types */
3
+ /* eslint-disable no-continue */
4
+ /* eslint-disable no-restricted-syntax */
5
+ /* eslint-disable react/no-array-index-key */
6
+ /* eslint-disable no-underscore-dangle */
7
+ import React from 'react';
8
+ import SyntaxHighlighter from 'react-syntax-highlighter';
9
+ import Markdown from 'react-markdown';
10
+ import { parseExample } from './DocBuilderUtils';
11
+ import SignatureHTML from './SignatureHTML';
12
+ import OverrideMethodDescription from './OverrideMethodDescription';
13
+ import FileDocLinkHTML from './FileDocLinkHTML';
14
+ import OverrideMethod from './OverrideMethod';
15
+ import Properties from './Properties';
16
+ import TypeDocLinkHTML from './TypeDocLinkHTML';
17
+ import DocLinkHTML from './DocLinkHTML';
18
+ import DocsLinkHTML from './DocsLinkHTML';
19
+ import ExperimentalHTML from './ExperimentalHTML';
20
+ import DeprecatedHTML from './DeprecatedHTML';
21
+
22
+ /**
23
+ * build detail output html by docs.
24
+ * https://github.com/esdoc/esdoc-plugins/blob/2de5022baa569785a189056a99acd1d7ca8284b7/esdoc-publish-html-plugin/src/Builder/DocBuilder.js#L373
25
+ * @param {DocObject[]} docs - target docs.
26
+ * @param {string} title - detail title.
27
+ * @return {IceCap} detail output.
28
+ * @private
29
+ */
30
+ function DetailDocs({ docs, title }) {
31
+ return (
32
+ <>
33
+ <h2 data-ice="title">{title}</h2>
34
+ {docs.map((doc) => {
35
+ const scope = doc.static ? 'static' : 'instance';
36
+ let isFunction = false;
37
+ if (['method', 'constructor', 'function'].indexOf(doc.kind) !== -1)
38
+ isFunction = true;
39
+ if (
40
+ doc.kind === 'typedef' &&
41
+ doc.params &&
42
+ doc.type.types[0] === 'function'
43
+ )
44
+ isFunction = true;
45
+
46
+ return (
47
+ <div
48
+ className="detail"
49
+ data-ice="detail"
50
+ key={`${scope}-${doc.kind}-${doc.name}`}
51
+ id={`${scope}-${doc.kind}-${doc.name}`}
52
+ >
53
+ <span
54
+ className="anchor-offset"
55
+ id={`${scope}-${doc.kind}-${doc.name}-offset-anchor`}
56
+ />
57
+ <h3 data-ice="anchor">
58
+ {doc.access !== 'public' && (
59
+ <span className="access" data-ice="access">
60
+ {doc.access}{' '}
61
+ </span>
62
+ )}
63
+ {['member', 'method', 'get', 'set'].includes(doc.kind) && (
64
+ <span data-ice="static">{doc.static ? 'static ' : ''}</span>
65
+ )}
66
+ {['get', 'set'].includes(doc.kind) && (
67
+ <span className="kind" data-ice="kind">
68
+ {doc.kind}
69
+ </span>
70
+ )}
71
+ <span className="abstract" data-ice="abstract">
72
+ {doc.abstract ? 'abstract ' : ''}
73
+ </span>
74
+ <span data-ice="async">{doc.async ? 'async ' : ''}</span>
75
+ <span data-ice="generator">{doc.generator ? '* ' : ''}</span>
76
+ <span className="code" data-ice="name">
77
+ {doc.kind === 'constructor'
78
+ ? `new ${doc.longname.match(/~([^)]+)#constructor/)[1]}`
79
+ : doc.name}
80
+ </span>
81
+ <span className="code" data-ice="signature">
82
+ <SignatureHTML doc={doc} />
83
+ </span>
84
+ <span className="right-info">
85
+ {doc.version && (
86
+ <span className="version" data-ice="version">
87
+ version {doc.version}
88
+ </span>
89
+ )}
90
+ {doc.since && (
91
+ <span className="since" data-ice="since">
92
+ since {doc.since}
93
+ </span>
94
+ )}
95
+ <span data-ice="source">
96
+ <FileDocLinkHTML doc={doc} text="source" />
97
+ </span>
98
+ </span>
99
+ </h3>
100
+ {doc.export && doc.importPath && doc.importStyle && (
101
+ <div data-ice="importPath" className="import-path">
102
+ <SyntaxHighlighter language="js">
103
+ {`import ${doc.importStyle} from '${doc.importPath}';`}
104
+ </SyntaxHighlighter>
105
+ </div>
106
+ )}
107
+ <div className="deprecated" data-ice="deprecated">
108
+ <DeprecatedHTML doc={doc} />
109
+ </div>
110
+ <div className="experimental" data-ice="experimental">
111
+ <ExperimentalHTML doc={doc} />
112
+ </div>
113
+ <div data-ice="description">
114
+ {doc.description || <OverrideMethodDescription doc={doc} />}
115
+ </div>
116
+ <div data-ice="override" className="hide-no-content">
117
+ <h4>Override:</h4>
118
+ <OverrideMethod doc={doc} />
119
+ </div>
120
+ <div data-ice="properties">
121
+ {isFunction && doc.params && !!doc.params.length && (
122
+ <Properties properties={doc.params} title="Params:" />
123
+ )}
124
+ {!isFunction && doc.properties && !!doc.properties.length && (
125
+ <Properties properties={doc.properties} title="Properties:" />
126
+ )}
127
+ </div>
128
+ {doc.return && (
129
+ <div className="return-params" data-ice="returnParams">
130
+ <h4>Return:</h4>
131
+ <table>
132
+ <tbody>
133
+ <tr>
134
+ <td className="return-type code" data-ice="returnType">
135
+ {doc.return.types.map((typeName, idx) => {
136
+ return (
137
+ <React.Fragment key={idx}>
138
+ <TypeDocLinkHTML typeName={typeName} />
139
+ {idx !== doc.return.types.length - 1 ? ' | ' : ''}
140
+ </React.Fragment>
141
+ );
142
+ })}
143
+ {typeof doc.return.nullable === 'boolean' &&
144
+ `(nullable: ${doc.return.nullable})`}
145
+ </td>
146
+ <td className="return-desc" data-ice="returnDescription">
147
+ <Markdown>{doc.return.description}</Markdown>
148
+ </td>
149
+ </tr>
150
+ </tbody>
151
+ </table>
152
+ {doc.properties && (
153
+ <div data-ice="returnProperties">
154
+ <Properties
155
+ properties={doc.properties}
156
+ title="Return Properties:"
157
+ />
158
+ </div>
159
+ )}
160
+ </div>
161
+ )}
162
+ {doc.emits && (
163
+ <div data-ice="emitWrap">
164
+ <h4>Emit:</h4>
165
+ <table>
166
+ <tbody>
167
+ {doc.emits.map((emitDoc, idx) => {
168
+ return (
169
+ <tr key={idx} className="emit" data-ice="emit">
170
+ <td>
171
+ <p data-ice="emitName">
172
+ <DocLinkHTML longname={emitDoc.types[0]} />
173
+ </p>
174
+ </td>
175
+ <td data-ice="emitDesc">
176
+ <Markdown>{emitDoc.description}</Markdown>
177
+ </td>
178
+ </tr>
179
+ );
180
+ })}
181
+ </tbody>
182
+ </table>
183
+ </div>
184
+ )}
185
+ {doc.listens && (
186
+ <div data-ice="listenWrap">
187
+ <h4>Listen:</h4>
188
+ <table>
189
+ <tbody>
190
+ {doc.listens.map((listenDoc, idx) => {
191
+ return (
192
+ <tr key={idx} className="listen" data-ice="listen">
193
+ <td>
194
+ <p data-ice="listenName">
195
+ <DocLinkHTML longname={listenDoc.types[0]} />
196
+ </p>
197
+ </td>
198
+ <td data-ice="listenDesc">
199
+ <Markdown>{listenDoc.description}</Markdown>
200
+ </td>
201
+ </tr>
202
+ );
203
+ })}
204
+ </tbody>
205
+ </table>
206
+ </div>
207
+ )}
208
+ {doc.throws && (
209
+ <div data-ice="throwWrap">
210
+ <h4>Throw:</h4>
211
+ <table>
212
+ <tbody>
213
+ {doc.throws.map((exceptionDoc, idx) => {
214
+ return (
215
+ <tr key={idx} className="throw" data-ice="throw">
216
+ <td>
217
+ <p data-ice="throwName">
218
+ <DocLinkHTML longname={exceptionDoc.types[0]} />
219
+ </p>
220
+ </td>
221
+ <td data-ice="throwDesc">
222
+ <Markdown>{exceptionDoc.description}</Markdown>
223
+ </td>
224
+ </tr>
225
+ );
226
+ })}
227
+ </tbody>
228
+ </table>
229
+ </div>
230
+ )}
231
+ {/* TODO
232
+ <div data-ice="decorator">
233
+ <h4>Decorators:</h4>
234
+ </div> */}
235
+ {doc.examples && doc.examples.length && (
236
+ <div data-ice="example">
237
+ <h4>Example:</h4>
238
+ <div className="example-doc" data-ice="exampleDoc">
239
+ {doc.examples.map((example) => {
240
+ const parsed = parseExample(example);
241
+ return (
242
+ <React.Fragment key={example}>
243
+ {parsed.caption && (
244
+ <div
245
+ className="example-caption"
246
+ data-ice="exampleCaption"
247
+ >
248
+ {parsed.caption}
249
+ </div>
250
+ )}
251
+ <SyntaxHighlighter language="js">
252
+ {parsed.body}
253
+ </SyntaxHighlighter>
254
+ </React.Fragment>
255
+ );
256
+ })}
257
+ </div>
258
+ </div>
259
+ )}
260
+ {/* TODO
261
+ <div data-ice="tests">
262
+ <h4>Test:</h4>
263
+ <ul>
264
+ <li data-ice="test" />
265
+ </ul>
266
+ </div> */}
267
+ <div data-ice="see" className="hide-no-content">
268
+ <h4>See:</h4>
269
+ <DocsLinkHTML longnames={doc.see} />
270
+ </div>
271
+ {/* TODO
272
+ <div data-ice="todo">
273
+ <h4>TODO:</h4>
274
+ </div> */}
275
+ </div>
276
+ );
277
+ })}
278
+ </>
279
+ );
280
+ }
281
+ export default React.memo(DetailDocs);
@@ -0,0 +1,33 @@
1
+ /* eslint-disable no-continue */
2
+ /* eslint-disable no-restricted-syntax */
3
+ /* eslint-disable react/no-array-index-key */
4
+ /* eslint-disable no-underscore-dangle */
5
+ import React from 'react';
6
+ import { _findAccessDocs } from './DocBuilderUtils';
7
+ import DetailDocs from './DetailDocs';
8
+
9
+ /**
10
+ * build detail output html by parent doc.
11
+ * https://github.com/esdoc/esdoc-plugins/blob/2de5022baa569785a189056a99acd1d7ca8284b7/esdoc-publish-html-plugin/src/Builder/DocBuilder.js#L345
12
+ * @param {DocObject} doc - parent doc object.
13
+ * @param {string} kind - target kind property.
14
+ * @param {string} title - detail title.
15
+ * @param {boolean} [isStatic=true] - target static property.
16
+ * @returns {string} html of detail.
17
+ * @private
18
+ */
19
+ const DetailHTML = ({ doc, kind, title, isStatic = true }) => {
20
+ const accessDocs = _findAccessDocs(doc, kind, isStatic);
21
+ return accessDocs.map((accessDoc, idx) => {
22
+ const docs = accessDoc[1];
23
+ if (!docs.length) return null;
24
+
25
+ let prefix = '';
26
+ if (docs[0].static) prefix = 'Static ';
27
+ const _title = `${prefix}${
28
+ accessDoc[0] === 'Public' ? '' : `${accessDoc[0]} `
29
+ }${title}`;
30
+ return <DetailDocs key={idx} docs={docs} title={_title} />;
31
+ });
32
+ };
33
+ export default React.memo(DetailHTML);
@@ -0,0 +1,30 @@
1
+ /* eslint-disable react/prop-types */
2
+ /* eslint-disable no-underscore-dangle */
3
+ import React from 'react';
4
+ import DocLinkHTML from './DocLinkHTML';
5
+
6
+ /**
7
+ * build direct subclass list.
8
+ * https://github.com/esdoc/esdoc-plugins/blob/2de5022baa569785a189056a99acd1d7ca8284b7/esdoc-publish-html-plugin/src/Builder/ClassDocBuilder.js#L203
9
+ * @param {DocObject} doc - target class doc.
10
+ * @returns {string} html of direct subclass links.
11
+ * @private
12
+ */
13
+ function DirectSubclassHTML({ doc }) {
14
+ if (!doc._custom_direct_subclasses) return '';
15
+
16
+ return (
17
+ <div className="flat-list" data-ice="directSubclass">
18
+ <h4>Direct Subclass:</h4>
19
+ <div>
20
+ {doc._custom_direct_subclasses.map((extend, idx) => (
21
+ <React.Fragment key={extend}>
22
+ <DocLinkHTML longname={extend} />
23
+ {idx !== doc._custom_direct_subclasses.length - 1 ? ', ' : ''}
24
+ </React.Fragment>
25
+ ))}
26
+ </div>
27
+ </div>
28
+ );
29
+ }
30
+ export default React.memo(DirectSubclassHTML);