From a53cfae63aa44878ddbf3224e306bce5dbde45b6 Mon Sep 17 00:00:00 2001 From: gchoqueux Date: Fri, 24 Jan 2025 17:09:36 +0100 Subject: [PATCH] chore(architecture): monorepo structure --- .eslintignore | 2 +- .eslintrc.cjs | 12 +- .github/workflows/integration.yml | 46 +- .gitignore | 10 +- CODING.md | 11 + Gruntfile.cjs | 14 +- README.md | 31 + babel.config.json | 6 +- config/concurrently.mjs | 12 + config/prepare.mjs | 12 - docs/config.json | 5 +- package-lock.json | 624 ++++++++++++++++-- package.json | 69 +- packages/Debug/.babelrc | 25 + packages/Debug/.eslintrc.cjs | 7 + packages/Debug/README.md | 33 + packages/Debug/package.json | 37 ++ .../Debug/src}/3dTilesDebug.js | 5 +- {utils/debug => packages/Debug/src}/Debug.js | 5 +- .../Debug/src}/GeometryDebug.js | 0 packages/Debug/src/GuiTools.js | 184 ++++++ packages/Debug/src/Main.js | 7 + .../debug => packages/Debug/src}/OBBHelper.js | 0 .../Debug/src}/OGC3DTilesDebug.js | 2 +- .../Debug/src}/PointCloudDebug.js | 2 +- .../debug => packages/Debug/src}/TileDebug.js | 4 +- .../Debug/src}/charts/ChartConfig.js | 0 .../Debug/src}/charts/ThreeStatsChart.js | 0 .../Debug/src}/charts/TileObjectChart.js | 0 .../Debug/src}/charts/TileVisibilityChart.js | 0 packages/Debug/tsconfig.json | 10 + packages/Geographic/.babelrc | 21 + packages/Geographic/.eslintrc.cjs | 7 + packages/Geographic/README.md | 67 ++ packages/Geographic/package.json | 39 ++ .../Geographic/src}/CoordStars.js | 2 +- .../Geographic/src}/Coordinates.ts | 4 +- .../Geographic/src}/Crs.ts | 0 .../Geographic/src}/Ellipsoid.ts | 2 +- .../Geographic/src}/Extent.js | 2 +- packages/Geographic/src/Main.js | 8 + .../Geographic/src}/OrientationUtils.js | 2 +- packages/Geographic/test/.eslintrc.cjs | 9 + .../Geographic/test}/unit/coordinate.js | 2 +- .../Geographic/test}/unit/crs.js | 2 +- .../Geographic/test}/unit/ellipsoid.js | 32 +- .../Geographic/test}/unit/extent.js | 4 +- .../Geographic/test}/unit/orientationUtils.js | 4 +- packages/Geographic/tsconfig.json | 10 + .babelrc => packages/Main/.babelrc | 1 + packages/Main/.eslintignore | 5 + packages/Main/.eslintrc.cjs | 6 + packages/Main/README.md | 5 + packages/Main/clean.cjs | 5 + packages/Main/package.json | 73 ++ packages/Main/scripts/prepare.mjs | 16 + .../Main/scripts}/replace.config.mjs | 0 .../Main/scripts}/threeExamples.mjs | 2 +- .../Main/src}/Controls/FirstPersonControls.js | 0 .../Main/src}/Controls/FlyControls.js | 0 .../Main/src}/Controls/GlobeControls.js | 3 +- .../Main/src}/Controls/PlanarControls.js | 0 .../Main/src}/Controls/StateControl.js | 0 .../Main/src}/Controls/StreetControls.js | 0 .../Main/src}/Converter/Feature2Mesh.js | 4 +- .../Main/src}/Converter/Feature2Texture.js | 3 +- .../Main/src}/Converter/convertToTile.js | 0 .../Main/src}/Converter/textureConverter.js | 2 +- .../Main/src}/Core/3DTiles/C3DTBatchTable.js | 0 .../C3DTBatchTableHierarchyExtension.js | 0 .../src}/Core/3DTiles/C3DTBoundingVolume.js | 3 +- .../Main/src}/Core/3DTiles/C3DTExtensions.js | 0 .../Main/src}/Core/3DTiles/C3DTFeature.js | 0 .../Main/src}/Core/3DTiles/C3DTilesEnums.js | 0 .../Main/src}/Core/3DTiles/C3DTileset.js | 0 .../3DTiles/utils/BinaryPropertyAccessor.js | 0 .../Main/src}/Core/AnimationPlayer.js | 0 {src => packages/Main/src}/Core/CopcNode.js | 0 .../Main/src}/Core/Deprecated/Undeprecator.js | 0 .../Main/src}/Core/EntwinePointTileNode.js | 0 {src => packages/Main/src}/Core/Feature.js | 3 +- .../Main/src}/Core/Geographic/GeoidGrid.js | 4 +- {src => packages/Main/src}/Core/Label.js | 2 +- {src => packages/Main/src}/Core/MainLoop.js | 0 {src => packages/Main/src}/Core/Picking.js | 2 +- .../Main/src}/Core/PointCloudNode.js | 0 .../Main/src}/Core/Potree2Node.js | 0 .../Main/src}/Core/Potree2PointAttributes.js | 0 {src => packages/Main/src}/Core/PotreeNode.js | 0 .../Main/src}/Core/Prefab/Globe/Atmosphere.js | 4 +- .../Main/src}/Core/Prefab/Globe/GlobeLayer.js | 2 +- .../Core/Prefab/Globe/GlobeTileBuilder.ts | 3 +- .../Core/Prefab/Globe/Shaders/CloudsFS.glsl | 0 .../Core/Prefab/Globe/Shaders/CloudsVS.glsl | 0 .../Core/Prefab/Globe/Shaders/GlowFS.glsl | 0 .../Core/Prefab/Globe/Shaders/GlowVS.glsl | 0 .../Core/Prefab/Globe/Shaders/groundFS.glsl | 0 .../Core/Prefab/Globe/Shaders/groundVS.glsl | 0 .../src}/Core/Prefab/Globe/Shaders/skyFS.glsl | 0 .../src}/Core/Prefab/Globe/Shaders/skyVS.glsl | 0 .../Main/src}/Core/Prefab/Globe/SkyShader.js | 0 .../Main/src}/Core/Prefab/GlobeView.js | 5 +- .../src}/Core/Prefab/Planar/PlanarLayer.js | 0 .../Core/Prefab/Planar/PlanarTileBuilder.ts | 3 +- .../Main/src}/Core/Prefab/PlanarView.js | 0 .../Main/src}/Core/Prefab/TileBuilder.ts | 4 +- .../Core/Prefab/computeBufferTileGeometry.ts | 0 .../Main/src}/Core/Scheduler/Cache.js | 0 .../Scheduler/CancelledCommandException.js | 0 .../Main/src}/Core/Scheduler/Scheduler.js | 0 {src => packages/Main/src}/Core/Style.js | 2 +- .../itowns_stroke_single_before.css | 0 .../Main/src}/Core/System/Capabilities.js | 4 +- {src => packages/Main/src}/Core/Tile/Tile.js | 4 +- .../Main/src}/Core/Tile/TileGrid.js | 2 +- .../Main/src}/Core/TileGeometry.ts | 4 +- {src => packages/Main/src}/Core/TileMesh.js | 0 {src => packages/Main/src}/Core/View.js | 3 +- .../Main/src}/Layer/C3DTilesLayer.js | 0 .../Main/src}/Layer/ColorLayer.js | 0 {src => packages/Main/src}/Layer/CopcLayer.js | 0 .../Main/src}/Layer/ElevationLayer.js | 0 .../Main/src}/Layer/EntwinePointTileLayer.js | 2 +- .../Main/src}/Layer/FeatureGeometryLayer.js | 0 .../Main/src}/Layer/GeoidLayer.js | 0 .../Main/src}/Layer/GeometryLayer.js | 0 {src => packages/Main/src}/Layer/InfoLayer.js | 2 +- .../Main/src}/Layer/LabelLayer.js | 3 +- {src => packages/Main/src}/Layer/Layer.js | 0 .../Main/src}/Layer/LayerUpdateState.js | 0 .../Main/src}/Layer/LayerUpdateStrategy.js | 0 .../Main/src}/Layer/OGC3DTilesLayer.js | 0 .../Main/src}/Layer/OrientedImageLayer.js | 3 +- .../Main/src}/Layer/PointCloudLayer.js | 0 .../Main/src}/Layer/Potree2Layer.js | 2 +- .../Main/src}/Layer/PotreeLayer.js | 2 +- .../Main/src}/Layer/RasterLayer.js | 0 .../src}/Layer/ReferencingLayerProperties.js | 0 .../Main/src}/Layer/TiledGeometryLayer.js | 0 .../Main/src}/Loader/LASLoader.js | 0 .../Main/src}/Loader/Potree2BrotliLoader.js | 0 .../Main/src}/Loader/Potree2Loader.js | 0 {src => packages/Main/src}/Main.js | 9 +- {src => packages/Main/src}/MainBundle.js | 2 +- .../Main/src}/Parser/B3dmParser.js | 0 .../src}/Parser/CameraCalibrationParser.js | 0 .../Main/src}/Parser/GDFParser.js | 2 +- .../Main/src}/Parser/GTXParser.js | 3 +- .../Main/src}/Parser/GeoJsonParser.js | 2 +- .../Main/src}/Parser/GpxParser.js | 0 .../Main/src}/Parser/ISGParser.js | 2 +- .../Main/src}/Parser/KMLParser.js | 0 .../Main/src}/Parser/LASParser.js | 0 .../Main/src}/Parser/MapBoxUrlParser.js | 0 .../Main/src}/Parser/PntsParser.js | 0 .../Main/src}/Parser/Potree2BinParser.js | 0 .../Main/src}/Parser/PotreeBinParser.js | 0 .../Main/src}/Parser/PotreeCinParser.js | 0 .../Main/src}/Parser/ShapefileParser.js | 0 .../Main/src}/Parser/VectorTileParser.js | 4 +- .../Main/src}/Parser/XbilParser.js | 0 .../Parser/deprecated/LegacyGLTFLoader.js | 0 .../Main/src}/Parser/iGLTFLoader.js | 0 .../Main/src}/Process/3dTilesProcessing.js | 0 .../Main/src}/Process/FeatureProcessing.js | 2 +- .../Process/LayeredMaterialNodeProcessing.js | 0 .../Main/src}/Process/ObjectRemovalHelper.js | 0 .../Main/src}/Process/handlerNodeError.js | 0 .../Main/src}/Provider/3dTilesProvider.js | 0 .../Main/src}/Provider/DataSourceProvider.js | 0 .../Main/src}/Provider/Fetcher.js | 0 .../Main/src}/Provider/PointCloudProvider.js | 2 +- .../Main/src}/Provider/TileProvider.js | 0 .../Main/src}/Provider/URLBuilder.js | 0 {src => packages/Main/src}/Renderer/Camera.js | 2 +- {src => packages/Main/src}/Renderer/Color.js | 0 .../Main/src}/Renderer/ColorLayersOrdering.js | 0 .../Main/src}/Renderer/CommonMaterial.js | 0 .../Main/src}/Renderer/Label2DRenderer.js | 0 .../Main/src}/Renderer/LayeredMaterial.js | 4 +- {src => packages/Main/src}/Renderer/OBB.js | 3 +- .../Main/src}/Renderer/OrientedImageCamera.js | 0 .../src}/Renderer/OrientedImageMaterial.js | 4 +- .../Main/src}/Renderer/PointsMaterial.js | 0 .../Main/src}/Renderer/RasterTile.js | 0 .../Main/src}/Renderer/RenderMode.js | 0 .../Chunk/color_layers_pars_fragment.glsl | 0 .../Shader/Chunk/elevation_pars_vertex.glsl | 0 .../Shader/Chunk/elevation_vertex.glsl | 0 .../Renderer/Shader/Chunk/fog_fragment.glsl | 0 .../Shader/Chunk/fog_pars_fragment.glsl | 0 .../Renderer/Shader/Chunk/geoid_vertex.glsl | 0 .../Shader/Chunk/lighting_fragment.glsl | 0 .../Shader/Chunk/lighting_pars_fragment.glsl | 0 .../Shader/Chunk/mode_depth_fragment.glsl | 0 .../Shader/Chunk/mode_id_fragment.glsl | 0 .../Shader/Chunk/mode_pars_fragment.glsl | 0 .../Shader/Chunk/overlay_fragment.glsl | 0 .../Shader/Chunk/overlay_pars_fragment.glsl | 0 .../src}/Renderer/Shader/Chunk/pitUV.glsl | 0 .../Shader/Chunk/precision_qualifier.glsl | 0 .../projective_texturing_pars_fragment.glsl | 0 .../projective_texturing_pars_vertex.glsl | 0 .../Chunk/projective_texturing_vertex.glsl | 0 .../Main/src}/Renderer/Shader/PointsFS.glsl | 0 .../Main/src}/Renderer/Shader/PointsVS.glsl | 0 .../Renderer/Shader/ProjectiveTextureFS.glsl | 0 .../Renderer/Shader/ProjectiveTextureVS.glsl | 0 .../src}/Renderer/Shader/SampleTestFS.glsl | 0 .../src}/Renderer/Shader/SampleTestVS.glsl | 0 .../Main/src}/Renderer/Shader/ShaderChunk.js | 0 .../Main/src}/Renderer/Shader/ShaderUtils.js | 0 .../Main/src}/Renderer/Shader/TileFS.glsl | 0 .../Main/src}/Renderer/Shader/TileVS.glsl | 0 .../Main/src}/Renderer/SphereHelper.js | 0 {src => packages/Main/src}/Renderer/WebXR.js | 0 .../Main/src}/Renderer/c3DEngine.js | 2 +- .../Main/src}/Source/C3DTilesGoogleSource.js | 0 .../Main/src}/Source/C3DTilesIonSource.js | 0 .../Main/src}/Source/C3DTilesSource.js | 0 .../Main/src}/Source/CopcSource.js | 2 +- .../src}/Source/EntwinePointTileSource.js | 0 .../Main/src}/Source/FileSource.js | 0 .../src}/Source/OGC3DTilesGoogleSource.js | 0 .../Main/src}/Source/OGC3DTilesIonSource.js | 0 .../Main/src}/Source/OGC3DTilesSource.js | 0 .../Main/src}/Source/OrientedImageSource.js | 0 .../Main/src}/Source/Potree2Source.js | 0 .../Main/src}/Source/PotreeSource.js | 0 {src => packages/Main/src}/Source/Source.js | 3 +- .../Main/src}/Source/TMSSource.js | 4 +- .../Main/src}/Source/VectorTilesSource.js | 0 .../Main/src}/Source/WFSSource.js | 2 +- .../Main/src}/Source/WMSSource.js | 3 +- .../Main/src}/Source/WMTSSource.js | 0 .../Main/src}/Utils/CameraUtils.js | 3 +- {src => packages/Main/src}/Utils/DEMUtils.js | 2 +- .../Main/src}/Utils/FeaturesUtils.js | 2 +- {src => packages/Main/src}/Utils/Gradients.js | 0 .../Main/src}/Utils/ThreeUtils.js | 0 .../Main/src}/Utils/placeObjectOnGround.js | 2 +- .../Main/src}/Worker/LASLoaderWorker.js | 0 .../Main/src}/Worker/Potree2Worker.js | 0 packages/Main/test/.eslintrc.cjs | 9 + .../Main/test}/data/EGM2008_simplified.gdf | 0 .../data/OrientedImage/cameraCalibration.json | 0 .../panoramicsMetaDataParis.geojson | 0 .../data/entwine/ept-hierarchy/0-0-0-0.json | 0 .../Main/test}/data/entwine/ept.json | 0 .../filesource/featCollec_Polygone.geojson | 0 .../data/filesource/feat_Polygone.geojson | 0 .../Main/test}/data/geojson/gpx.geojson | 0 .../Main/test}/data/geojson/holes.geojson | 0 .../test}/data/geojson/holesPoints.geojson | 0 .../Main/test}/data/geojson/map.geojson | 0 .../Main/test}/data/geojson/map_big.geojson | 0 .../Main/test}/data/geojson/map_small.geojson | 0 .../Main/test}/data/geojson/points.geojson | 0 .../Main/test}/data/geojson/simple.geojson | 0 .../Main/test}/data/gltf/box.glb | Bin .../Main/test}/data/mapboxMulti.json | 0 .../Main/test}/data/pbf/multipolygon.pbf | Bin .../Main/test}/data/raf09_simplified.isg | 0 .../Main/test}/data/vectortiles/sprite.json | 0 .../Main/test}/data/vectortiles/style.json | 0 .../Main/test}/data/vectortiles/tilejson.json | 0 {test => packages/Main/test}/unit/3dtiles.js | 7 +- .../Main/test}/unit/3dtilesbatchtable.js | 0 .../test}/unit/3dtilesbatchtablehierarchy.js | 0 .../unit/3dtilesbinarypropertyaccessor.js | 0 .../Main/test}/unit/3dtilesfeature.js | 0 .../Main/test}/unit/3dtilesgetchildren.js | 0 .../Main/test}/unit/3dtileslayerprocess.js | 2 +- .../unit/3dtileslayerprocessbatchtable.js | 2 +- .../Main/test}/unit/3dtileslayerstyle.js | 5 +- .../Main/test}/unit/bootstrap.js | 0 {test => packages/Main/test}/unit/cache.js | 0 {test => packages/Main/test}/unit/camera.js | 2 +- .../Main/test}/unit/cameraUtils.js | 7 +- {test => packages/Main/test}/unit/copc.js | 0 .../Main/test}/unit/dataSourceProvider.js | 2 +- {test => packages/Main/test}/unit/demutils.js | 3 +- {test => packages/Main/test}/unit/entwine.js | 4 +- {test => packages/Main/test}/unit/feature.js | 2 +- .../Main/test}/unit/feature2mesh.js | 4 +- .../Main/test}/unit/featureUtils.js | 2 +- .../Main/test}/unit/featuregeometrylayer.js | 3 +- .../test}/unit/featuregeometrylayererror.js | 3 +- {test => packages/Main/test}/unit/fetcher.js | 0 .../Main/test}/unit/gdfparser.js | 0 .../Main/test}/unit/geoidgrid.js | 4 +- .../Main/test}/unit/geoidlayer.js | 3 +- {test => packages/Main/test}/unit/geojson.js | 5 +- .../Main/test}/unit/geometrylayer.js | 0 .../Main/test}/unit/globecontrol.js | 2 +- .../Main/test}/unit/globeview.js | 3 +- .../Main/test}/unit/gtxparser.js | 0 .../Main/test}/unit/igltfloader.js | 0 .../Main/test}/unit/isgparser.js | 0 {test => packages/Main/test}/unit/label.js | 3 +- .../Main/test}/unit/lasparser.js | 2 +- {test => packages/Main/test}/unit/layer.js | 0 .../Main/test}/unit/layeredmaterial.js | 2 +- .../unit/layeredmaterialnodeprocessing.js | 2 +- .../Main/test}/unit/layerupdatestrategy.js | 2 +- {test => packages/Main/test}/unit/obb.js | 5 +- .../Main/test}/unit/ogc3dtileslayer.js | 0 .../Main/test}/unit/orientedImageCamera.js | 0 .../Main/test}/unit/orientedimagelayer.js | 5 +- .../Main/test}/unit/planarControls.js | 2 +- .../Main/test}/unit/planarView.js | 2 +- .../Main/test}/unit/pnts_parser.js | 0 .../Main/test}/unit/pointsmaterial.js | 0 {test => packages/Main/test}/unit/potree.js | 2 +- {test => packages/Main/test}/unit/potree2.js | 0 .../Main/test}/unit/potree2BinParser.js | 0 .../Main/test}/unit/potree2layerparsing.js | 2 +- .../Main/test}/unit/potree2layerprocessing.js | 0 .../Main/test}/unit/potreeBinParser.js | 0 .../Main/test}/unit/potreelayerparsing.js | 2 +- .../Main/test}/unit/potreelayerprocessing.js | 0 .../Main/test}/unit/provider_url.js | 2 +- .../Main/test}/unit/scheduler.js | 0 .../Main/test}/unit/shaderchunk.js | 0 {test => packages/Main/test}/unit/source.js | 2 +- .../Main/test}/unit/statecontrol.js | 2 +- {test => packages/Main/test}/unit/style.js | 0 .../Main/test}/unit/threeutils.js | 0 {test => packages/Main/test}/unit/tile.js | 0 .../Main/test}/unit/tiledGeometryLayer.js | 3 +- {test => packages/Main/test}/unit/tilemesh.js | 0 {test => packages/Main/test}/unit/utils.js | 0 .../Main/test}/unit/vectortiles.js | 0 {test => packages/Main/test}/unit/view.js | 0 {test => packages/Main/test}/unit/webxr.js | 0 packages/Main/tsconfig.json | 10 + packages/Widgets/.babelrc | 24 + packages/Widgets/.eslintrc.cjs | 7 + packages/Widgets/README.md | 26 + packages/Widgets/package.json | 36 + .../Widgets/src}/C3DTilesStyle.js | 2 +- .../gui => packages/Widgets/src}/Main.js | 0 .../gui => packages/Widgets/src}/Minimap.js | 6 +- .../Widgets/src}/Navigation.js | 2 +- .../gui => packages/Widgets/src}/Scale.js | 5 +- .../gui => packages/Widgets/src}/Searchbar.js | 2 +- .../gui => packages/Widgets/src}/Widget.js | 0 packages/Widgets/tsconfig.json | 10 + tsconfig.json | 5 - utils/debug/Main.js | 6 - webpack.config.cjs | 20 +- 351 files changed, 1608 insertions(+), 318 deletions(-) create mode 100755 config/concurrently.mjs create mode 100644 packages/Debug/.babelrc create mode 100644 packages/Debug/.eslintrc.cjs create mode 100644 packages/Debug/README.md create mode 100644 packages/Debug/package.json rename {utils/debug => packages/Debug/src}/3dTilesDebug.js (95%) rename {utils/debug => packages/Debug/src}/Debug.js (98%) rename {utils/debug => packages/Debug/src}/GeometryDebug.js (100%) create mode 100644 packages/Debug/src/GuiTools.js create mode 100644 packages/Debug/src/Main.js rename {utils/debug => packages/Debug/src}/OBBHelper.js (100%) rename {utils/debug => packages/Debug/src}/OGC3DTilesDebug.js (97%) rename {utils/debug => packages/Debug/src}/PointCloudDebug.js (99%) rename {utils/debug => packages/Debug/src}/TileDebug.js (98%) rename {utils/debug => packages/Debug/src}/charts/ChartConfig.js (100%) rename {utils/debug => packages/Debug/src}/charts/ThreeStatsChart.js (100%) rename {utils/debug => packages/Debug/src}/charts/TileObjectChart.js (100%) rename {utils/debug => packages/Debug/src}/charts/TileVisibilityChart.js (100%) create mode 100644 packages/Debug/tsconfig.json create mode 100644 packages/Geographic/.babelrc create mode 100644 packages/Geographic/.eslintrc.cjs create mode 100644 packages/Geographic/README.md create mode 100644 packages/Geographic/package.json rename {src/Core/Geographic => packages/Geographic/src}/CoordStars.js (98%) rename {src/Core/Geographic => packages/Geographic/src}/Coordinates.ts (99%) rename {src/Core/Geographic => packages/Geographic/src}/Crs.ts (100%) rename {src/Core/Math => packages/Geographic/src}/Ellipsoid.ts (99%) rename {src/Core/Geographic => packages/Geographic/src}/Extent.js (100%) create mode 100644 packages/Geographic/src/Main.js rename {src/Utils => packages/Geographic/src}/OrientationUtils.js (99%) create mode 100644 packages/Geographic/test/.eslintrc.cjs rename {test => packages/Geographic/test}/unit/coordinate.js (99%) rename {test => packages/Geographic/test}/unit/crs.js (98%) rename {test => packages/Geographic/test}/unit/ellipsoid.js (69%) rename {test => packages/Geographic/test}/unit/extent.js (99%) rename {test => packages/Geographic/test}/unit/orientationUtils.js (98%) create mode 100644 packages/Geographic/tsconfig.json rename .babelrc => packages/Main/.babelrc (96%) create mode 100644 packages/Main/.eslintignore create mode 100644 packages/Main/.eslintrc.cjs create mode 100644 packages/Main/README.md create mode 100644 packages/Main/clean.cjs create mode 100644 packages/Main/package.json create mode 100644 packages/Main/scripts/prepare.mjs rename {config => packages/Main/scripts}/replace.config.mjs (100%) rename {config => packages/Main/scripts}/threeExamples.mjs (91%) rename {src => packages/Main/src}/Controls/FirstPersonControls.js (100%) rename {src => packages/Main/src}/Controls/FlyControls.js (100%) rename {src => packages/Main/src}/Controls/GlobeControls.js (99%) rename {src => packages/Main/src}/Controls/PlanarControls.js (100%) rename {src => packages/Main/src}/Controls/StateControl.js (100%) rename {src => packages/Main/src}/Controls/StreetControls.js (100%) rename {src => packages/Main/src}/Converter/Feature2Mesh.js (99%) rename {src => packages/Main/src}/Converter/Feature2Texture.js (98%) rename {src => packages/Main/src}/Converter/convertToTile.js (100%) rename {src => packages/Main/src}/Converter/textureConverter.js (97%) rename {src => packages/Main/src}/Core/3DTiles/C3DTBatchTable.js (100%) rename {src => packages/Main/src}/Core/3DTiles/C3DTBatchTableHierarchyExtension.js (100%) rename {src => packages/Main/src}/Core/3DTiles/C3DTBoundingVolume.js (98%) rename {src => packages/Main/src}/Core/3DTiles/C3DTExtensions.js (100%) rename {src => packages/Main/src}/Core/3DTiles/C3DTFeature.js (100%) rename {src => packages/Main/src}/Core/3DTiles/C3DTilesEnums.js (100%) rename {src => packages/Main/src}/Core/3DTiles/C3DTileset.js (100%) rename {src => packages/Main/src}/Core/3DTiles/utils/BinaryPropertyAccessor.js (100%) rename {src => packages/Main/src}/Core/AnimationPlayer.js (100%) rename {src => packages/Main/src}/Core/CopcNode.js (100%) rename {src => packages/Main/src}/Core/Deprecated/Undeprecator.js (100%) rename {src => packages/Main/src}/Core/EntwinePointTileNode.js (100%) rename {src => packages/Main/src}/Core/Feature.js (99%) rename {src => packages/Main/src}/Core/Geographic/GeoidGrid.js (98%) rename {src => packages/Main/src}/Core/Label.js (99%) rename {src => packages/Main/src}/Core/MainLoop.js (100%) rename {src => packages/Main/src}/Core/Picking.js (99%) rename {src => packages/Main/src}/Core/PointCloudNode.js (100%) rename {src => packages/Main/src}/Core/Potree2Node.js (100%) rename {src => packages/Main/src}/Core/Potree2PointAttributes.js (100%) rename {src => packages/Main/src}/Core/PotreeNode.js (100%) rename {src => packages/Main/src}/Core/Prefab/Globe/Atmosphere.js (98%) rename {src => packages/Main/src}/Core/Prefab/Globe/GlobeLayer.js (99%) rename {src => packages/Main/src}/Core/Prefab/Globe/GlobeTileBuilder.ts (98%) rename {src => packages/Main/src}/Core/Prefab/Globe/Shaders/CloudsFS.glsl (100%) rename {src => packages/Main/src}/Core/Prefab/Globe/Shaders/CloudsVS.glsl (100%) rename {src => packages/Main/src}/Core/Prefab/Globe/Shaders/GlowFS.glsl (100%) rename {src => packages/Main/src}/Core/Prefab/Globe/Shaders/GlowVS.glsl (100%) rename {src => packages/Main/src}/Core/Prefab/Globe/Shaders/groundFS.glsl (100%) rename {src => packages/Main/src}/Core/Prefab/Globe/Shaders/groundVS.glsl (100%) rename {src => packages/Main/src}/Core/Prefab/Globe/Shaders/skyFS.glsl (100%) rename {src => packages/Main/src}/Core/Prefab/Globe/Shaders/skyVS.glsl (100%) rename {src => packages/Main/src}/Core/Prefab/Globe/SkyShader.js (100%) rename {src => packages/Main/src}/Core/Prefab/GlobeView.js (98%) rename {src => packages/Main/src}/Core/Prefab/Planar/PlanarLayer.js (100%) rename {src => packages/Main/src}/Core/Prefab/Planar/PlanarTileBuilder.ts (96%) rename {src => packages/Main/src}/Core/Prefab/PlanarView.js (100%) rename {src => packages/Main/src}/Core/Prefab/TileBuilder.ts (98%) rename {src => packages/Main/src}/Core/Prefab/computeBufferTileGeometry.ts (100%) rename {src => packages/Main/src}/Core/Scheduler/Cache.js (100%) rename {src => packages/Main/src}/Core/Scheduler/CancelledCommandException.js (100%) rename {src => packages/Main/src}/Core/Scheduler/Scheduler.js (100%) rename {src => packages/Main/src}/Core/Style.js (99%) rename {src => packages/Main/src}/Core/StyleChunk/itowns_stroke_single_before.css (100%) rename {src => packages/Main/src}/Core/System/Capabilities.js (95%) rename {src => packages/Main/src}/Core/Tile/Tile.js (98%) rename {src => packages/Main/src}/Core/Tile/TileGrid.js (97%) rename {src => packages/Main/src}/Core/TileGeometry.ts (98%) rename {src => packages/Main/src}/Core/TileMesh.js (100%) rename {src => packages/Main/src}/Core/View.js (99%) rename {src => packages/Main/src}/Layer/C3DTilesLayer.js (100%) rename {src => packages/Main/src}/Layer/ColorLayer.js (100%) rename {src => packages/Main/src}/Layer/CopcLayer.js (100%) rename {src => packages/Main/src}/Layer/ElevationLayer.js (100%) rename {src => packages/Main/src}/Layer/EntwinePointTileLayer.js (98%) rename {src => packages/Main/src}/Layer/FeatureGeometryLayer.js (100%) rename {src => packages/Main/src}/Layer/GeoidLayer.js (100%) rename {src => packages/Main/src}/Layer/GeometryLayer.js (100%) rename {src => packages/Main/src}/Layer/InfoLayer.js (98%) rename {src => packages/Main/src}/Layer/LabelLayer.js (99%) rename {src => packages/Main/src}/Layer/Layer.js (100%) rename {src => packages/Main/src}/Layer/LayerUpdateState.js (100%) rename {src => packages/Main/src}/Layer/LayerUpdateStrategy.js (100%) rename {src => packages/Main/src}/Layer/OGC3DTilesLayer.js (100%) rename {src => packages/Main/src}/Layer/OrientedImageLayer.js (98%) rename {src => packages/Main/src}/Layer/PointCloudLayer.js (100%) rename {src => packages/Main/src}/Layer/Potree2Layer.js (99%) rename {src => packages/Main/src}/Layer/PotreeLayer.js (98%) rename {src => packages/Main/src}/Layer/RasterLayer.js (100%) rename {src => packages/Main/src}/Layer/ReferencingLayerProperties.js (100%) rename {src => packages/Main/src}/Layer/TiledGeometryLayer.js (100%) rename {src => packages/Main/src}/Loader/LASLoader.js (100%) rename {src => packages/Main/src}/Loader/Potree2BrotliLoader.js (100%) rename {src => packages/Main/src}/Loader/Potree2Loader.js (100%) rename {src => packages/Main/src}/Main.js (95%) rename {src => packages/Main/src}/MainBundle.js (79%) rename {src => packages/Main/src}/Parser/B3dmParser.js (100%) rename {src => packages/Main/src}/Parser/CameraCalibrationParser.js (100%) rename {src => packages/Main/src}/Parser/GDFParser.js (98%) rename {src => packages/Main/src}/Parser/GTXParser.js (98%) rename {src => packages/Main/src}/Parser/GeoJsonParser.js (99%) rename {src => packages/Main/src}/Parser/GpxParser.js (100%) rename {src => packages/Main/src}/Parser/ISGParser.js (98%) rename {src => packages/Main/src}/Parser/KMLParser.js (100%) rename {src => packages/Main/src}/Parser/LASParser.js (100%) rename {src => packages/Main/src}/Parser/MapBoxUrlParser.js (100%) rename {src => packages/Main/src}/Parser/PntsParser.js (100%) rename {src => packages/Main/src}/Parser/Potree2BinParser.js (100%) rename {src => packages/Main/src}/Parser/PotreeBinParser.js (100%) rename {src => packages/Main/src}/Parser/PotreeCinParser.js (100%) rename {src => packages/Main/src}/Parser/ShapefileParser.js (100%) rename {src => packages/Main/src}/Parser/VectorTileParser.js (99%) rename {src => packages/Main/src}/Parser/XbilParser.js (100%) rename {src => packages/Main/src}/Parser/deprecated/LegacyGLTFLoader.js (100%) rename {src => packages/Main/src}/Parser/iGLTFLoader.js (100%) rename {src => packages/Main/src}/Process/3dTilesProcessing.js (100%) rename {src => packages/Main/src}/Process/FeatureProcessing.js (98%) rename {src => packages/Main/src}/Process/LayeredMaterialNodeProcessing.js (100%) rename {src => packages/Main/src}/Process/ObjectRemovalHelper.js (100%) rename {src => packages/Main/src}/Process/handlerNodeError.js (100%) rename {src => packages/Main/src}/Provider/3dTilesProvider.js (100%) rename {src => packages/Main/src}/Provider/DataSourceProvider.js (100%) rename {src => packages/Main/src}/Provider/Fetcher.js (100%) rename {src => packages/Main/src}/Provider/PointCloudProvider.js (97%) rename {src => packages/Main/src}/Provider/TileProvider.js (100%) rename {src => packages/Main/src}/Provider/URLBuilder.js (100%) rename {src => packages/Main/src}/Renderer/Camera.js (99%) rename {src => packages/Main/src}/Renderer/Color.js (100%) rename {src => packages/Main/src}/Renderer/ColorLayersOrdering.js (100%) rename {src => packages/Main/src}/Renderer/CommonMaterial.js (100%) rename {src => packages/Main/src}/Renderer/Label2DRenderer.js (100%) rename {src => packages/Main/src}/Renderer/LayeredMaterial.js (98%) rename {src => packages/Main/src}/Renderer/OBB.js (98%) rename {src => packages/Main/src}/Renderer/OrientedImageCamera.js (100%) rename {src => packages/Main/src}/Renderer/OrientedImageMaterial.js (98%) rename {src => packages/Main/src}/Renderer/PointsMaterial.js (100%) rename {src => packages/Main/src}/Renderer/RasterTile.js (100%) rename {src => packages/Main/src}/Renderer/RenderMode.js (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/color_layers_pars_fragment.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/elevation_pars_vertex.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/elevation_vertex.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/fog_fragment.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/fog_pars_fragment.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/geoid_vertex.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/lighting_fragment.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/lighting_pars_fragment.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/mode_depth_fragment.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/mode_id_fragment.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/mode_pars_fragment.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/overlay_fragment.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/overlay_pars_fragment.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/pitUV.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/precision_qualifier.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/projective_texturing_pars_fragment.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/projective_texturing_pars_vertex.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/Chunk/projective_texturing_vertex.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/PointsFS.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/PointsVS.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/ProjectiveTextureFS.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/ProjectiveTextureVS.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/SampleTestFS.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/SampleTestVS.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/ShaderChunk.js (100%) rename {src => packages/Main/src}/Renderer/Shader/ShaderUtils.js (100%) rename {src => packages/Main/src}/Renderer/Shader/TileFS.glsl (100%) rename {src => packages/Main/src}/Renderer/Shader/TileVS.glsl (100%) rename {src => packages/Main/src}/Renderer/SphereHelper.js (100%) rename {src => packages/Main/src}/Renderer/WebXR.js (100%) rename {src => packages/Main/src}/Renderer/c3DEngine.js (100%) rename {src => packages/Main/src}/Source/C3DTilesGoogleSource.js (100%) rename {src => packages/Main/src}/Source/C3DTilesIonSource.js (100%) rename {src => packages/Main/src}/Source/C3DTilesSource.js (100%) rename {src => packages/Main/src}/Source/CopcSource.js (99%) rename {src => packages/Main/src}/Source/EntwinePointTileSource.js (100%) rename {src => packages/Main/src}/Source/FileSource.js (100%) rename {src => packages/Main/src}/Source/OGC3DTilesGoogleSource.js (100%) rename {src => packages/Main/src}/Source/OGC3DTilesIonSource.js (100%) rename {src => packages/Main/src}/Source/OGC3DTilesSource.js (100%) rename {src => packages/Main/src}/Source/OrientedImageSource.js (100%) rename {src => packages/Main/src}/Source/Potree2Source.js (100%) rename {src => packages/Main/src}/Source/PotreeSource.js (100%) rename {src => packages/Main/src}/Source/Source.js (98%) rename {src => packages/Main/src}/Source/TMSSource.js (99%) rename {src => packages/Main/src}/Source/VectorTilesSource.js (100%) rename {src => packages/Main/src}/Source/WFSSource.js (99%) rename {src => packages/Main/src}/Source/WMSSource.js (98%) rename {src => packages/Main/src}/Source/WMTSSource.js (100%) rename {src => packages/Main/src}/Utils/CameraUtils.js (99%) rename {src => packages/Main/src}/Utils/DEMUtils.js (99%) rename {src => packages/Main/src}/Utils/FeaturesUtils.js (99%) rename {src => packages/Main/src}/Utils/Gradients.js (100%) rename {src => packages/Main/src}/Utils/ThreeUtils.js (100%) rename {src => packages/Main/src}/Utils/placeObjectOnGround.js (99%) rename {src => packages/Main/src}/Worker/LASLoaderWorker.js (100%) rename {src => packages/Main/src}/Worker/Potree2Worker.js (100%) create mode 100644 packages/Main/test/.eslintrc.cjs rename {test => packages/Main/test}/data/EGM2008_simplified.gdf (100%) rename {test => packages/Main/test}/data/OrientedImage/cameraCalibration.json (100%) rename {test => packages/Main/test}/data/OrientedImage/panoramicsMetaDataParis.geojson (100%) rename {test => packages/Main/test}/data/entwine/ept-hierarchy/0-0-0-0.json (100%) rename {test => packages/Main/test}/data/entwine/ept.json (100%) rename {test => packages/Main/test}/data/filesource/featCollec_Polygone.geojson (100%) rename {test => packages/Main/test}/data/filesource/feat_Polygone.geojson (100%) rename {test => packages/Main/test}/data/geojson/gpx.geojson (100%) rename {test => packages/Main/test}/data/geojson/holes.geojson (100%) rename {test => packages/Main/test}/data/geojson/holesPoints.geojson (100%) rename {test => packages/Main/test}/data/geojson/map.geojson (100%) rename {test => packages/Main/test}/data/geojson/map_big.geojson (100%) rename {test => packages/Main/test}/data/geojson/map_small.geojson (100%) rename {test => packages/Main/test}/data/geojson/points.geojson (100%) rename {test => packages/Main/test}/data/geojson/simple.geojson (100%) rename {test => packages/Main/test}/data/gltf/box.glb (100%) rename {test => packages/Main/test}/data/mapboxMulti.json (100%) rename {test => packages/Main/test}/data/pbf/multipolygon.pbf (100%) rename {test => packages/Main/test}/data/raf09_simplified.isg (100%) rename {test => packages/Main/test}/data/vectortiles/sprite.json (100%) rename {test => packages/Main/test}/data/vectortiles/style.json (100%) rename {test => packages/Main/test}/data/vectortiles/tilejson.json (100%) rename {test => packages/Main/test}/unit/3dtiles.js (97%) rename {test => packages/Main/test}/unit/3dtilesbatchtable.js (100%) rename {test => packages/Main/test}/unit/3dtilesbatchtablehierarchy.js (100%) rename {test => packages/Main/test}/unit/3dtilesbinarypropertyaccessor.js (100%) rename {test => packages/Main/test}/unit/3dtilesfeature.js (100%) rename {test => packages/Main/test}/unit/3dtilesgetchildren.js (100%) rename {test => packages/Main/test}/unit/3dtileslayerprocess.js (98%) rename {test => packages/Main/test}/unit/3dtileslayerprocessbatchtable.js (98%) rename {test => packages/Main/test}/unit/3dtileslayerstyle.js (94%) rename {test => packages/Main/test}/unit/bootstrap.js (100%) rename {test => packages/Main/test}/unit/cache.js (100%) rename {test => packages/Main/test}/unit/camera.js (97%) rename {test => packages/Main/test}/unit/cameraUtils.js (95%) rename {test => packages/Main/test}/unit/copc.js (100%) rename {test => packages/Main/test}/unit/dataSourceProvider.js (99%) rename {test => packages/Main/test}/unit/demutils.js (97%) rename {test => packages/Main/test}/unit/entwine.js (98%) rename {test => packages/Main/test}/unit/feature.js (98%) rename {test => packages/Main/test}/unit/feature2mesh.js (98%) rename {test => packages/Main/test}/unit/featureUtils.js (98%) rename {test => packages/Main/test}/unit/featuregeometrylayer.js (97%) rename {test => packages/Main/test}/unit/featuregeometrylayererror.js (97%) rename {test => packages/Main/test}/unit/fetcher.js (100%) rename {test => packages/Main/test}/unit/gdfparser.js (100%) rename {test => packages/Main/test}/unit/geoidgrid.js (90%) rename {test => packages/Main/test}/unit/geoidlayer.js (96%) rename {test => packages/Main/test}/unit/geojson.js (97%) rename {test => packages/Main/test}/unit/geometrylayer.js (100%) rename {test => packages/Main/test}/unit/globecontrol.js (99%) rename {test => packages/Main/test}/unit/globeview.js (97%) rename {test => packages/Main/test}/unit/gtxparser.js (100%) rename {test => packages/Main/test}/unit/igltfloader.js (100%) rename {test => packages/Main/test}/unit/isgparser.js (100%) rename {test => packages/Main/test}/unit/label.js (98%) rename {test => packages/Main/test}/unit/lasparser.js (98%) rename {test => packages/Main/test}/unit/layer.js (100%) rename {test => packages/Main/test}/unit/layeredmaterial.js (98%) rename {test => packages/Main/test}/unit/layeredmaterialnodeprocessing.js (99%) rename {test => packages/Main/test}/unit/layerupdatestrategy.js (99%) rename {test => packages/Main/test}/unit/obb.js (93%) rename {test => packages/Main/test}/unit/ogc3dtileslayer.js (100%) rename {test => packages/Main/test}/unit/orientedImageCamera.js (100%) rename {test => packages/Main/test}/unit/orientedimagelayer.js (93%) rename {test => packages/Main/test}/unit/planarControls.js (99%) rename {test => packages/Main/test}/unit/planarView.js (92%) rename {test => packages/Main/test}/unit/pnts_parser.js (100%) rename {test => packages/Main/test}/unit/pointsmaterial.js (100%) rename {test => packages/Main/test}/unit/potree.js (99%) rename {test => packages/Main/test}/unit/potree2.js (100%) rename {test => packages/Main/test}/unit/potree2BinParser.js (100%) rename {test => packages/Main/test}/unit/potree2layerparsing.js (99%) rename {test => packages/Main/test}/unit/potree2layerprocessing.js (100%) rename {test => packages/Main/test}/unit/potreeBinParser.js (100%) rename {test => packages/Main/test}/unit/potreelayerparsing.js (99%) rename {test => packages/Main/test}/unit/potreelayerprocessing.js (100%) rename {test => packages/Main/test}/unit/provider_url.js (98%) rename {test => packages/Main/test}/unit/scheduler.js (100%) rename {test => packages/Main/test}/unit/shaderchunk.js (100%) rename {test => packages/Main/test}/unit/source.js (99%) rename {test => packages/Main/test}/unit/statecontrol.js (99%) rename {test => packages/Main/test}/unit/style.js (100%) rename {test => packages/Main/test}/unit/threeutils.js (100%) rename {test => packages/Main/test}/unit/tile.js (100%) rename {test => packages/Main/test}/unit/tiledGeometryLayer.js (94%) rename {test => packages/Main/test}/unit/tilemesh.js (100%) rename {test => packages/Main/test}/unit/utils.js (100%) rename {test => packages/Main/test}/unit/vectortiles.js (100%) rename {test => packages/Main/test}/unit/view.js (100%) rename {test => packages/Main/test}/unit/webxr.js (100%) create mode 100644 packages/Main/tsconfig.json create mode 100644 packages/Widgets/.babelrc create mode 100644 packages/Widgets/.eslintrc.cjs create mode 100644 packages/Widgets/README.md create mode 100644 packages/Widgets/package.json rename {src/Utils/gui => packages/Widgets/src}/C3DTilesStyle.js (99%) rename {src/Utils/gui => packages/Widgets/src}/Main.js (100%) rename {src/Utils/gui => packages/Widgets/src}/Minimap.js (97%) rename {src/Utils/gui => packages/Widgets/src}/Navigation.js (99%) rename {src/Utils/gui => packages/Widgets/src}/Scale.js (96%) rename {src/Utils/gui => packages/Widgets/src}/Searchbar.js (99%) rename {src/Utils/gui => packages/Widgets/src}/Widget.js (100%) create mode 100644 packages/Widgets/tsconfig.json delete mode 100644 utils/debug/Main.js diff --git a/.eslintignore b/.eslintignore index 0da3e0f1cd..820d1a28fb 100644 --- a/.eslintignore +++ b/.eslintignore @@ -1,6 +1,6 @@ examples/libs/ examples/layers/ -src/ThreeExtended/ +packages/Main/src/ThreeExtended/ test/hooks.js dist/ node_modules/ diff --git a/.eslintrc.cjs b/.eslintrc.cjs index 0006ab9edd..de8ea725cf 100644 --- a/.eslintrc.cjs +++ b/.eslintrc.cjs @@ -1,3 +1,5 @@ +const path = require('path'); + module.exports = { // Global ESLint settings @@ -15,7 +17,15 @@ module.exports = { }, settings: { 'import/resolver': { - 'babel-module': {}, + 'babel-module': { + alias: { + '@itowns/geographic': path.resolve(__dirname, 'packages/Geographic/src/Main.js'), + itowns: path.resolve(__dirname, 'packages/Main/src/Main.js'), + }, + plugins: [ + ['module-extension-resolver'], + ], + }, }, }, env: { diff --git a/.github/workflows/integration.yml b/.github/workflows/integration.yml index bcb91e0cb5..30927991f3 100644 --- a/.github/workflows/integration.yml +++ b/.github/workflows/integration.yml @@ -9,7 +9,6 @@ on: - master workflow_dispatch: {} - jobs: # Build bundle, doc and check linter @@ -79,8 +78,15 @@ jobs: # Unit and coverage tests unit-and-coverage-tests: name: Unit and coverage tests - needs: build + needs: [build, check-commit-message] runs-on: ubuntu-latest + strategy: + matrix: + include: + - package: "@itowns/geographic" + path: "Geographic" + - package: "itowns" + path: "Main" steps: # Use specific Node.js version @@ -95,17 +101,33 @@ jobs: - name: Install packages run: npm ci - - name: Run unit tests - run: npm run test-with-coverage_lcov + # Transpile + - name: transpile packages + run: npm run transpile - # Code coverage - - name: Coveralls - if: ${{ success() }} - uses: coverallsapp/github-action@master + - name: Test ${{ matrix.package }} + run: npm run test-with-coverage_lcov --workspace ${{ matrix.package}} + - name: Coveralls Parallel + uses: coverallsapp/github-action@v2 with: + format: lcov + base-path: ./packages/${{ matrix.path }} + path-to-lcov: ./packages/${{ matrix.path }}/coverage/lcov.info github-token: ${{ secrets.GITHUB_TOKEN }} + flag-name: run-${{ matrix.package }} + parallel: true - + # Final Code coverage + finish-coverage: + name: finish parallel test unit + needs: unit-and-coverage-tests + runs-on: ubuntu-latest + steps: + - name: Close parallel build + uses: coverallsapp/github-action@v2 + with: + parallel-finished: true + github-token: ${{ secrets.GITHUB_TOKEN }} # Functional tests functional-tests: name: Functional tests @@ -139,7 +161,7 @@ jobs: publish: name: Publish NPM package if: ${{ github.ref == 'refs/heads/master' }} - needs: [unit-and-coverage-tests, functional-tests, check-commit-message] + needs: [finish-coverage, functional-tests] runs-on: ubuntu-latest permissions: # id-token: write permission is required for npm provenance: @@ -196,7 +218,7 @@ jobs: deploy: name: Deploy to itowns.github.io if: ${{ github.ref == 'refs/heads/master' }} - needs: [unit-and-coverage-tests, functional-tests, check-commit-message] + needs: [finish-coverage, functional-tests] runs-on: ubuntu-latest steps: @@ -257,7 +279,7 @@ jobs: release: name: Release GitHub if: ${{ github.ref == 'refs/heads/master' && startsWith( github.event.head_commit.message, 'release v' ) }} - needs: [unit-and-coverage-tests, functional-tests, check-commit-message] + needs: [finish-coverage, functional-tests] runs-on: ubuntu-latest steps: diff --git a/.gitignore b/.gitignore index 5ebc710462..a9a52359a8 100644 --- a/.gitignore +++ b/.gitignore @@ -3,12 +3,12 @@ # See https://help.github.com/articles/ignoring-files/ for how to configure your environment. # See https://github.com/github/gitignore/tree/master/Global for a list of global ignore rules. -/node_modules/ -/dist/ +node_modules/ +**/dist/ /potree/ potree -/lib/ +**/lib/ /docs/out/ -coverage +**/coverage .nyc_output/ -/src/ThreeExtended/ +**/src/ThreeExtended/ diff --git a/CODING.md b/CODING.md index 0be99cfcf5..18ecca7757 100644 --- a/CODING.md +++ b/CODING.md @@ -34,6 +34,17 @@ See the [node website](https://nodejs.org) to install node and npm. * You can then require `src/Main.js` in your code * Test and lint changes: see test, lint and test-examples npm script +## Monorepo structure + +The project is organized into the following sub-packages. This structuring is in progress. +The roadmap is to divide the `Main` sub-module into independent functionalities. +The final structure is exposed in this (page)[https://github.com/iTowns/itowns/issues/2414]. + +* `Geographic` (public): The geographic package provides utilities for handling coordinates, ellipsoids, extents and rotations across different coordinate systems; +* `Main` (public): all featues that haven't yet been moved to sub-module; +* `Debug` (private, for the moment): iTowns debugging utilities; +* `Widgets` (private, for the moment): Graphic user interface for iTowns; + ## Debugging * `babel-inline-import-loader` prevents the source map debug in browser. If you want launch server and debug with the original source map, run : `npm run diff --git a/Gruntfile.cjs b/Gruntfile.cjs index 81ce8f2ddb..2d352811ac 100644 --- a/Gruntfile.cjs +++ b/Gruntfile.cjs @@ -4,11 +4,21 @@ module.exports = (grunt) => { pkg: grunt.file.readJSON('package.json'), bump: { options: { - files: ['package.json', 'package-lock.json', 'src/Main.js'], + files: ['package.json', 'package-lock.json', 'packages/Main/src/Main.js', + 'packages/Main/package.json', + 'packages/Geographic/package.json', + 'packages/Widgets/package.json', + 'packages/Debug/package.json', + ], updateConfigs: [], commit: true, commitMessage: 'release v%VERSION%', - commitFiles: ['package.json', 'package-lock.json', 'src/Main.js'], + commitFiles: ['package.json', 'package-lock.json', + 'packages/Main/package.json', + 'packages/Geographic/package.json', + 'packages/Widgets/package.json', + 'packages/Debug/package.json', + ], createTag: false, tagName: 'v%VERSION%', tagMessage: 'Release %VERSION%.', diff --git a/README.md b/README.md index 0c81f9742c..e56129748f 100644 --- a/README.md +++ b/README.md @@ -58,10 +58,41 @@ github release page. In your project: +To use all iTowns features, install `itowns` package : + ```bash npm install --save itowns ``` +```js +import { Coordinates } from 'itowns'; + +const coordinates = new Coordinates('EPSG:4326', 88., 50.3, 120.3); + +// change projection system to pseudo mercator +coordinates.as('EPSG:3857'); +``` + +To import Widget features + +```js +import { Navigation } from 'itowns/widgets'; + +const viewerDiv = document.getElementById('viewerDiv'); + +// Create a GlobeView +const view = new itowns.GlobeView(viewerDiv); + +// Add navigation widget +const navigation = new Navigation(view, { + position: 'bottom-right', + translate: { y: -40 }, +}); +``` + +iTowns is currently moving to a monorepo organization and to a segmentation in sub-modules, allowing to import only some of itowns functionalities. Current itowns sub-modules are: +- [@itowns/geographic](packages/Geographic/README.md): `npm install --save @itowns/geographic` + This package contains the ES5-compatible sources of iTowns, up to date with the latest release. If you're using a module bundler (like wepback), you can directly write diff --git a/babel.config.json b/babel.config.json index 001ec6fbf8..17bedab28c 100644 --- a/babel.config.json +++ b/babel.config.json @@ -1,5 +1,9 @@ { "babelrcRoots": [ - "." + ".", + "./packages/Geographic", + "./packages/Main", + "./packages/Debug", + "./packages/Widgets" ] } diff --git a/config/concurrently.mjs b/config/concurrently.mjs new file mode 100755 index 0000000000..3d0530b9c7 --- /dev/null +++ b/config/concurrently.mjs @@ -0,0 +1,12 @@ +import concurrently from 'concurrently'; + +import fs from 'fs'; + +const pck = JSON.parse(fs.readFileSync('package.json', 'utf8')); +const script = process.argv[2]; + +concurrently(pck.workspaces.map(workspace => ({ + command: `npm run ${script} -w ${workspace} --if-present`, + name: `${workspace}`, +}))); + diff --git a/config/prepare.mjs b/config/prepare.mjs index b7e58e2786..40db9de872 100644 --- a/config/prepare.mjs +++ b/config/prepare.mjs @@ -1,8 +1,5 @@ import chalk from 'chalk'; -import copyfiles from 'copyfiles'; -// const chalk = require('chalk'); import { execSync } from 'child_process'; -import threeExamples from './threeExamples.mjs'; @@ -33,12 +30,3 @@ const npmVersion = execSync('npm --version', { if (npmVersion) { console.log(chalk.green('Npm version :', npmVersion), '\n'); } - - - -// Copy and patch THREE Examples Files -const paths = threeExamples.filesExamples.map(f => f.replace('./', './node_modules/three/examples/jsm/')); - -paths.push(threeExamples.patchedPath); - -copyfiles(paths, { up: 4 }, () => {}); diff --git a/docs/config.json b/docs/config.json index 2e3aa04b72..fe3fdad116 100644 --- a/docs/config.json +++ b/docs/config.json @@ -193,8 +193,9 @@ } }, "source": { - "include": [ "src", "examples/js/plugins" ], - "exclude": [ "src/ThreeExtended" ] + "include": [ "examples/js/plugins", "packages" ], + "exclude": [ "packages/Main/src/ThreeExtended" ], + "excludePattern": "(^|\\/|\\\\)lib" }, "plugins": ["plugins/markdown"] } diff --git a/package-lock.json b/package-lock.json index 153efb1195..1fefb186be 100644 --- a/package-lock.json +++ b/package-lock.json @@ -5,23 +5,14 @@ "requires": true, "packages": { "": { - "name": "itowns", "version": "2.44.2", "license": "(CECILL-B OR MIT)", - "dependencies": { - "@mapbox/vector-tile": "^2.0.3", - "@maplibre/maplibre-gl-style-spec": "^22.0.0", - "@tmcw/togeojson": "^5.8.1", - "@tweenjs/tween.js": "^25.0.0", - "3d-tiles-renderer": "^0.3.39", - "brotli-compress": "^1.3.3", - "copc": "^0.0.6", - "earcut": "^3.0.0", - "js-priority-queue": "^0.1.5", - "pbf": "^4.0.1", - "shpjs": "^6.1.0", - "threads": "^1.7.0" - }, + "workspaces": [ + "packages/Geographic", + "packages/Main", + "packages/Debug", + "packages/Widgets" + ], "devDependencies": { "@babel/cli": "^7.25.6", "@babel/core": "^7.25.2", @@ -44,8 +35,8 @@ "babel-plugin-module-resolver": "^5.0.2", "c8": "^10.1.2", "chalk": "^5.3.0", - "chart.js": "^4.4.4", "compare-func": "^2.0.0", + "concurrently": "^8.2.2", "conventional-changelog-cli": "^4.1.0", "copyfiles": "^2.4.1", "core-js": "^3.38.1", @@ -74,10 +65,6 @@ "webpack": "^5.94.0", "webpack-cli": "^5.1.4", "webpack-dev-server": "^5.1.0" - }, - "peerDependencies": { - "proj4": "^2.12.1", - "three": "^0.168.0" } }, "node_modules/@ampproject/remapping": { @@ -179,6 +166,23 @@ "url": "https://opencollective.com/babel" } }, + "node_modules/@babel/core/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "devOptional": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/@babel/generator": { "version": "7.25.6", "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.25.6.tgz", @@ -296,6 +300,23 @@ "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" } }, + "node_modules/@babel/helper-define-polyfill-provider/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/@babel/helper-member-expression-to-functions": { "version": "7.24.8", "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.24.8.tgz", @@ -2092,6 +2113,23 @@ "node": ">=6.9.0" } }, + "node_modules/@babel/traverse/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "devOptional": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/@babel/types": { "version": "7.25.6", "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.25.6.tgz", @@ -2542,6 +2580,23 @@ "url": "https://opencollective.com/eslint" } }, + "node_modules/@eslint/eslintrc/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/@eslint/eslintrc/node_modules/globals": { "version": "13.24.0", "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", @@ -2597,6 +2652,23 @@ "node": ">=10.10.0" } }, + "node_modules/@humanwhocodes/config-array/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/@humanwhocodes/module-importer": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", @@ -2742,6 +2814,10 @@ "node": ">=8" } }, + "node_modules/@itowns/geographic": { + "resolved": "packages/Geographic", + "link": true + }, "node_modules/@jest/schemas": { "version": "29.6.3", "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-29.6.3.tgz", @@ -2928,7 +3004,6 @@ "version": "0.3.2", "resolved": "https://registry.npmjs.org/@kurkle/color/-/color-0.3.2.tgz", "integrity": "sha512-fuscdXJ9G1qb7W8VdHi+IwRqij3lBkosAm4ydQtEmbY58OzHXqQhvlxqEkoz0yssNVn38bcpRWgA9PP+OGoisw==", - "dev": true, "license": "MIT" }, "node_modules/@leichtgewicht/ip-codec": { @@ -3112,6 +3187,23 @@ "node": ">=18" } }, + "node_modules/@puppeteer/browsers/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/@puppeteer/browsers/node_modules/semver": { "version": "7.6.3", "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", @@ -4042,6 +4134,23 @@ } } }, + "node_modules/@typescript-eslint/parser/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/@typescript-eslint/scope-manager": { "version": "8.5.0", "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-8.5.0.tgz", @@ -4085,6 +4194,23 @@ } } }, + "node_modules/@typescript-eslint/type-utils/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/@typescript-eslint/types": { "version": "8.5.0", "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.5.0.tgz", @@ -4138,6 +4264,23 @@ "balanced-match": "^1.0.0" } }, + "node_modules/@typescript-eslint/typescript-estree/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/@typescript-eslint/typescript-estree/node_modules/minimatch": { "version": "9.0.5", "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", @@ -4630,6 +4773,23 @@ "node": ">= 14" } }, + "node_modules/agent-base/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/ajv": { "version": "6.12.6", "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", @@ -5753,7 +5913,6 @@ "version": "4.4.4", "resolved": "https://registry.npmjs.org/chart.js/-/chart.js-4.4.4.tgz", "integrity": "sha512-emICKGBABnxhMjUjlYRR12PmOXhJ2eJjEHL2/dZlWjxRAZT1D8xplLFq5M0tMQK8ja+wBS/tuVEJB5C6r7VxJA==", - "dev": true, "license": "MIT", "dependencies": { "@kurkle/color": "^0.3.0" @@ -5993,6 +6152,76 @@ "dev": true, "license": "MIT" }, + "node_modules/concurrently": { + "version": "8.2.2", + "resolved": "https://registry.npmjs.org/concurrently/-/concurrently-8.2.2.tgz", + "integrity": "sha512-1dP4gpXFhei8IOtlXRE/T/4H88ElHgTiUzh71YUmtjTEHMSRS2Z/fgOxHSxxusGHogsRfxNq1vyAwxSC+EVyDg==", + "dev": true, + "dependencies": { + "chalk": "^4.1.2", + "date-fns": "^2.30.0", + "lodash": "^4.17.21", + "rxjs": "^7.8.1", + "shell-quote": "^1.8.1", + "spawn-command": "0.0.2", + "supports-color": "^8.1.1", + "tree-kill": "^1.2.2", + "yargs": "^17.7.2" + }, + "bin": { + "conc": "dist/bin/concurrently.js", + "concurrently": "dist/bin/concurrently.js" + }, + "engines": { + "node": "^14.13.0 || >=16.0.0" + }, + "funding": { + "url": "https://github.com/open-cli-tools/concurrently?sponsor=1" + } + }, + "node_modules/concurrently/node_modules/chalk": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", + "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", + "dev": true, + "dependencies": { + "ansi-styles": "^4.1.0", + "supports-color": "^7.1.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/chalk?sponsor=1" + } + }, + "node_modules/concurrently/node_modules/chalk/node_modules/supports-color": { + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", + "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/concurrently/node_modules/supports-color": { + "version": "8.1.1", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", + "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", + "dev": true, + "dependencies": { + "has-flag": "^4.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/supports-color?sponsor=1" + } + }, "node_modules/confusing-browser-globals": { "version": "1.0.11", "resolved": "https://registry.npmjs.org/confusing-browser-globals/-/confusing-browser-globals-1.0.11.tgz", @@ -6485,6 +6714,11 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/dat.gui": { + "version": "0.7.9", + "resolved": "https://registry.npmjs.org/dat.gui/-/dat.gui-0.7.9.tgz", + "integrity": "sha512-sCNc1OHobc+Erc1HqiswYgHdVNpSJUlk/Hz8vzOCsER7rl+oF/4+v8GXFUyCgtXpoCX6+bnmg07DedLvBLwYKQ==" + }, "node_modules/data-view-buffer": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/data-view-buffer/-/data-view-buffer-1.0.1.tgz", @@ -6539,6 +6773,22 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/date-fns": { + "version": "2.30.0", + "resolved": "https://registry.npmjs.org/date-fns/-/date-fns-2.30.0.tgz", + "integrity": "sha512-fnULvOpxnC5/Vg3NCiWelDsLiUc9bRwAPs/+LfTLNvetFCtCTN+yQz15C/fs4AwX1R9K5GLtLfn8QW+dWisaAw==", + "dev": true, + "dependencies": { + "@babel/runtime": "^7.21.0" + }, + "engines": { + "node": ">=0.11" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/date-fns" + } + }, "node_modules/dateformat": { "version": "4.6.3", "resolved": "https://registry.npmjs.org/dateformat/-/dateformat-4.6.3.tgz", @@ -6555,22 +6805,9 @@ "integrity": "sha512-XRRe6Glud4rd/ZGQfiV1ruXSfbvfJedlV9Y6zOlP+2K04vBYiJEte6stfFkCP03aMnY5tsipamumUjL14fofug==", "optional": true }, - "node_modules/debug": { - "version": "4.3.7", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.7.tgz", - "integrity": "sha512-Er2nc/H7RrMXZBFCEim6TCmMk02Z8vLC2Rbi1KEBggpo0fS6l0S1nnapwmIi3yW/+GOJap1Krg4w0Hg80oCqgQ==", - "license": "MIT", - "dependencies": { - "ms": "^2.1.3" - }, - "engines": { - "node": ">=6.0" - }, - "peerDependenciesMeta": { - "supports-color": { - "optional": true - } - } + "node_modules/Debug": { + "resolved": "packages/Debug", + "link": true }, "node_modules/decamelize": { "version": "4.0.0", @@ -7414,6 +7651,23 @@ "url": "https://github.com/chalk/chalk?sponsor=1" } }, + "node_modules/eslint/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/eslint/node_modules/glob-parent": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", @@ -7694,6 +7948,23 @@ "@types/yauzl": "^2.9.1" } }, + "node_modules/extract-zip/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/fast-deep-equal": { "version": "3.1.3", "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", @@ -8248,6 +8519,23 @@ "node": ">= 14" } }, + "node_modules/get-uri/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/getobject": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/getobject/-/getobject-1.0.2.tgz", @@ -8989,6 +9277,23 @@ "node": ">= 14" } }, + "node_modules/http-proxy-agent/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/http-proxy-middleware": { "version": "2.0.6", "resolved": "https://registry.npmjs.org/http-proxy-middleware/-/http-proxy-middleware-2.0.6.tgz", @@ -9028,6 +9333,23 @@ "node": ">= 14" } }, + "node_modules/https-proxy-agent/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/hyperdyperid": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/hyperdyperid/-/hyperdyperid-1.2.0.tgz", @@ -9854,6 +10176,10 @@ "node": ">=8" } }, + "node_modules/itowns": { + "resolved": "packages/Main", + "link": true + }, "node_modules/its-fine": { "version": "1.2.5", "resolved": "https://registry.npmjs.org/its-fine/-/its-fine-1.2.5.tgz", @@ -10735,6 +11061,23 @@ "wrap-ansi": "^7.0.0" } }, + "node_modules/mocha/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/mocha/node_modules/glob": { "version": "8.1.0", "resolved": "https://registry.npmjs.org/glob/-/glob-8.1.0.tgz", @@ -11346,6 +11689,23 @@ "node": ">= 14" } }, + "node_modules/pac-proxy-agent/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/pac-resolver": { "version": "7.0.1", "resolved": "https://registry.npmjs.org/pac-resolver/-/pac-resolver-7.0.1.tgz", @@ -11894,6 +12254,23 @@ "node": ">= 14" } }, + "node_modules/proxy-agent/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/proxy-agent/node_modules/lru-cache": { "version": "7.18.3", "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-7.18.3.tgz", @@ -11982,6 +12359,23 @@ "node": ">=18" } }, + "node_modules/puppeteer-core/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/q": { "version": "1.5.1", "resolved": "https://registry.npmjs.org/q/-/q-1.5.1.tgz", @@ -12794,6 +13188,15 @@ "integrity": "sha512-PdhdWy89SiZogBLaw42zdeqtRJ//zFd2PgQavcICDUgJT5oW10QCRKbJ6bg4r0/UY2M6BWd5tkxuGFRvCkgfHQ==", "license": "BSD-3-Clause" }, + "node_modules/rxjs": { + "version": "7.8.1", + "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.8.1.tgz", + "integrity": "sha512-AA3TVj+0A2iuIoQkWEK/tqFjBq2j+6PO6Y0zJcvzLAFhEFIO3HL0vls9hWLncZbAAbK0mar7oZ4V079I/qPMxg==", + "dev": true, + "dependencies": { + "tslib": "^2.1.0" + } + }, "node_modules/safe-array-concat": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.1.2.tgz", @@ -13349,6 +13752,23 @@ "node": ">= 14" } }, + "node_modules/socks-proxy-agent/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/source-map": { "version": "0.6.1", "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", @@ -13380,6 +13800,12 @@ "source-map": "^0.6.0" } }, + "node_modules/spawn-command": { + "version": "0.0.2", + "resolved": "https://registry.npmjs.org/spawn-command/-/spawn-command-0.0.2.tgz", + "integrity": "sha512-zC8zGoGkmc8J9ndvml8Xksr1Amk9qBujgbF0JAIWO7kXr43w0h/0GJNM/Vustixu+YE8N/MTrQ7N31FvHUACxQ==", + "dev": true + }, "node_modules/spdx-correct": { "version": "3.2.0", "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.2.0.tgz", @@ -13448,6 +13874,23 @@ "wbuf": "^1.7.3" } }, + "node_modules/spdy-transport/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/spdy-transport/node_modules/readable-stream": { "version": "3.6.2", "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", @@ -13473,6 +13916,23 @@ "safe-buffer": "~5.2.0" } }, + "node_modules/spdy/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dev": true, + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/split2": { "version": "4.2.0", "resolved": "https://registry.npmjs.org/split2/-/split2-4.2.0.tgz", @@ -13997,6 +14457,22 @@ "tiny-worker": ">= 2" } }, + "node_modules/threads/node_modules/debug": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz", + "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, "node_modules/three": { "version": "0.168.0", "resolved": "https://registry.npmjs.org/three/-/three-0.168.0.tgz", @@ -14139,6 +14615,15 @@ "tslib": "2" } }, + "node_modules/tree-kill": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz", + "integrity": "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==", + "dev": true, + "bin": { + "tree-kill": "cli.js" + } + }, "node_modules/ts-api-utils": { "version": "1.3.0", "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.3.0.tgz", @@ -15034,6 +15519,10 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/Widgets": { + "resolved": "packages/Widgets", + "link": true + }, "node_modules/wildcard": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/wildcard/-/wildcard-2.0.1.tgz", @@ -15286,6 +15775,65 @@ "optional": true } } + }, + "packages/Debug": { + "version": "2.44.2", + "license": "(CECILL-B OR MIT)", + "dependencies": { + "@tweenjs/tween.js": "^25.0.0", + "chart.js": "^4.4.4", + "dat.gui": "^0.7.9", + "itowns": "^2.44.2" + }, + "peerDependencies": { + "three": "^0.168.0" + } + }, + "packages/Geographic": { + "name": "@itowns/geographic", + "version": "2.44.2", + "license": "(CECILL-B OR MIT)", + "peerDependencies": { + "proj4": "^2.12.1", + "three": "^0.168.0" + } + }, + "packages/Main": { + "name": "itowns", + "version": "2.44.2", + "hasInstallScript": true, + "license": "(CECILL-B OR MIT)", + "dependencies": { + "@itowns/geographic": "^2.44.2", + "@mapbox/vector-tile": "^2.0.3", + "@maplibre/maplibre-gl-style-spec": "^22.0.0", + "@tmcw/togeojson": "^5.8.1", + "@tweenjs/tween.js": "^25.0.0", + "3d-tiles-renderer": "^0.3.39", + "brotli-compress": "^1.3.3", + "copc": "^0.0.6", + "earcut": "^3.0.0", + "js-priority-queue": "^0.1.5", + "pbf": "^4.0.1", + "shpjs": "^6.1.0", + "threads": "^1.7.0" + }, + "devDependencies": { + "chalk": "^5.3.0", + "copyfiles": "^2.4.1" + }, + "peerDependencies": { + "proj4": "^2.12.1", + "three": "^0.168.0" + } + }, + "packages/Widgets": { + "version": "2.44.2", + "license": "(CECILL-B OR MIT)", + "dependencies": { + "@itowns/geographic": "^2.44.2", + "itowns": "^2.44.2" + } } } } diff --git a/package.json b/package.json index 3937c01f21..c6c55ce6d5 100644 --- a/package.json +++ b/package.json @@ -1,43 +1,48 @@ { - "name": "itowns", + "private": true, "version": "2.44.2", "description": "A JS/WebGL framework for 3D geospatial data visualization", "type": "module", - "main": "lib/Main.js", - "exports": { - ".": "./lib/Main.js", - "./widgets": "./lib/Utils/gui/Main.js" - }, + "workspaces": [ + "packages/Geographic", + "packages/Main", + "packages/Debug", + "packages/Widgets" + ], "scripts": { - "lint": "eslint \"src/**/*.{js,ts,tsx}\" \"test/**/*.js\" \"examples/**/*.js\" \"docs/*.js\"", + "lint": "npm run lint --workspaces && eslint \"examples/**/*.js\" \"docs/*.js\"", "doc": "jsdoc --readme docs/HOMEPAGE.md -c docs/config.json", "doclint": "npm run doc -- -t templates/silent", - "test": "npm run lint -- --max-warnings=0 && npm run build && npm run test-with-coverage && npm run test-functional", - "test-dev": "npm run lint -- --max-warnings=0 && npm run build-dev && npm run test-with-coverage && npm run test-functional", - "test-unit": "npm run base-test-unit test/unit", - "test-functional": "mocha -t 100000 --require test/hooks_functional.js --recursive test/functional", - "test-with-coverage": "c8 -n src -r html cross-env npm run test-unit", - "test-with-coverage_lcov": "c8 -n src --reporter=lcov cross-env npm run test-unit", - "base-test-unit": "cross-env BABEL_DISABLE_CACHE=1 mocha --file test/unit/bootstrap.js --import=./config/babel-register/register.mjs", - "build": "cross-env NODE_ENV=production webpack", + "test": "npm run transpile && npm run test-with-coverage && npm run build && npm run test-functional", + "test-dev": "npm run test-unit && npm run build-dev && npm run test-functional", + "test-unit": "npm run test-unit --workspaces --if-present", + "test-functional": "npm run build && mocha -t 100000 --require test/hooks_functional.js --recursive test/functional", + "test-with-coverage": "npm run test-with-coverage --workspaces --if-present", + "test-with-coverage_lcov": "npm run test-with-coverage_lcov --workspaces --if-present && c8 report --reporter=lcov", + "build": "npm run transpile && cross-env NODE_ENV=production webpack", "build-dev": "cross-env NODE_ENV=development webpack", - "transpile": "cross-env BABEL_DISABLE_CACHE=1 babel src --out-dir lib --extensions .js,.ts", + "transpile": "npm run transpile --workspaces", "start": "cross-env NODE_ENV=development webpack serve", "start-https": "cross-env NODE_ENV=development webpack serve --https", "debug": "cross-env noInline=true npm start", "prepublishOnly": "npm run build && npm run transpile", - "prepare": "cross-env NO_UPDATE_NOTIFIER=true node ./config/prepare.mjs && node ./config/replace.config.mjs", - "watch": "npm run transpile -- --watch", + "prepare": "cross-env NO_UPDATE_NOTIFIER=true node ./config/prepare.mjs && npm run prepare --workspaces --if-present", + "watch": "node ./config/concurrently.mjs watch", "changelog": "conventional-changelog -n ./config/conventionalChangelog/config.cjs -i changelog.md -s", - "bump": "if [ -z $npm_config_level ]; then grunt bump:minor; else grunt bump:$npm_config_level; fi && npm run changelog && npm install && git add -A && git commit --amend --no-edit", - "publish-next": "npm version prerelease --preid next && npm publish --access public --tag=next --provenance", - "publish-latest": "npm publish --access public --tag=latest --provenance" + "bump": "if [ -z $npm_config_level ]; then grunt bump:minor; else grunt bump:$npm_config_level; fi && npm run changelog && npm run update-packages && npm install && git add -A && git commit --amend --no-edit", + "publish-next": "npm run publish-next -workspaces --if-present && npm publish --access public --tag=next --workspaces --provenance", + "publish-latest": "npm publish --access public --tag=latest --provenance --workspaces", + "update-packages": "npm run update-package -workspaces --if-present" }, "c8": { "exclude": [ + "**/test/**", + "**/lib/**", "**/*ThreeExtended", "**/*src/Utils/placeObjectOnGround.js", - "**/*src/Parser/deprecated/LegacyGLTFLoader.js" + "**/*src/Parser/deprecated/LegacyGLTFLoader.js", + "**/packages/Widgets/", + "**/packages/Debug/" ] }, "files": [ @@ -56,24 +61,6 @@ "url": "https://github.com/iTowns/itowns/issues" }, "homepage": "https://itowns.github.io/", - "dependencies": { - "@mapbox/vector-tile": "^2.0.3", - "@maplibre/maplibre-gl-style-spec": "^22.0.0", - "@tmcw/togeojson": "^5.8.1", - "@tweenjs/tween.js": "^25.0.0", - "3d-tiles-renderer": "^0.3.39", - "brotli-compress": "^1.3.3", - "copc": "^0.0.6", - "earcut": "^3.0.0", - "js-priority-queue": "^0.1.5", - "pbf": "^4.0.1", - "shpjs": "^6.1.0", - "threads": "^1.7.0" - }, - "peerDependencies": { - "proj4": "^2.12.1", - "three": "^0.168.0" - }, "devDependencies": { "@babel/cli": "^7.25.6", "@babel/core": "^7.25.2", @@ -96,8 +83,8 @@ "babel-plugin-module-resolver": "^5.0.2", "c8": "^10.1.2", "chalk": "^5.3.0", - "chart.js": "^4.4.4", "compare-func": "^2.0.0", + "concurrently": "^8.2.2", "conventional-changelog-cli": "^4.1.0", "copyfiles": "^2.4.1", "core-js": "^3.38.1", diff --git a/packages/Debug/.babelrc b/packages/Debug/.babelrc new file mode 100644 index 0000000000..37a7182f87 --- /dev/null +++ b/packages/Debug/.babelrc @@ -0,0 +1,25 @@ +{ + "presets": [ + ["@babel/preset-typescript"], + ["@babel/preset-env", { + "targets": { + "browsers": "defaults and supports webgl2" + }, + "modules": false + }] + ], + "plugins": [ + ["module-resolver", { + "cwd": "packagejson", + "root": ["./src"], + "extensions": [".js", ".ts", ".tsx"] + }], + ["module-extension-resolver", { + "srcExtensions": [".ts", ".js"] + }], + ["@babel/plugin-transform-runtime", { + "regenerator": false + }], + ["minify-dead-code-elimination"] + ] +} diff --git a/packages/Debug/.eslintrc.cjs b/packages/Debug/.eslintrc.cjs new file mode 100644 index 0000000000..9e9e3440e3 --- /dev/null +++ b/packages/Debug/.eslintrc.cjs @@ -0,0 +1,7 @@ + +module.exports = { + extends: [ + '../../.eslintrc.cjs', + ], +}; + diff --git a/packages/Debug/README.md b/packages/Debug/README.md new file mode 100644 index 0000000000..cf61f418f9 --- /dev/null +++ b/packages/Debug/README.md @@ -0,0 +1,33 @@ +## iTowns Debug (private, for the moment) + +iTowns debugging utilities. + +## Getting started + +For the moment, The debug features aren't exposed in `itowns` module but in bundle. +We provide a debug bundle you can directly include in your html files: + +```html + + + + +``` + diff --git a/packages/Debug/package.json b/packages/Debug/package.json new file mode 100644 index 0000000000..a6fd50fb83 --- /dev/null +++ b/packages/Debug/package.json @@ -0,0 +1,37 @@ +{ + "private": true, + "version": "2.44.2", + "type": "module", + "main": "lib/Main.js", + "exports": { + ".": "./lib/Main.js" + }, + "scripts": { + "lint": "eslint \"src/**/*.{js,ts,tsx}\"", + "transpile": "cross-env BABEL_DISABLE_CACHE=1 babel src --out-dir lib --extensions .js,.ts", + "watch": "npm run transpile -- --watch" + }, + "files": [ + "*.md", + "src", + "lib" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/iTowns/itowns.git" + }, + "license": "(CECILL-B OR MIT)", + "bugs": { + "url": "https://github.com/itowns/itowns/issues" + }, + "homepage": "https://itowns.github.io/", + "dependencies": { + "chart.js": "^4.4.4", + "dat.gui": "^0.7.9", + "itowns": "^2.44.2", + "@tweenjs/tween.js": "^25.0.0" + }, + "peerDependencies": { + "three": "^0.168.0" + } +} diff --git a/utils/debug/3dTilesDebug.js b/packages/Debug/src/3dTilesDebug.js similarity index 95% rename from utils/debug/3dTilesDebug.js rename to packages/Debug/src/3dTilesDebug.js index 3081c193da..b21db437e7 100644 --- a/utils/debug/3dTilesDebug.js +++ b/packages/Debug/src/3dTilesDebug.js @@ -1,8 +1,5 @@ import * as THREE from 'three'; -import View from 'Core/View'; -import GeometryLayer from 'Layer/GeometryLayer'; -import { C3DTilesBoundingVolumeTypes } from 'Core/3DTiles/C3DTilesEnums'; -import { PNTS_MODE, PNTS_SHAPE, PNTS_SIZE_MODE } from 'Renderer/PointsMaterial'; +import { View, GeometryLayer, C3DTilesBoundingVolumeTypes, PNTS_MODE, PNTS_SHAPE, PNTS_SIZE_MODE } from 'itowns'; import GeometryDebug from './GeometryDebug'; const bboxMesh = new THREE.Mesh(); diff --git a/utils/debug/Debug.js b/packages/Debug/src/Debug.js similarity index 98% rename from utils/debug/Debug.js rename to packages/Debug/src/Debug.js index 55361cf5b6..d0b52f774a 100644 --- a/utils/debug/Debug.js +++ b/packages/Debug/src/Debug.js @@ -1,7 +1,6 @@ import { CameraHelper, Color, Vector3 } from 'three'; -import Coordinates from 'Core/Geographic/Coordinates'; -import { MAIN_LOOP_EVENTS } from 'Core/MainLoop'; -import OBB from 'Renderer/OBB'; +import { Coordinates } from '@itowns/geographic'; +import { MAIN_LOOP_EVENTS, OBB } from 'itowns'; import * as THREE from 'three'; import ThreeStatsChart from './charts/ThreeStatsChart'; import { backgroundChartDiv, color_blue } from './charts/ChartConfig'; diff --git a/utils/debug/GeometryDebug.js b/packages/Debug/src/GeometryDebug.js similarity index 100% rename from utils/debug/GeometryDebug.js rename to packages/Debug/src/GeometryDebug.js diff --git a/packages/Debug/src/GuiTools.js b/packages/Debug/src/GuiTools.js new file mode 100644 index 0000000000..fc75cd228f --- /dev/null +++ b/packages/Debug/src/GuiTools.js @@ -0,0 +1,184 @@ +import * as itowns from 'itowns'; +import * as dat from 'dat.gui'; + +dat.GUI.prototype.removeFolder = function removeFolder(name) { + const folder = this.__folders[name]; + if (!folder) { + return; + } + folder.close(); + this.__ul.removeChild(folder.domElement.parentNode); + delete this.__folders[name]; + this.onResize(); +}; + +dat.GUI.prototype.colorLayerFolder = function colorLayerFolder(name, value) { + const folder = this.__folders[name]; + if (!folder) { + return; + } + const title = folder.__ul.getElementsByClassName('title')[0]; + + if (title.style) { + title.style.background = value; + } +}; + +dat.GUI.prototype.hasFolder = function hasFolder(name) { + return this.__folders[name]; +}; + +function GuiTools(domId, view, w) { + if (view) { + const width = w || 245; + const element = document.createElement('div'); + element.id = 'menuDiv'; + this.gui = new dat.GUI({ autoPlace: false, width }); + element.appendChild(this.gui.domElement); + document.body.appendChild(element); + this.colorGui = this.gui.addFolder('Color Layers'); + this.elevationGui = this.gui.addFolder('Elevation Layers'); + this.geoidGui = this.gui.addFolder('Geoid Layers'); + this.elevationGui.hide(); + this.colorGui.hide(); + this.geoidGui.hide(); + this.view = view; + view.addEventListener('layers-order-changed', (() => { + let i; + const colorLayers = view.getLayers(l => l.isColorLayer); + for (i = 0; i < colorLayers.length; i++) { + this.removeLayersGUI(colorLayers[i].id); + } + + this.addImageryLayersGUI(colorLayers); + })); + } +} + +GuiTools.prototype.addLayerGUI = function fnAddLayerGUI(layer) { + if (layer.isColorLayer) { + this.addImageryLayerGUI(layer); + } else if (layer.isElevationLayer) { + this.addElevationLayerGUI(layer); + } else if (layer.isGeoidLayer) { + this.addGeoidLayerGUI(layer); + } +}; + +GuiTools.prototype.addLayersGUI = function fnAddLayersGUI() { + function filterColor(l) { return l.isColorLayer; } + function filterElevation(l) { return l.isElevationLayer; } + this.addImageryLayersGUI(this.view.getLayers(filterColor)); + this.addElevationLayersGUI(this.view.getLayers(filterElevation)); + // eslint-disable-next-line no-console + console.info('menu initialized'); +}; + +GuiTools.prototype.addImageryLayerGUI = function addImageryLayerGUI(layer) { + if (this.colorGui.hasFolder(layer.id)) { return; } + this.colorGui.show(); + const folder = this.colorGui.addFolder(layer.id); + folder.add({ visible: layer.visible }, 'visible').onChange(((value) => { + layer.visible = value; + this.view.notifyChange(layer); + })); + folder.add({ opacity: layer.opacity }, 'opacity', 0.0, 1.0, 0.01).onChange(((value) => { + layer.opacity = value; + this.view.notifyChange(layer); + })); + folder.add({ frozen: layer.frozen }, 'frozen').onChange(((value) => { + layer.frozen = value; + this.view.notifyChange(layer); + })); +}; + +GuiTools.prototype.addElevationLayerGUI = function addElevationLayerGUI(layer) { + if (this.elevationGui.hasFolder(layer.id)) { return; } + this.elevationGui.show(); + const folder = this.elevationGui.addFolder(layer.id); + folder.add({ frozen: layer.frozen }, 'frozen').onChange((value) => { + layer.frozen = value; + }); + folder.add({ scale: layer.scale }, 'scale').min(1.0).max(20000.0).onChange(((value) => { + layer.scale = value; + this.view.notifyChange(layer); + })); +}; + +GuiTools.prototype.addGeoidLayerGUI = function addGeoidLayerGUI(layer) { + if (this.geoidGui.hasFolder(layer.id)) { return; } + this.geoidGui.show(); + const folder = this.geoidGui.addFolder(layer.id); + folder.add({ frozen: layer.frozen }, 'frozen').onChange((value) => { + layer.frozen = value; + }); + folder.add({ visible: layer.visible }, 'visible').onChange(((value) => { + layer.visible = value; + this.view.notifyChange(layer); + })); +}; + +GuiTools.prototype.addImageryLayersGUI = function addImageryLayersGUI(layers) { + let i; + const seq = itowns.ImageryLayers.getColorLayersIdOrderedBySequence(layers); + const sortedLayers = layers.sort((a, b) => seq.indexOf(a.id) < seq.indexOf(b.id)); + for (i = 0; i < sortedLayers.length; i++) { + this.addImageryLayerGUI(sortedLayers[i]); + } +}; + +GuiTools.prototype.addElevationLayersGUI = function addElevationLayersGUI(layers) { + let i; + for (i = 0; i < layers.length; i++) { + this.addElevationLayerGUI(layers[i]); + } +}; + +GuiTools.prototype.removeLayersGUI = function removeLayersGUI(nameLayer) { + this.colorGui.removeFolder(nameLayer); +}; + +GuiTools.prototype.addGUI = function addGUI(name, value, callback) { + this[name] = value; + return this.gui.add(this, name).onChange(callback); +}; + +GuiTools.prototype.colorLayerFolder = function colorLayerFolder(nameLayer, value) { + this.colorGui.colorLayerFolder(nameLayer, value); +}; + +// Recursive function that creates an HTML List from a javascript +// object +// eslint-disable-next-line no-unused-vars +function createHTMLListFromObject(jsObject) { + const list = document.createElement('ul'); + // Change the padding (top: 0, right:0, bottom:0 and left:1.5) + list.style.padding = '0 0 0 1.5rem'; + // For each property of the object + Object.keys(jsObject).forEach((property) => { + // create item + const item = document.createElement('li'); + // append property name + item.appendChild(document.createTextNode(property)); + + if (jsObject[property] === null) { + jsObject[property] = 'null'; + } + + if (typeof jsObject[property] === 'object') { + // if property value is an object, then recurse to + // create a list from it + // eslint-disable-next-line no-unused-vars + item.appendChild(createHTMLListFromObject(jsObject[property])); + } else { + // else append the value of the property to the item + item.appendChild(document.createTextNode(': ')); + item.appendChild( + document.createTextNode(jsObject[property])); + } + list.appendChild(item); + }); + return list; +} + +export default GuiTools; diff --git a/packages/Debug/src/Main.js b/packages/Debug/src/Main.js new file mode 100644 index 0000000000..fd694f0645 --- /dev/null +++ b/packages/Debug/src/Main.js @@ -0,0 +1,7 @@ +export { default as Debug } from 'Debug'; +export { default as PointCloudDebug } from 'PointCloudDebug'; +export { default as createTileDebugUI } from 'TileDebug'; +export { default as create3dTilesDebugUI } from '3dTilesDebug'; +export { default as createOGC3DTilesDebugUI } from 'OGC3DTilesDebug'; +export { default as GeometryDebug } from 'GeometryDebug'; +export { default as GuiTools } from 'GuiTools'; diff --git a/utils/debug/OBBHelper.js b/packages/Debug/src/OBBHelper.js similarity index 100% rename from utils/debug/OBBHelper.js rename to packages/Debug/src/OBBHelper.js diff --git a/utils/debug/OGC3DTilesDebug.js b/packages/Debug/src/OGC3DTilesDebug.js similarity index 97% rename from utils/debug/OGC3DTilesDebug.js rename to packages/Debug/src/OGC3DTilesDebug.js index 7963f4314c..f528a46b06 100644 --- a/utils/debug/OGC3DTilesDebug.js +++ b/packages/Debug/src/OGC3DTilesDebug.js @@ -1,6 +1,6 @@ import { DebugTilesPlugin } from '3d-tiles-renderer'; -import { PNTS_MODE, PNTS_SHAPE, PNTS_SIZE_MODE } from 'Renderer/PointsMaterial'; +import { PNTS_MODE, PNTS_SHAPE, PNTS_SIZE_MODE } from 'itowns'; import GeometryDebug from './GeometryDebug'; export default function createOGC3DTilesDebugUI(datDebugTool, view, _3dTileslayer) { diff --git a/utils/debug/PointCloudDebug.js b/packages/Debug/src/PointCloudDebug.js similarity index 99% rename from utils/debug/PointCloudDebug.js rename to packages/Debug/src/PointCloudDebug.js index b2a963ad9d..b497cc6204 100644 --- a/utils/debug/PointCloudDebug.js +++ b/packages/Debug/src/PointCloudDebug.js @@ -1,4 +1,4 @@ -import { PNTS_MODE, PNTS_SHAPE, PNTS_SIZE_MODE } from 'Renderer/PointsMaterial'; +import { PNTS_MODE, PNTS_SHAPE, PNTS_SIZE_MODE } from 'itowns'; function getController(gui, name) { let controller = null; diff --git a/utils/debug/TileDebug.js b/packages/Debug/src/TileDebug.js similarity index 98% rename from utils/debug/TileDebug.js rename to packages/Debug/src/TileDebug.js index 1866698264..77852c129d 100644 --- a/utils/debug/TileDebug.js +++ b/packages/Debug/src/TileDebug.js @@ -1,8 +1,6 @@ import * as THREE from 'three'; import TWEEN from '@tweenjs/tween.js'; -import GeometryLayer from 'Layer/GeometryLayer'; -import { MAIN_LOOP_EVENTS } from 'Core/MainLoop'; -import ObjectRemovalHelper from 'Process/ObjectRemovalHelper'; +import { MAIN_LOOP_EVENTS, GeometryLayer, ObjectRemovalHelper } from 'itowns'; import TileObjectChart from './charts/TileObjectChart'; import TileVisibilityChart from './charts/TileVisibilityChart'; import GeometryDebug from './GeometryDebug'; diff --git a/utils/debug/charts/ChartConfig.js b/packages/Debug/src/charts/ChartConfig.js similarity index 100% rename from utils/debug/charts/ChartConfig.js rename to packages/Debug/src/charts/ChartConfig.js diff --git a/utils/debug/charts/ThreeStatsChart.js b/packages/Debug/src/charts/ThreeStatsChart.js similarity index 100% rename from utils/debug/charts/ThreeStatsChart.js rename to packages/Debug/src/charts/ThreeStatsChart.js diff --git a/utils/debug/charts/TileObjectChart.js b/packages/Debug/src/charts/TileObjectChart.js similarity index 100% rename from utils/debug/charts/TileObjectChart.js rename to packages/Debug/src/charts/TileObjectChart.js diff --git a/utils/debug/charts/TileVisibilityChart.js b/packages/Debug/src/charts/TileVisibilityChart.js similarity index 100% rename from utils/debug/charts/TileVisibilityChart.js rename to packages/Debug/src/charts/TileVisibilityChart.js diff --git a/packages/Debug/tsconfig.json b/packages/Debug/tsconfig.json new file mode 100644 index 0000000000..8c6936f80e --- /dev/null +++ b/packages/Debug/tsconfig.json @@ -0,0 +1,10 @@ +{ + "extends": "../../tsconfig.json", + "include": [ "src/Main.js" ], + "exclude": [ "node_modules", "lib" ], + "compilerOptions": { + "paths": { + "*": [ "src/*" ] + }, + } +} diff --git a/packages/Geographic/.babelrc b/packages/Geographic/.babelrc new file mode 100644 index 0000000000..160b1d5ea3 --- /dev/null +++ b/packages/Geographic/.babelrc @@ -0,0 +1,21 @@ +{ + "presets": [ + ["@babel/preset-typescript"], + ["@babel/preset-env", { + "targets": { + "browsers": "defaults and supports webgl2" + }, + "modules": false + }] + ], + "plugins": [ + ["module-resolver", { + "cwd": "packagejson", + "root": ["./src"], + "extensions": [".js", ".ts", ".tsx"] + }], + ["module-extension-resolver", { + "srcExtensions": [".ts", ".js"] + }], + ] +} diff --git a/packages/Geographic/.eslintrc.cjs b/packages/Geographic/.eslintrc.cjs new file mode 100644 index 0000000000..9e9e3440e3 --- /dev/null +++ b/packages/Geographic/.eslintrc.cjs @@ -0,0 +1,7 @@ + +module.exports = { + extends: [ + '../../.eslintrc.cjs', + ], +}; + diff --git a/packages/Geographic/README.md b/packages/Geographic/README.md new file mode 100644 index 0000000000..ae3d0dc78b --- /dev/null +++ b/packages/Geographic/README.md @@ -0,0 +1,67 @@ +## iTowns Geographic + +The geographic package provides utilities for handling coordinates, ellipsoids, extents and rotations across different coordinate systems. + +* [Coordinates](http://www.itowns-project.org/itowns/docs/#api/Geographic/Coordinates) : A Coordinates object (geodetic datum), defined by a [crs] and three values. +* [Coordinates stars] : get sun position, azimuth, ascention, ecliptic longitude and declination from date. +* [Coordinate Reference System](http://www.itowns-project.org/itowns/docs/#api/Geographic/CRS) : This module provides basic methods to manipulate a CRS (as a string). to explore available coordinates systems and use their **proj4js** definition to define them in itowns with `proj4.defs(crs, proj4def)`. +* Ellipsoid : A representation of an [ellipsoid](https://en.wikipedia.org/wiki/Ellipsoid) and useful computation methods (geodetic normal, etc.) +* Ellipsoid Size: The length of the earth ellispoid semi-axes. +* [Extent](http://www.itowns-project.org/itowns/docs/#api/Geographic/Extent) : Extent is geographical bounding rectangle defined by a crs and 4 limits: west, east, south and north . +* [OrientationUtils](http://www.itowns-project.org/itowns/docs/#api/Geographic/OrientationUtils) : utilities to compute a rotation quaternion from various rotation conventions, including between different crs. + +# Install + +`npm install --save @itowns/geographic` + +# Getting started + +```js +import { Coordinates, Extent, CRS } from '@itowns/geographic'; + +const coordinates = new Coordinates('EPSG:4326', 88.002445, 50.336522, 120.32201); +const extent = new Extent('EPSG:4326', 88.002445, 50.336522, 22.021, 50.302548); + +// change projection system to pseudo mercator + +coordinates.as('EPSG:3857'); +extent.as('EPSG:3857'); + +// change projection system to EPSG:2154 + +// defs EPSG:2154 crs (visit epsg.io to get the proj4js definition of a crs) +CRS.defs('EPSG:2154','+proj=lcc +lat_0=46.5 +lon_0=3 +lat_1=49 +lat_2=44 +x_0=700000 +y_0=6600000 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs +type=crs'); + +coordinates.as('EPSG:2154'); + +``` + +## OrientationUtils example + +In geodesy, attitude refers to the orientation of a geodetic instrument or platform in three-dimensional space. It is defined by the angles that describe how an instrument or a vehicle (like a satellite or aircraft) is positioned relative to a reference coordinate system, typically the Earth's surface or a local tangent plane. + +```js +// Compute the rotation around the point of origin from a frame aligned with Lambert93 axes (epsg:2154), +// to the geocentric frame (epsg:4978) + +quat_crs2crs = OrientationUtils.quaternionFromCRSToCRS("EPSG:2154", "EPSG:4978")(origin); + +// Compute the rotation of a sensor platform defined by its attitude + +const attitude = { + // Rotation around the longitudinal axis of the object (front-to-back axis), tilting the object sideways. + Roll: 0.0, + // Rotation around the lateral axis (side-to-side axis), moving the nose or front up or down. + Pitch: Math.PI * 0.2, + // Rotation around the vertical axis (top-to-bottom axis), changing the direction the object is facing horizontally. + Yaw: Math.PI * 0.5, +} + +quat_attitude = OrientationUtils.quaternionFromAttitude(attitude); + +// Compute the rotation from the sensor platform frame to the geocentric frame + +quat = quat_crs2crs.multiply(quat_attitude); +``` + +Visit the iTowns [documentation](http://www.itowns-project.org/itowns/docs/#home) for more information. diff --git a/packages/Geographic/package.json b/packages/Geographic/package.json new file mode 100644 index 0000000000..86df9b4fc3 --- /dev/null +++ b/packages/Geographic/package.json @@ -0,0 +1,39 @@ +{ + "name": "@itowns/geographic", + "version": "2.44.2", + "description": "Geodesy", + "type": "module", + "main": "lib/Main.js", + "exports": { + ".": "./lib/Main.js" + }, + "scripts": { + "build": "", + "lint": "eslint \"src/**/*.{js,ts,tsx}\" \"test/**/*.js\"", + "transpile": "cross-env BABEL_DISABLE_CACHE=1 babel src --out-dir lib --extensions .js,.ts", + "test-unit": "npm run base-test-unit test/unit", + "base-test-unit": "cross-env BABEL_DISABLE_CACHE=1 mocha --import=../../config/babel-register/register.mjs", + "test-with-coverage": "c8 -n src -r html cross-env npm run test-unit", + "test-with-coverage_lcov": "c8 -n src --reporter=lcov cross-env npm run test-unit", + "watch": "npm run transpile -- --watch", + "publish-next": "npm version prerelease --preid next" + }, + "files": [ + "*.md", + "src", + "lib" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/iTowns/itowns.git" + }, + "license": "(CECILL-B OR MIT)", + "bugs": { + "url": "https://github.com/itowns/itowns/issues" + }, + "peerDependencies": { + "proj4": "^2.12.1", + "three": "^0.168.0" + }, + "homepage": "https://itowns.github.io/" +} diff --git a/src/Core/Geographic/CoordStars.js b/packages/Geographic/src/CoordStars.js similarity index 98% rename from src/Core/Geographic/CoordStars.js rename to packages/Geographic/src/CoordStars.js index 34066a728f..593b4e4243 100644 --- a/src/Core/Geographic/CoordStars.js +++ b/packages/Geographic/src/CoordStars.js @@ -3,7 +3,7 @@ * Class: CoordStars * Description: get coord of stars like earth... */ -import Coordinates from 'Core/Geographic/Coordinates'; +import Coordinates from 'Coordinates'; const CoordStars = { diff --git a/src/Core/Geographic/Coordinates.ts b/packages/Geographic/src/Coordinates.ts similarity index 99% rename from src/Core/Geographic/Coordinates.ts rename to packages/Geographic/src/Coordinates.ts index ca134ee415..01f1b8450e 100644 --- a/src/Core/Geographic/Coordinates.ts +++ b/packages/Geographic/src/Coordinates.ts @@ -1,7 +1,7 @@ import * as THREE from 'three'; import proj4 from 'proj4'; -import * as CRS from 'Core/Geographic/Crs'; -import Ellipsoid from 'Core/Math/Ellipsoid'; +import Ellipsoid from 'Ellipsoid'; +import * as CRS from './Crs'; import type { ProjectionLike } from './Crs'; diff --git a/src/Core/Geographic/Crs.ts b/packages/Geographic/src/Crs.ts similarity index 100% rename from src/Core/Geographic/Crs.ts rename to packages/Geographic/src/Crs.ts diff --git a/src/Core/Math/Ellipsoid.ts b/packages/Geographic/src/Ellipsoid.ts similarity index 99% rename from src/Core/Math/Ellipsoid.ts rename to packages/Geographic/src/Ellipsoid.ts index 67ef10d405..8450804a33 100644 --- a/src/Core/Math/Ellipsoid.ts +++ b/packages/Geographic/src/Ellipsoid.ts @@ -1,6 +1,6 @@ import * as THREE from 'three'; import proj4 from 'proj4'; -import Coordinates from '../Geographic/Coordinates'; +import Coordinates from 'Coordinates'; /** * Length of the semi-axes of the WGS84 ellipsoid. diff --git a/src/Core/Geographic/Extent.js b/packages/Geographic/src/Extent.js similarity index 100% rename from src/Core/Geographic/Extent.js rename to packages/Geographic/src/Extent.js index 39c9ddf1ab..ec89d94814 100644 --- a/src/Core/Geographic/Extent.js +++ b/packages/Geographic/src/Extent.js @@ -1,6 +1,6 @@ import * as THREE from 'three'; -import * as CRS from './Crs'; import Coordinates from './Coordinates'; +import * as CRS from './Crs'; /** * Extent is a SIG-area (so 2D) diff --git a/packages/Geographic/src/Main.js b/packages/Geographic/src/Main.js new file mode 100644 index 0000000000..5eb45d829f --- /dev/null +++ b/packages/Geographic/src/Main.js @@ -0,0 +1,8 @@ +// Geodesic tools +export { default as Extent } from 'Extent'; +export { default as Coordinates } from 'Coordinates'; +export * as CRS from 'Crs'; +export { default as CoordStars } from 'CoordStars'; +export { default as OrientationUtils } from 'OrientationUtils'; +export { default as Ellipsoid, ellipsoidSizes } from 'Ellipsoid'; + diff --git a/src/Utils/OrientationUtils.js b/packages/Geographic/src/OrientationUtils.js similarity index 99% rename from src/Utils/OrientationUtils.js rename to packages/Geographic/src/OrientationUtils.js index 55a9b63c00..1687f51005 100644 --- a/src/Utils/OrientationUtils.js +++ b/packages/Geographic/src/OrientationUtils.js @@ -1,6 +1,6 @@ import * as THREE from 'three'; import proj4 from 'proj4'; -import Coordinates from '../Core/Geographic/Coordinates'; +import Coordinates from 'Coordinates'; const DEG2RAD = THREE.MathUtils.DEG2RAD; const matrix = new THREE.Matrix4(); diff --git a/packages/Geographic/test/.eslintrc.cjs b/packages/Geographic/test/.eslintrc.cjs new file mode 100644 index 0000000000..28b3eb003d --- /dev/null +++ b/packages/Geographic/test/.eslintrc.cjs @@ -0,0 +1,9 @@ +module.exports = { + rules: { + 'func-names': 'off', + 'prefer-arrow-callback': 'off', + }, + env: { + mocha: true, + }, +}; diff --git a/test/unit/coordinate.js b/packages/Geographic/test/unit/coordinate.js similarity index 99% rename from test/unit/coordinate.js rename to packages/Geographic/test/unit/coordinate.js index 90b0524270..507d265183 100644 --- a/test/unit/coordinate.js +++ b/packages/Geographic/test/unit/coordinate.js @@ -1,7 +1,7 @@ import proj4 from 'proj4'; import { Vector3, Matrix4, Quaternion } from 'three'; import assert from 'assert'; -import Coordinates from 'Core/Geographic/Coordinates'; +import Coordinates from 'Coordinates'; // Define crs projection that we will use (taken from https://epsg.io/3946, Proj4js section) proj4.defs('EPSG:3946', '+proj=lcc +lat_1=45.25 +lat_2=46.75 +lat_0=46 +lon_0=3 +x_0=1700000 +y_0=5200000 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs'); diff --git a/test/unit/crs.js b/packages/Geographic/test/unit/crs.js similarity index 98% rename from test/unit/crs.js rename to packages/Geographic/test/unit/crs.js index cf3e64b201..c057ec91de 100644 --- a/test/unit/crs.js +++ b/packages/Geographic/test/unit/crs.js @@ -1,6 +1,6 @@ +import * as CRS from 'Crs'; import assert from 'assert'; import proj4 from 'proj4'; -import * as CRS from 'Core/Geographic/Crs'; proj4.defs('EPSG:7133', '+proj=longlat +ellps=GRS80 +no_defs +units=degrees'); proj4.defs('EPSG:INVALID', '+units=invalid +no_defs'); diff --git a/test/unit/ellipsoid.js b/packages/Geographic/test/unit/ellipsoid.js similarity index 69% rename from test/unit/ellipsoid.js rename to packages/Geographic/test/unit/ellipsoid.js index 88f5c23fe9..6edc5e2003 100644 --- a/test/unit/ellipsoid.js +++ b/packages/Geographic/test/unit/ellipsoid.js @@ -1,6 +1,7 @@ +import { Ray, Vector3 } from 'three'; import assert from 'assert'; -import Coordinates from 'Core/Geographic/Coordinates'; -import Ellipsoid from 'Core/Math/Ellipsoid'; +import Coordinates from 'Coordinates'; +import Ellipsoid from 'Ellipsoid'; describe('Ellipsoid', function () { const c1 = new Coordinates('EPSG:4326', 0, 0, 0); @@ -65,4 +66,31 @@ describe('Ellipsoid', function () { const d = ellipsoid.geodesicDistance(c3, c4) / 1000; assert.ok(Math.abs(d - 200) < 0.01); }); + + it('intersect ray with ellipsoid', () => { + const e = new Ellipsoid({ x: 1, y: 2, z: 3 }); + + // intersection to X axis + const ray = new Ray(new Vector3(10, 0, 0), new Vector3(-1, 0, 0)); + const interX = e.intersection(ray); + assert.equal(interX.x, 1); + assert.equal(interX.y, 0); + assert.equal(interX.z, 0); + + // intersection to Y axis + ray.origin.set(0, 10, 0); + ray.direction.set(0, -1, 0); + const interY = e.intersection(ray); + assert.equal(interY.x, 0); + assert.equal(interY.y, 2); + assert.equal(interY.z, 0); + + // intersection to Z axis + ray.origin.set(0, 0, 10); + ray.direction.set(0, 0, -1); + const interZ = e.intersection(ray); + assert.equal(interZ.x, 0); + assert.equal(interZ.y, 0); + assert.equal(interZ.z.toFixed(5), 3); + }); }); diff --git a/test/unit/extent.js b/packages/Geographic/test/unit/extent.js similarity index 99% rename from test/unit/extent.js rename to packages/Geographic/test/unit/extent.js index 1557526f0e..084fc43c78 100644 --- a/test/unit/extent.js +++ b/packages/Geographic/test/unit/extent.js @@ -1,7 +1,7 @@ import assert from 'assert'; import { Box3, Vector3, Vector2, Matrix4, Quaternion } from 'three'; -import Coordinates from 'Core/Geographic/Coordinates'; -import Extent from 'Core/Geographic/Extent'; +import Coordinates from 'Coordinates'; +import Extent from 'Extent'; import proj4 from 'proj4'; proj4.defs('EPSG:2154', '+proj=lcc +lat_1=49 +lat_2=44 +lat_0=46.5 +lon_0=3 +x_0=700000 +y_0=6600000 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs'); diff --git a/test/unit/orientationUtils.js b/packages/Geographic/test/unit/orientationUtils.js similarity index 98% rename from test/unit/orientationUtils.js rename to packages/Geographic/test/unit/orientationUtils.js index 9e8948d0c8..22dc075ff6 100644 --- a/test/unit/orientationUtils.js +++ b/packages/Geographic/test/unit/orientationUtils.js @@ -1,7 +1,7 @@ import * as THREE from 'three'; import assert from 'assert'; -import OrientationUtils from 'Utils/OrientationUtils'; -import Coordinates from 'Core/Geographic/Coordinates'; +import Coordinates from 'Coordinates'; +import OrientationUtils from 'OrientationUtils'; // Asster two float number are equals, with 5 digits precision. function assertFloatEqual(float1, float2, msg, precision = 15) { diff --git a/packages/Geographic/tsconfig.json b/packages/Geographic/tsconfig.json new file mode 100644 index 0000000000..8c6936f80e --- /dev/null +++ b/packages/Geographic/tsconfig.json @@ -0,0 +1,10 @@ +{ + "extends": "../../tsconfig.json", + "include": [ "src/Main.js" ], + "exclude": [ "node_modules", "lib" ], + "compilerOptions": { + "paths": { + "*": [ "src/*" ] + }, + } +} diff --git a/.babelrc b/packages/Main/.babelrc similarity index 96% rename from .babelrc rename to packages/Main/.babelrc index 02c1f168e9..90337692b3 100644 --- a/.babelrc +++ b/packages/Main/.babelrc @@ -10,6 +10,7 @@ ], "plugins": [ ["module-resolver", { + "cwd": "packagejson", "root": ["./src"], "extensions": [".js", ".ts", ".tsx"] }], diff --git a/packages/Main/.eslintignore b/packages/Main/.eslintignore new file mode 100644 index 0000000000..4abd04c588 --- /dev/null +++ b/packages/Main/.eslintignore @@ -0,0 +1,5 @@ +src/ThreeExtended/ +test/hooks.js +dist/ +node_modules/ +test/data/ diff --git a/packages/Main/.eslintrc.cjs b/packages/Main/.eslintrc.cjs new file mode 100644 index 0000000000..f15429438d --- /dev/null +++ b/packages/Main/.eslintrc.cjs @@ -0,0 +1,6 @@ + +module.exports = { + extends: [ + '../../.eslintrc.cjs', + ], +}; diff --git a/packages/Main/README.md b/packages/Main/README.md new file mode 100644 index 0000000000..52bf3fa7ce --- /dev/null +++ b/packages/Main/README.md @@ -0,0 +1,5 @@ +## What is it? + +This itowns module acts as a central point of access, allowing users to leverage the complete range of features offered by the @itowns submodules without needing to import or manage them individually. +Refer to [README main](https://raw.githubusercontent.com/iTowns/itowns.github.io/master/README.md) for more information. +The official documentation is [available here](http://www.itowns-project.org/itowns/docs/) diff --git a/packages/Main/clean.cjs b/packages/Main/clean.cjs new file mode 100644 index 0000000000..911900b21a --- /dev/null +++ b/packages/Main/clean.cjs @@ -0,0 +1,5 @@ +const fs = require('node:fs'); + +fs.rmSync('./examples', { recursive: true, force: true }); +fs.rmSync('./docs', { recursive: true, force: true }); +fs.rmSync('./dist', { recursive: true, force: true }); diff --git a/packages/Main/package.json b/packages/Main/package.json new file mode 100644 index 0000000000..11c6ba2f86 --- /dev/null +++ b/packages/Main/package.json @@ -0,0 +1,73 @@ +{ + "name": "itowns", + "version": "2.44.2", + "description": "A JS/WebGL framework for 3D geospatial data visualization", + "type": "module", + "main": "lib/Main.js", + "exports": { + ".": "./lib/Main.js", + "./widgets": "./lib/Utils/gui/Main.js" + }, + "scripts": { + "lint": "eslint \"src/**/*.{js,ts,tsx}\" \"test/**/*.js\"", + "transpile": "cross-env BABEL_DISABLE_CACHE=1 babel src --out-dir lib --extensions .js,.ts", + "test-unit": "npm run base-test-unit test/unit", + "base-test-unit": "cross-env BABEL_DISABLE_CACHE=1 mocha --file test/unit/bootstrap.js --import=../../config/babel-register/register.mjs", + "test-with-coverage": "c8 -n src -r html cross-env npm run test-unit", + "test-with-coverage_lcov": "c8 -n src --reporter=lcov cross-env npm run test-unit", + "watch": "npm run transpile -- --watch", + "postinstall": "cross-env NO_UPDATE_NOTIFIER=true node ./scripts/prepare.mjs && node ./scripts/replace.config.mjs", + "prepublishOnly": "npx copyfiles -u 1 \"../../examples/**/*\" ./examples/ && npx copyfiles -u 1 \"../../docs/**/*\" ./docs/ && npx copyfiles -u 1 \"../../dist/**/*\" ./dist/ ", + "postpublish": "node clean.cjs", + "publish-next": "npm version prerelease --preid next && npm run update-package", + "update-package": "npm remove @itowns/geographic && npm install @itowns/geographic@$npm_package_version --save" + }, + "c8": { + "exclude": [ + "**/test/**", + "**/lib/**", + "**/*ThreeExtended", + "**/*src/Utils/placeObjectOnGround.js", + "**/*src/Parser/deprecated/LegacyGLTFLoader.js" + ] + }, + "files": [ + "*.md", + "dist", + "lib", + "doc", + "examples" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/iTowns/itowns.git" + }, + "license": "(CECILL-B OR MIT)", + "bugs": { + "url": "https://github.com/iTowns/itowns/issues" + }, + "dependencies": { + "@itowns/geographic": "^2.44.2", + "@mapbox/vector-tile": "^2.0.3", + "@maplibre/maplibre-gl-style-spec": "^22.0.0", + "@tmcw/togeojson": "^5.8.1", + "@tweenjs/tween.js": "^25.0.0", + "3d-tiles-renderer": "^0.3.39", + "brotli-compress": "^1.3.3", + "copc": "^0.0.6", + "earcut": "^3.0.0", + "js-priority-queue": "^0.1.5", + "pbf": "^4.0.1", + "shpjs": "^6.1.0", + "threads": "^1.7.0" + }, + "peerDependencies": { + "proj4": "^2.12.1", + "three": "^0.168.0" + }, + "devDependencies": { + "chalk": "^5.3.0", + "copyfiles": "^2.4.1" + }, + "homepage": "https://itowns.github.io/" +} diff --git a/packages/Main/scripts/prepare.mjs b/packages/Main/scripts/prepare.mjs new file mode 100644 index 0000000000..c7aa40b35f --- /dev/null +++ b/packages/Main/scripts/prepare.mjs @@ -0,0 +1,16 @@ +import fs from 'node:fs'; +import copyfiles from 'copyfiles'; +import threeExamples from './threeExamples.mjs'; + +let path = './node_modules/three/examples/jsm/'; + +if (!fs.existsSync(path)) { + path = `../../${path}`; +} + +// Copy THREE Examples Files +const paths = threeExamples.filesExamples.map(f => f.replace('./', path)); + +paths.push(threeExamples.patchedPath); + +copyfiles(paths, { up: 6 }, () => {}); diff --git a/config/replace.config.mjs b/packages/Main/scripts/replace.config.mjs similarity index 100% rename from config/replace.config.mjs rename to packages/Main/scripts/replace.config.mjs diff --git a/config/threeExamples.mjs b/packages/Main/scripts/threeExamples.mjs similarity index 91% rename from config/threeExamples.mjs rename to packages/Main/scripts/threeExamples.mjs index 9c1107d8a7..c3163860ca 100644 --- a/config/threeExamples.mjs +++ b/packages/Main/scripts/threeExamples.mjs @@ -9,6 +9,6 @@ export default { './utils/WorkerPool.js', './capabilities/WebGL.js', './libs/ktx-parse.module.js', - './libs/zstddec.module.js' + './libs/zstddec.module.js', ], }; diff --git a/src/Controls/FirstPersonControls.js b/packages/Main/src/Controls/FirstPersonControls.js similarity index 100% rename from src/Controls/FirstPersonControls.js rename to packages/Main/src/Controls/FirstPersonControls.js diff --git a/src/Controls/FlyControls.js b/packages/Main/src/Controls/FlyControls.js similarity index 100% rename from src/Controls/FlyControls.js rename to packages/Main/src/Controls/FlyControls.js diff --git a/src/Controls/GlobeControls.js b/packages/Main/src/Controls/GlobeControls.js similarity index 99% rename from src/Controls/GlobeControls.js rename to packages/Main/src/Controls/GlobeControls.js index 68ae25518d..e3931cb6ee 100644 --- a/src/Controls/GlobeControls.js +++ b/packages/Main/src/Controls/GlobeControls.js @@ -1,7 +1,6 @@ import * as THREE from 'three'; import AnimationPlayer from 'Core/AnimationPlayer'; -import Coordinates from 'Core/Geographic/Coordinates'; -import { ellipsoidSizes } from 'Core/Math/Ellipsoid'; +import { Coordinates, ellipsoidSizes } from '@itowns/geographic'; import CameraUtils from 'Utils/CameraUtils'; import StateControl from 'Controls/StateControl'; import { VIEW_EVENTS } from 'Core/View'; diff --git a/src/Controls/PlanarControls.js b/packages/Main/src/Controls/PlanarControls.js similarity index 100% rename from src/Controls/PlanarControls.js rename to packages/Main/src/Controls/PlanarControls.js diff --git a/src/Controls/StateControl.js b/packages/Main/src/Controls/StateControl.js similarity index 100% rename from src/Controls/StateControl.js rename to packages/Main/src/Controls/StateControl.js diff --git a/src/Controls/StreetControls.js b/packages/Main/src/Controls/StreetControls.js similarity index 100% rename from src/Controls/StreetControls.js rename to packages/Main/src/Controls/StreetControls.js diff --git a/src/Converter/Feature2Mesh.js b/packages/Main/src/Converter/Feature2Mesh.js similarity index 99% rename from src/Converter/Feature2Mesh.js rename to packages/Main/src/Converter/Feature2Mesh.js index 85dca95ac1..9aeb0b75d0 100644 --- a/src/Converter/Feature2Mesh.js +++ b/packages/Main/src/Converter/Feature2Mesh.js @@ -3,9 +3,7 @@ import Earcut from 'earcut'; import { FEATURE_TYPES } from 'Core/Feature'; import ReferLayerProperties from 'Layer/ReferencingLayerProperties'; import { deprecatedFeature2MeshOptions } from 'Core/Deprecated/Undeprecator'; -import Extent from 'Core/Geographic/Extent'; -import OrientationUtils from 'Utils/OrientationUtils'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Extent, Coordinates, OrientationUtils } from '@itowns/geographic'; import Style, { StyleContext } from 'Core/Style'; const coord = new Coordinates('EPSG:4326', 0, 0, 0); diff --git a/src/Converter/Feature2Texture.js b/packages/Main/src/Converter/Feature2Texture.js similarity index 98% rename from src/Converter/Feature2Texture.js rename to packages/Main/src/Converter/Feature2Texture.js index 82c13a50eb..fb6161454f 100644 --- a/src/Converter/Feature2Texture.js +++ b/packages/Main/src/Converter/Feature2Texture.js @@ -1,7 +1,6 @@ import * as THREE from 'three'; import { FEATURE_TYPES } from 'Core/Feature'; -import Extent from 'Core/Geographic/Extent'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Extent, Coordinates } from '@itowns/geographic'; import Style, { StyleContext } from 'Core/Style'; const defaultStyle = new Style(); diff --git a/src/Converter/convertToTile.js b/packages/Main/src/Converter/convertToTile.js similarity index 100% rename from src/Converter/convertToTile.js rename to packages/Main/src/Converter/convertToTile.js diff --git a/src/Converter/textureConverter.js b/packages/Main/src/Converter/textureConverter.js similarity index 97% rename from src/Converter/textureConverter.js rename to packages/Main/src/Converter/textureConverter.js index 5455e9d96f..9c49f39577 100644 --- a/src/Converter/textureConverter.js +++ b/packages/Main/src/Converter/textureConverter.js @@ -1,6 +1,6 @@ import * as THREE from 'three'; import Feature2Texture from 'Converter/Feature2Texture'; -import Extent from 'Core/Geographic/Extent'; +import { Extent } from '@itowns/geographic'; const extentTexture = new Extent('EPSG:4326', [0, 0, 0, 0]); diff --git a/src/Core/3DTiles/C3DTBatchTable.js b/packages/Main/src/Core/3DTiles/C3DTBatchTable.js similarity index 100% rename from src/Core/3DTiles/C3DTBatchTable.js rename to packages/Main/src/Core/3DTiles/C3DTBatchTable.js diff --git a/src/Core/3DTiles/C3DTBatchTableHierarchyExtension.js b/packages/Main/src/Core/3DTiles/C3DTBatchTableHierarchyExtension.js similarity index 100% rename from src/Core/3DTiles/C3DTBatchTableHierarchyExtension.js rename to packages/Main/src/Core/3DTiles/C3DTBatchTableHierarchyExtension.js diff --git a/src/Core/3DTiles/C3DTBoundingVolume.js b/packages/Main/src/Core/3DTiles/C3DTBoundingVolume.js similarity index 98% rename from src/Core/3DTiles/C3DTBoundingVolume.js rename to packages/Main/src/Core/3DTiles/C3DTBoundingVolume.js index d4ad136de8..59a98f1b32 100644 --- a/src/Core/3DTiles/C3DTBoundingVolume.js +++ b/packages/Main/src/Core/3DTiles/C3DTBoundingVolume.js @@ -1,6 +1,5 @@ import * as THREE from 'three'; -import Ellipsoid from 'Core/Math/Ellipsoid'; -import Coordinates from '../Geographic/Coordinates'; +import { Ellipsoid, Coordinates } from '@itowns/geographic'; import { C3DTilesTypes, C3DTilesBoundingVolumeTypes } from './C3DTilesEnums'; const ellipsoid = new Ellipsoid(); diff --git a/src/Core/3DTiles/C3DTExtensions.js b/packages/Main/src/Core/3DTiles/C3DTExtensions.js similarity index 100% rename from src/Core/3DTiles/C3DTExtensions.js rename to packages/Main/src/Core/3DTiles/C3DTExtensions.js diff --git a/src/Core/3DTiles/C3DTFeature.js b/packages/Main/src/Core/3DTiles/C3DTFeature.js similarity index 100% rename from src/Core/3DTiles/C3DTFeature.js rename to packages/Main/src/Core/3DTiles/C3DTFeature.js diff --git a/src/Core/3DTiles/C3DTilesEnums.js b/packages/Main/src/Core/3DTiles/C3DTilesEnums.js similarity index 100% rename from src/Core/3DTiles/C3DTilesEnums.js rename to packages/Main/src/Core/3DTiles/C3DTilesEnums.js diff --git a/src/Core/3DTiles/C3DTileset.js b/packages/Main/src/Core/3DTiles/C3DTileset.js similarity index 100% rename from src/Core/3DTiles/C3DTileset.js rename to packages/Main/src/Core/3DTiles/C3DTileset.js diff --git a/src/Core/3DTiles/utils/BinaryPropertyAccessor.js b/packages/Main/src/Core/3DTiles/utils/BinaryPropertyAccessor.js similarity index 100% rename from src/Core/3DTiles/utils/BinaryPropertyAccessor.js rename to packages/Main/src/Core/3DTiles/utils/BinaryPropertyAccessor.js diff --git a/src/Core/AnimationPlayer.js b/packages/Main/src/Core/AnimationPlayer.js similarity index 100% rename from src/Core/AnimationPlayer.js rename to packages/Main/src/Core/AnimationPlayer.js diff --git a/src/Core/CopcNode.js b/packages/Main/src/Core/CopcNode.js similarity index 100% rename from src/Core/CopcNode.js rename to packages/Main/src/Core/CopcNode.js diff --git a/src/Core/Deprecated/Undeprecator.js b/packages/Main/src/Core/Deprecated/Undeprecator.js similarity index 100% rename from src/Core/Deprecated/Undeprecator.js rename to packages/Main/src/Core/Deprecated/Undeprecator.js diff --git a/src/Core/EntwinePointTileNode.js b/packages/Main/src/Core/EntwinePointTileNode.js similarity index 100% rename from src/Core/EntwinePointTileNode.js rename to packages/Main/src/Core/EntwinePointTileNode.js diff --git a/src/Core/Feature.js b/packages/Main/src/Core/Feature.js similarity index 99% rename from src/Core/Feature.js rename to packages/Main/src/Core/Feature.js index 018bb45c95..8c0e4bf310 100644 --- a/src/Core/Feature.js +++ b/packages/Main/src/Core/Feature.js @@ -1,6 +1,5 @@ import * as THREE from 'three'; -import Extent from 'Core/Geographic/Extent'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Extent, Coordinates } from '@itowns/geographic'; import Style from 'Core/Style'; function defaultExtent(crs) { diff --git a/src/Core/Geographic/GeoidGrid.js b/packages/Main/src/Core/Geographic/GeoidGrid.js similarity index 98% rename from src/Core/Geographic/GeoidGrid.js rename to packages/Main/src/Core/Geographic/GeoidGrid.js index 1d5d3cbfa7..a8621bba70 100644 --- a/src/Core/Geographic/GeoidGrid.js +++ b/packages/Main/src/Core/Geographic/GeoidGrid.js @@ -1,7 +1,5 @@ import * as THREE from 'three'; -import * as CRS from 'Core/Geographic/Crs'; -import Coordinates from 'Core/Geographic/Coordinates'; - +import { Coordinates, CRS } from '@itowns/geographic'; const coord = new Coordinates('EPSG:4326'); const indexes = new THREE.Vector2(); diff --git a/src/Core/Label.js b/packages/Main/src/Core/Label.js similarity index 99% rename from src/Core/Label.js rename to packages/Main/src/Core/Label.js index 019185443f..41fb696064 100644 --- a/src/Core/Label.js +++ b/packages/Main/src/Core/Label.js @@ -1,6 +1,6 @@ import * as THREE from 'three'; import DEMUtils from 'Utils/DEMUtils'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; const coord = new Coordinates('EPSG:4326'); let rect; diff --git a/src/Core/MainLoop.js b/packages/Main/src/Core/MainLoop.js similarity index 100% rename from src/Core/MainLoop.js rename to packages/Main/src/Core/MainLoop.js diff --git a/src/Core/Picking.js b/packages/Main/src/Core/Picking.js similarity index 99% rename from src/Core/Picking.js rename to packages/Main/src/Core/Picking.js index 117d31098f..8769046545 100644 --- a/src/Core/Picking.js +++ b/packages/Main/src/Core/Picking.js @@ -1,7 +1,7 @@ import * as THREE from 'three'; import RenderMode from 'Renderer/RenderMode'; import { unpack1K } from 'Renderer/LayeredMaterial'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; const depthRGBA = new THREE.Vector4(); // TileMesh picking support function diff --git a/src/Core/PointCloudNode.js b/packages/Main/src/Core/PointCloudNode.js similarity index 100% rename from src/Core/PointCloudNode.js rename to packages/Main/src/Core/PointCloudNode.js diff --git a/src/Core/Potree2Node.js b/packages/Main/src/Core/Potree2Node.js similarity index 100% rename from src/Core/Potree2Node.js rename to packages/Main/src/Core/Potree2Node.js diff --git a/src/Core/Potree2PointAttributes.js b/packages/Main/src/Core/Potree2PointAttributes.js similarity index 100% rename from src/Core/Potree2PointAttributes.js rename to packages/Main/src/Core/Potree2PointAttributes.js diff --git a/src/Core/PotreeNode.js b/packages/Main/src/Core/PotreeNode.js similarity index 100% rename from src/Core/PotreeNode.js rename to packages/Main/src/Core/PotreeNode.js diff --git a/src/Core/Prefab/Globe/Atmosphere.js b/packages/Main/src/Core/Prefab/Globe/Atmosphere.js similarity index 98% rename from src/Core/Prefab/Globe/Atmosphere.js rename to packages/Main/src/Core/Prefab/Globe/Atmosphere.js index 6da14081ee..30814eb411 100644 --- a/src/Core/Prefab/Globe/Atmosphere.js +++ b/packages/Main/src/Core/Prefab/Globe/Atmosphere.js @@ -1,8 +1,6 @@ import * as THREE from 'three'; import GeometryLayer from 'Layer/GeometryLayer'; -import Coordinates from 'Core/Geographic/Coordinates'; -import { ellipsoidSizes } from 'Core/Math/Ellipsoid'; -import CoordStars from 'Core/Geographic/CoordStars'; +import { Coordinates, ellipsoidSizes, CoordStars } from '@itowns/geographic'; import Sky from './SkyShader'; import skyFS from './Shaders/skyFS.glsl'; import skyVS from './Shaders/skyVS.glsl'; diff --git a/src/Core/Prefab/Globe/GlobeLayer.js b/packages/Main/src/Core/Prefab/Globe/GlobeLayer.js similarity index 99% rename from src/Core/Prefab/Globe/GlobeLayer.js rename to packages/Main/src/Core/Prefab/Globe/GlobeLayer.js index 3aa9f5a03f..54f2530c47 100644 --- a/src/Core/Prefab/Globe/GlobeLayer.js +++ b/packages/Main/src/Core/Prefab/Globe/GlobeLayer.js @@ -1,6 +1,6 @@ import * as THREE from 'three'; import TiledGeometryLayer from 'Layer/TiledGeometryLayer'; -import { ellipsoidSizes } from 'Core/Math/Ellipsoid'; +import { ellipsoidSizes } from '@itowns/geographic'; import { globalExtentTMS, schemeTiles } from 'Core/Tile/TileGrid'; import { GlobeTileBuilder } from 'Core/Prefab/Globe/GlobeTileBuilder'; diff --git a/src/Core/Prefab/Globe/GlobeTileBuilder.ts b/packages/Main/src/Core/Prefab/Globe/GlobeTileBuilder.ts similarity index 98% rename from src/Core/Prefab/Globe/GlobeTileBuilder.ts rename to packages/Main/src/Core/Prefab/Globe/GlobeTileBuilder.ts index 39bc384ae2..0ea311e678 100644 --- a/src/Core/Prefab/Globe/GlobeTileBuilder.ts +++ b/packages/Main/src/Core/Prefab/Globe/GlobeTileBuilder.ts @@ -1,6 +1,5 @@ import * as THREE from 'three'; -import Coordinates from 'Core/Geographic/Coordinates'; -import Extent from 'Core/Geographic/Extent'; +import { Coordinates, Extent } from '@itowns/geographic'; import { ShareableExtent, TileBuilder, diff --git a/src/Core/Prefab/Globe/Shaders/CloudsFS.glsl b/packages/Main/src/Core/Prefab/Globe/Shaders/CloudsFS.glsl similarity index 100% rename from src/Core/Prefab/Globe/Shaders/CloudsFS.glsl rename to packages/Main/src/Core/Prefab/Globe/Shaders/CloudsFS.glsl diff --git a/src/Core/Prefab/Globe/Shaders/CloudsVS.glsl b/packages/Main/src/Core/Prefab/Globe/Shaders/CloudsVS.glsl similarity index 100% rename from src/Core/Prefab/Globe/Shaders/CloudsVS.glsl rename to packages/Main/src/Core/Prefab/Globe/Shaders/CloudsVS.glsl diff --git a/src/Core/Prefab/Globe/Shaders/GlowFS.glsl b/packages/Main/src/Core/Prefab/Globe/Shaders/GlowFS.glsl similarity index 100% rename from src/Core/Prefab/Globe/Shaders/GlowFS.glsl rename to packages/Main/src/Core/Prefab/Globe/Shaders/GlowFS.glsl diff --git a/src/Core/Prefab/Globe/Shaders/GlowVS.glsl b/packages/Main/src/Core/Prefab/Globe/Shaders/GlowVS.glsl similarity index 100% rename from src/Core/Prefab/Globe/Shaders/GlowVS.glsl rename to packages/Main/src/Core/Prefab/Globe/Shaders/GlowVS.glsl diff --git a/src/Core/Prefab/Globe/Shaders/groundFS.glsl b/packages/Main/src/Core/Prefab/Globe/Shaders/groundFS.glsl similarity index 100% rename from src/Core/Prefab/Globe/Shaders/groundFS.glsl rename to packages/Main/src/Core/Prefab/Globe/Shaders/groundFS.glsl diff --git a/src/Core/Prefab/Globe/Shaders/groundVS.glsl b/packages/Main/src/Core/Prefab/Globe/Shaders/groundVS.glsl similarity index 100% rename from src/Core/Prefab/Globe/Shaders/groundVS.glsl rename to packages/Main/src/Core/Prefab/Globe/Shaders/groundVS.glsl diff --git a/src/Core/Prefab/Globe/Shaders/skyFS.glsl b/packages/Main/src/Core/Prefab/Globe/Shaders/skyFS.glsl similarity index 100% rename from src/Core/Prefab/Globe/Shaders/skyFS.glsl rename to packages/Main/src/Core/Prefab/Globe/Shaders/skyFS.glsl diff --git a/src/Core/Prefab/Globe/Shaders/skyVS.glsl b/packages/Main/src/Core/Prefab/Globe/Shaders/skyVS.glsl similarity index 100% rename from src/Core/Prefab/Globe/Shaders/skyVS.glsl rename to packages/Main/src/Core/Prefab/Globe/Shaders/skyVS.glsl diff --git a/src/Core/Prefab/Globe/SkyShader.js b/packages/Main/src/Core/Prefab/Globe/SkyShader.js similarity index 100% rename from src/Core/Prefab/Globe/SkyShader.js rename to packages/Main/src/Core/Prefab/Globe/SkyShader.js diff --git a/src/Core/Prefab/GlobeView.js b/packages/Main/src/Core/Prefab/GlobeView.js similarity index 98% rename from src/Core/Prefab/GlobeView.js rename to packages/Main/src/Core/Prefab/GlobeView.js index ce90a53661..7ed69e0787 100644 --- a/src/Core/Prefab/GlobeView.js +++ b/packages/Main/src/Core/Prefab/GlobeView.js @@ -2,14 +2,11 @@ import * as THREE from 'three'; import View, { VIEW_EVENTS } from 'Core/View'; import GlobeControls from 'Controls/GlobeControls'; -import Coordinates from 'Core/Geographic/Coordinates'; - +import { Coordinates, ellipsoidSizes } from '@itowns/geographic'; import GlobeLayer from 'Core/Prefab/Globe/GlobeLayer'; import Atmosphere from 'Core/Prefab/Globe/Atmosphere'; import CameraUtils from 'Utils/CameraUtils'; -import { ellipsoidSizes } from 'Core/Math/Ellipsoid'; - /** * Fires when the view is completely loaded. Controls and view's functions can be called then. * @event GlobeView#initialized diff --git a/src/Core/Prefab/Planar/PlanarLayer.js b/packages/Main/src/Core/Prefab/Planar/PlanarLayer.js similarity index 100% rename from src/Core/Prefab/Planar/PlanarLayer.js rename to packages/Main/src/Core/Prefab/Planar/PlanarLayer.js diff --git a/src/Core/Prefab/Planar/PlanarTileBuilder.ts b/packages/Main/src/Core/Prefab/Planar/PlanarTileBuilder.ts similarity index 96% rename from src/Core/Prefab/Planar/PlanarTileBuilder.ts rename to packages/Main/src/Core/Prefab/Planar/PlanarTileBuilder.ts index 30a18e7650..56f77875b2 100644 --- a/src/Core/Prefab/Planar/PlanarTileBuilder.ts +++ b/packages/Main/src/Core/Prefab/Planar/PlanarTileBuilder.ts @@ -1,6 +1,5 @@ import * as THREE from 'three'; -import Coordinates from 'Core/Geographic/Coordinates'; -import Extent from 'Core/Geographic/Extent'; +import { Coordinates, Extent } from '@itowns/geographic'; import { ShareableExtent, TileBuilder, diff --git a/src/Core/Prefab/PlanarView.js b/packages/Main/src/Core/Prefab/PlanarView.js similarity index 100% rename from src/Core/Prefab/PlanarView.js rename to packages/Main/src/Core/Prefab/PlanarView.js diff --git a/src/Core/Prefab/TileBuilder.ts b/packages/Main/src/Core/Prefab/TileBuilder.ts similarity index 98% rename from src/Core/Prefab/TileBuilder.ts rename to packages/Main/src/Core/Prefab/TileBuilder.ts index 7d1997767d..23ce266da0 100644 --- a/src/Core/Prefab/TileBuilder.ts +++ b/packages/Main/src/Core/Prefab/TileBuilder.ts @@ -3,8 +3,8 @@ import { TileGeometry } from 'Core/TileGeometry'; import Cache from 'Core/Scheduler/Cache'; import { computeBuffers } from 'Core/Prefab/computeBufferTileGeometry'; import OBB from 'Renderer/OBB'; -import type Extent from 'Core/Geographic/Extent'; -import Coordinates from 'Core/Geographic/Coordinates'; +import type { Extent } from '@itowns/geographic'; +import { Coordinates } from '@itowns/geographic'; const cacheBuffer = new Map diff --git a/src/Core/TileMesh.js b/packages/Main/src/Core/TileMesh.js similarity index 100% rename from src/Core/TileMesh.js rename to packages/Main/src/Core/TileMesh.js diff --git a/src/Core/View.js b/packages/Main/src/Core/View.js similarity index 99% rename from src/Core/View.js rename to packages/Main/src/Core/View.js index 72dff1f4ea..ab459331bf 100644 --- a/src/Core/View.js +++ b/packages/Main/src/Core/View.js @@ -1,5 +1,5 @@ import * as THREE from 'three'; -import * as CRS from 'Core/Geographic/Crs'; +import { CRS, Coordinates } from '@itowns/geographic'; import Camera from 'Renderer/Camera'; import initializeWebXR from 'Renderer/WebXR'; import MainLoop, { MAIN_LOOP_EVENTS, RENDERING_PAUSED } from 'Core/MainLoop'; @@ -7,7 +7,6 @@ import Capabilities from 'Core/System/Capabilities'; import { COLOR_LAYERS_ORDER_CHANGED } from 'Renderer/ColorLayersOrdering'; import c3DEngine from 'Renderer/c3DEngine'; import RenderMode from 'Renderer/RenderMode'; -import Coordinates from 'Core/Geographic/Coordinates'; import FeaturesUtils from 'Utils/FeaturesUtils'; import { getMaxColorSamplerUnitsCount } from 'Renderer/LayeredMaterial'; import Scheduler from 'Core/Scheduler/Scheduler'; diff --git a/src/Layer/C3DTilesLayer.js b/packages/Main/src/Layer/C3DTilesLayer.js similarity index 100% rename from src/Layer/C3DTilesLayer.js rename to packages/Main/src/Layer/C3DTilesLayer.js diff --git a/src/Layer/ColorLayer.js b/packages/Main/src/Layer/ColorLayer.js similarity index 100% rename from src/Layer/ColorLayer.js rename to packages/Main/src/Layer/ColorLayer.js diff --git a/src/Layer/CopcLayer.js b/packages/Main/src/Layer/CopcLayer.js similarity index 100% rename from src/Layer/CopcLayer.js rename to packages/Main/src/Layer/CopcLayer.js diff --git a/src/Layer/ElevationLayer.js b/packages/Main/src/Layer/ElevationLayer.js similarity index 100% rename from src/Layer/ElevationLayer.js rename to packages/Main/src/Layer/ElevationLayer.js diff --git a/src/Layer/EntwinePointTileLayer.js b/packages/Main/src/Layer/EntwinePointTileLayer.js similarity index 98% rename from src/Layer/EntwinePointTileLayer.js rename to packages/Main/src/Layer/EntwinePointTileLayer.js index 0a1add49a4..7fdf013037 100644 --- a/src/Layer/EntwinePointTileLayer.js +++ b/packages/Main/src/Layer/EntwinePointTileLayer.js @@ -1,7 +1,7 @@ import * as THREE from 'three'; import EntwinePointTileNode from 'Core/EntwinePointTileNode'; import PointCloudLayer from 'Layer/PointCloudLayer'; -import Extent from 'Core/Geographic/Extent'; +import { Extent } from '@itowns/geographic'; const bboxMesh = new THREE.Mesh(); const box3 = new THREE.Box3(); diff --git a/src/Layer/FeatureGeometryLayer.js b/packages/Main/src/Layer/FeatureGeometryLayer.js similarity index 100% rename from src/Layer/FeatureGeometryLayer.js rename to packages/Main/src/Layer/FeatureGeometryLayer.js diff --git a/src/Layer/GeoidLayer.js b/packages/Main/src/Layer/GeoidLayer.js similarity index 100% rename from src/Layer/GeoidLayer.js rename to packages/Main/src/Layer/GeoidLayer.js diff --git a/src/Layer/GeometryLayer.js b/packages/Main/src/Layer/GeometryLayer.js similarity index 100% rename from src/Layer/GeometryLayer.js rename to packages/Main/src/Layer/GeometryLayer.js diff --git a/src/Layer/InfoLayer.js b/packages/Main/src/Layer/InfoLayer.js similarity index 98% rename from src/Layer/InfoLayer.js rename to packages/Main/src/Layer/InfoLayer.js index d82677e744..a36bcbaf8d 100644 --- a/src/Layer/InfoLayer.js +++ b/packages/Main/src/Layer/InfoLayer.js @@ -1,4 +1,4 @@ -import Extent from 'Core/Geographic/Extent'; +import { Extent } from '@itowns/geographic'; export default class InfoLayer { constructor(layer) { diff --git a/src/Layer/LabelLayer.js b/packages/Main/src/Layer/LabelLayer.js similarity index 99% rename from src/Layer/LabelLayer.js rename to packages/Main/src/Layer/LabelLayer.js index ff2ffccc42..42fe7fcabf 100644 --- a/src/Layer/LabelLayer.js +++ b/packages/Main/src/Layer/LabelLayer.js @@ -2,8 +2,7 @@ import * as THREE from 'three'; import LayerUpdateState from 'Layer/LayerUpdateState'; import ObjectRemovalHelper from 'Process/ObjectRemovalHelper'; import GeometryLayer from 'Layer/GeometryLayer'; -import Coordinates from 'Core/Geographic/Coordinates'; -import Extent from 'Core/Geographic/Extent'; +import { Coordinates, Extent } from '@itowns/geographic'; import Label from 'Core/Label'; import { readExpression, StyleContext } from 'Core/Style'; import { ScreenGrid } from 'Renderer/Label2DRenderer'; diff --git a/src/Layer/Layer.js b/packages/Main/src/Layer/Layer.js similarity index 100% rename from src/Layer/Layer.js rename to packages/Main/src/Layer/Layer.js diff --git a/src/Layer/LayerUpdateState.js b/packages/Main/src/Layer/LayerUpdateState.js similarity index 100% rename from src/Layer/LayerUpdateState.js rename to packages/Main/src/Layer/LayerUpdateState.js diff --git a/src/Layer/LayerUpdateStrategy.js b/packages/Main/src/Layer/LayerUpdateStrategy.js similarity index 100% rename from src/Layer/LayerUpdateStrategy.js rename to packages/Main/src/Layer/LayerUpdateStrategy.js diff --git a/src/Layer/OGC3DTilesLayer.js b/packages/Main/src/Layer/OGC3DTilesLayer.js similarity index 100% rename from src/Layer/OGC3DTilesLayer.js rename to packages/Main/src/Layer/OGC3DTilesLayer.js diff --git a/src/Layer/OrientedImageLayer.js b/packages/Main/src/Layer/OrientedImageLayer.js similarity index 98% rename from src/Layer/OrientedImageLayer.js rename to packages/Main/src/Layer/OrientedImageLayer.js index 1327886d68..5239512057 100644 --- a/src/Layer/OrientedImageLayer.js +++ b/packages/Main/src/Layer/OrientedImageLayer.js @@ -3,8 +3,7 @@ import GeometryLayer from 'Layer/GeometryLayer'; import OrientedImageMaterial from 'Renderer/OrientedImageMaterial'; import GeoJsonParser from 'Parser/GeoJsonParser'; import CameraCalibrationParser from 'Parser/CameraCalibrationParser'; -import Coordinates from 'Core/Geographic/Coordinates'; -import OrientationUtils from 'Utils/OrientationUtils'; +import { Coordinates, OrientationUtils } from '@itowns/geographic'; const coord = new Coordinates('EPSG:4978', 0, 0, 0); const commandCancellation = cmd => cmd.requester.id !== cmd.layer.currentPano.id; diff --git a/src/Layer/PointCloudLayer.js b/packages/Main/src/Layer/PointCloudLayer.js similarity index 100% rename from src/Layer/PointCloudLayer.js rename to packages/Main/src/Layer/PointCloudLayer.js diff --git a/src/Layer/Potree2Layer.js b/packages/Main/src/Layer/Potree2Layer.js similarity index 99% rename from src/Layer/Potree2Layer.js rename to packages/Main/src/Layer/Potree2Layer.js index df8e7501d0..9d6302156b 100644 --- a/src/Layer/Potree2Layer.js +++ b/packages/Main/src/Layer/Potree2Layer.js @@ -36,7 +36,7 @@ of the authors and should not be interpreted as representing official policies, import * as THREE from 'three'; import PointCloudLayer from 'Layer/PointCloudLayer'; import Potree2Node from 'Core/Potree2Node'; -import Extent from 'Core/Geographic/Extent'; +import { Extent } from '@itowns/geographic'; import { PointAttribute, Potree2PointAttributes, PointAttributeTypes } from 'Core/Potree2PointAttributes'; diff --git a/src/Layer/PotreeLayer.js b/packages/Main/src/Layer/PotreeLayer.js similarity index 98% rename from src/Layer/PotreeLayer.js rename to packages/Main/src/Layer/PotreeLayer.js index 2940272602..de00920673 100644 --- a/src/Layer/PotreeLayer.js +++ b/packages/Main/src/Layer/PotreeLayer.js @@ -1,7 +1,7 @@ import * as THREE from 'three'; import PointCloudLayer from 'Layer/PointCloudLayer'; import PotreeNode from 'Core/PotreeNode'; -import Extent from 'Core/Geographic/Extent'; +import { Extent } from '@itowns/geographic'; const bboxMesh = new THREE.Mesh(); const box3 = new THREE.Box3(); diff --git a/src/Layer/RasterLayer.js b/packages/Main/src/Layer/RasterLayer.js similarity index 100% rename from src/Layer/RasterLayer.js rename to packages/Main/src/Layer/RasterLayer.js diff --git a/src/Layer/ReferencingLayerProperties.js b/packages/Main/src/Layer/ReferencingLayerProperties.js similarity index 100% rename from src/Layer/ReferencingLayerProperties.js rename to packages/Main/src/Layer/ReferencingLayerProperties.js diff --git a/src/Layer/TiledGeometryLayer.js b/packages/Main/src/Layer/TiledGeometryLayer.js similarity index 100% rename from src/Layer/TiledGeometryLayer.js rename to packages/Main/src/Layer/TiledGeometryLayer.js diff --git a/src/Loader/LASLoader.js b/packages/Main/src/Loader/LASLoader.js similarity index 100% rename from src/Loader/LASLoader.js rename to packages/Main/src/Loader/LASLoader.js diff --git a/src/Loader/Potree2BrotliLoader.js b/packages/Main/src/Loader/Potree2BrotliLoader.js similarity index 100% rename from src/Loader/Potree2BrotliLoader.js rename to packages/Main/src/Loader/Potree2BrotliLoader.js diff --git a/src/Loader/Potree2Loader.js b/packages/Main/src/Loader/Potree2Loader.js similarity index 100% rename from src/Loader/Potree2Loader.js rename to packages/Main/src/Loader/Potree2Loader.js diff --git a/src/Main.js b/packages/Main/src/Main.js similarity index 95% rename from src/Main.js rename to packages/Main/src/Main.js index 85b0f35709..2209b5a365 100644 --- a/src/Main.js +++ b/packages/Main/src/Main.js @@ -1,15 +1,13 @@ const conf = { version: '2.44.2', }; + export const REVISION = conf.version; // Geographic tools -export { default as Extent } from 'Core/Geographic/Extent'; -export { default as Coordinates } from 'Core/Geographic/Coordinates'; +export { Coordinates, Extent, CRS, Ellipsoid, ellipsoidSizes, OrientationUtils } from '@itowns/geographic'; export { default as GeoidGrid } from 'Core/Geographic/GeoidGrid'; -export * as CRS from 'Core/Geographic/Crs'; -export { default as Ellipsoid, ellipsoidSizes } from 'Core/Math/Ellipsoid'; export { default as GlobeView, GLOBE_VIEW_EVENTS } from 'Core/Prefab/GlobeView'; export { default as PlanarView } from 'Core/Prefab/PlanarView'; export { default as Fetcher } from 'Provider/Fetcher'; @@ -17,6 +15,7 @@ export { MAIN_LOOP_EVENTS } from 'Core/MainLoop'; export { default as View } from 'Core/View'; export { VIEW_EVENTS } from 'Core/View'; export { default as FeatureProcessing } from 'Process/FeatureProcessing'; +export { default as ObjectRemovalHelper } from 'Process/ObjectRemovalHelper'; export { updateLayeredMaterialNodeImagery, updateLayeredMaterialNodeElevation } from 'Process/LayeredMaterialNodeProcessing'; export { default as OrientedImageCamera } from 'Renderer/OrientedImageCamera'; export { default as PointsMaterial, PNTS_MODE, PNTS_SHAPE, PNTS_SIZE_MODE, ClassificationScheme } from 'Renderer/PointsMaterial'; @@ -31,11 +30,11 @@ export { default as Feature2Mesh } from 'Converter/Feature2Mesh'; export { default as FeaturesUtils } from 'Utils/FeaturesUtils'; export { default as DEMUtils } from 'Utils/DEMUtils'; export { default as CameraUtils } from 'Utils/CameraUtils'; -export { default as OrientationUtils } from 'Utils/OrientationUtils'; export { default as ShaderChunk } from 'Renderer/Shader/ShaderChunk'; export { getMaxColorSamplerUnitsCount, colorLayerEffects } from 'Renderer/LayeredMaterial'; export { default as Capabilities } from 'Core/System/Capabilities'; export { CAMERA_TYPE } from 'Renderer/Camera'; +export { default as OBB } from 'Renderer/OBB'; // Internal itowns format export { default as Feature, FeatureCollection, FeatureGeometry, FEATURE_TYPES } from 'Core/Feature'; diff --git a/src/MainBundle.js b/packages/Main/src/MainBundle.js similarity index 79% rename from src/MainBundle.js rename to packages/Main/src/MainBundle.js index e81f70997a..da0369673a 100644 --- a/src/MainBundle.js +++ b/packages/Main/src/MainBundle.js @@ -3,5 +3,5 @@ import * as THREE from 'three'; export { THREE }; export { default as proj4 } from 'proj4'; -export * from 'Main.js'; +export * from './Main'; diff --git a/src/Parser/B3dmParser.js b/packages/Main/src/Parser/B3dmParser.js similarity index 100% rename from src/Parser/B3dmParser.js rename to packages/Main/src/Parser/B3dmParser.js diff --git a/src/Parser/CameraCalibrationParser.js b/packages/Main/src/Parser/CameraCalibrationParser.js similarity index 100% rename from src/Parser/CameraCalibrationParser.js rename to packages/Main/src/Parser/CameraCalibrationParser.js diff --git a/src/Parser/GDFParser.js b/packages/Main/src/Parser/GDFParser.js similarity index 98% rename from src/Parser/GDFParser.js rename to packages/Main/src/Parser/GDFParser.js index 42214ce316..22fbacebb6 100644 --- a/src/Parser/GDFParser.js +++ b/packages/Main/src/Parser/GDFParser.js @@ -1,6 +1,6 @@ import * as THREE from 'three'; +import { Extent } from '@itowns/geographic'; import GeoidGrid from 'Core/Geographic/GeoidGrid'; -import Extent from 'Core/Geographic/Extent'; import { BYTES_PER_DOUBLE } from 'Parser/GTXParser'; diff --git a/src/Parser/GTXParser.js b/packages/Main/src/Parser/GTXParser.js similarity index 98% rename from src/Parser/GTXParser.js rename to packages/Main/src/Parser/GTXParser.js index 5fbbe0c40b..a061c9e076 100644 --- a/src/Parser/GTXParser.js +++ b/packages/Main/src/Parser/GTXParser.js @@ -1,7 +1,6 @@ import * as THREE from 'three'; +import { Extent } from '@itowns/geographic'; import GeoidGrid from 'Core/Geographic/GeoidGrid'; -import Extent from 'Core/Geographic/Extent'; - export const BYTES_PER_DOUBLE = 8; export const BYTES_PER_FLOAT = 4; diff --git a/src/Parser/GeoJsonParser.js b/packages/Main/src/Parser/GeoJsonParser.js similarity index 99% rename from src/Parser/GeoJsonParser.js rename to packages/Main/src/Parser/GeoJsonParser.js index 4049736064..4f881d229e 100644 --- a/src/Parser/GeoJsonParser.js +++ b/packages/Main/src/Parser/GeoJsonParser.js @@ -1,4 +1,4 @@ -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; import { FeatureCollection, FEATURE_TYPES } from 'Core/Feature'; import { deprecatedParsingOptionsToNewOne } from 'Core/Deprecated/Undeprecator'; diff --git a/src/Parser/GpxParser.js b/packages/Main/src/Parser/GpxParser.js similarity index 100% rename from src/Parser/GpxParser.js rename to packages/Main/src/Parser/GpxParser.js diff --git a/src/Parser/ISGParser.js b/packages/Main/src/Parser/ISGParser.js similarity index 98% rename from src/Parser/ISGParser.js rename to packages/Main/src/Parser/ISGParser.js index 6c9d241575..3a18c857c7 100644 --- a/src/Parser/ISGParser.js +++ b/packages/Main/src/Parser/ISGParser.js @@ -1,6 +1,6 @@ import * as THREE from 'three'; +import { Extent } from '@itowns/geographic'; import GeoidGrid from 'Core/Geographic/GeoidGrid'; -import Extent from 'Core/Geographic/Extent'; import { getHeaderAttribute } from 'Parser/GDFParser'; import { BYTES_PER_DOUBLE } from 'Parser/GTXParser'; diff --git a/src/Parser/KMLParser.js b/packages/Main/src/Parser/KMLParser.js similarity index 100% rename from src/Parser/KMLParser.js rename to packages/Main/src/Parser/KMLParser.js diff --git a/src/Parser/LASParser.js b/packages/Main/src/Parser/LASParser.js similarity index 100% rename from src/Parser/LASParser.js rename to packages/Main/src/Parser/LASParser.js diff --git a/src/Parser/MapBoxUrlParser.js b/packages/Main/src/Parser/MapBoxUrlParser.js similarity index 100% rename from src/Parser/MapBoxUrlParser.js rename to packages/Main/src/Parser/MapBoxUrlParser.js diff --git a/src/Parser/PntsParser.js b/packages/Main/src/Parser/PntsParser.js similarity index 100% rename from src/Parser/PntsParser.js rename to packages/Main/src/Parser/PntsParser.js diff --git a/src/Parser/Potree2BinParser.js b/packages/Main/src/Parser/Potree2BinParser.js similarity index 100% rename from src/Parser/Potree2BinParser.js rename to packages/Main/src/Parser/Potree2BinParser.js diff --git a/src/Parser/PotreeBinParser.js b/packages/Main/src/Parser/PotreeBinParser.js similarity index 100% rename from src/Parser/PotreeBinParser.js rename to packages/Main/src/Parser/PotreeBinParser.js diff --git a/src/Parser/PotreeCinParser.js b/packages/Main/src/Parser/PotreeCinParser.js similarity index 100% rename from src/Parser/PotreeCinParser.js rename to packages/Main/src/Parser/PotreeCinParser.js diff --git a/src/Parser/ShapefileParser.js b/packages/Main/src/Parser/ShapefileParser.js similarity index 100% rename from src/Parser/ShapefileParser.js rename to packages/Main/src/Parser/ShapefileParser.js diff --git a/src/Parser/VectorTileParser.js b/packages/Main/src/Parser/VectorTileParser.js similarity index 99% rename from src/Parser/VectorTileParser.js rename to packages/Main/src/Parser/VectorTileParser.js index 021b41035d..1f2aae137a 100644 --- a/src/Parser/VectorTileParser.js +++ b/packages/Main/src/Parser/VectorTileParser.js @@ -1,10 +1,10 @@ import { Vector2, Vector3 } from 'three'; import Protobuf from 'pbf'; import { VectorTile } from '@mapbox/vector-tile'; -import { globalExtentTMS } from 'Core/Tile/TileGrid'; import { FeatureCollection, FEATURE_TYPES } from 'Core/Feature'; +import { globalExtentTMS } from 'Core/Tile/TileGrid'; import { deprecatedParsingOptionsToNewOne } from 'Core/Deprecated/Undeprecator'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; const worldDimension3857 = globalExtentTMS.get('EPSG:3857').planarDimensions(); const globalExtent = new Vector3(worldDimension3857.x, worldDimension3857.y, 1); diff --git a/src/Parser/XbilParser.js b/packages/Main/src/Parser/XbilParser.js similarity index 100% rename from src/Parser/XbilParser.js rename to packages/Main/src/Parser/XbilParser.js diff --git a/src/Parser/deprecated/LegacyGLTFLoader.js b/packages/Main/src/Parser/deprecated/LegacyGLTFLoader.js similarity index 100% rename from src/Parser/deprecated/LegacyGLTFLoader.js rename to packages/Main/src/Parser/deprecated/LegacyGLTFLoader.js diff --git a/src/Parser/iGLTFLoader.js b/packages/Main/src/Parser/iGLTFLoader.js similarity index 100% rename from src/Parser/iGLTFLoader.js rename to packages/Main/src/Parser/iGLTFLoader.js diff --git a/src/Process/3dTilesProcessing.js b/packages/Main/src/Process/3dTilesProcessing.js similarity index 100% rename from src/Process/3dTilesProcessing.js rename to packages/Main/src/Process/3dTilesProcessing.js diff --git a/src/Process/FeatureProcessing.js b/packages/Main/src/Process/FeatureProcessing.js similarity index 98% rename from src/Process/FeatureProcessing.js rename to packages/Main/src/Process/FeatureProcessing.js index 29d1c9efcb..1a49308fa9 100644 --- a/src/Process/FeatureProcessing.js +++ b/packages/Main/src/Process/FeatureProcessing.js @@ -1,7 +1,7 @@ import LayerUpdateState from 'Layer/LayerUpdateState'; import ObjectRemovalHelper from 'Process/ObjectRemovalHelper'; import handlingError from 'Process/handlerNodeError'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; import { geoidLayerIsVisible } from 'Layer/GeoidLayer'; const coord = new Coordinates('EPSG:4326', 0, 0, 0); diff --git a/src/Process/LayeredMaterialNodeProcessing.js b/packages/Main/src/Process/LayeredMaterialNodeProcessing.js similarity index 100% rename from src/Process/LayeredMaterialNodeProcessing.js rename to packages/Main/src/Process/LayeredMaterialNodeProcessing.js diff --git a/src/Process/ObjectRemovalHelper.js b/packages/Main/src/Process/ObjectRemovalHelper.js similarity index 100% rename from src/Process/ObjectRemovalHelper.js rename to packages/Main/src/Process/ObjectRemovalHelper.js diff --git a/src/Process/handlerNodeError.js b/packages/Main/src/Process/handlerNodeError.js similarity index 100% rename from src/Process/handlerNodeError.js rename to packages/Main/src/Process/handlerNodeError.js diff --git a/src/Provider/3dTilesProvider.js b/packages/Main/src/Provider/3dTilesProvider.js similarity index 100% rename from src/Provider/3dTilesProvider.js rename to packages/Main/src/Provider/3dTilesProvider.js diff --git a/src/Provider/DataSourceProvider.js b/packages/Main/src/Provider/DataSourceProvider.js similarity index 100% rename from src/Provider/DataSourceProvider.js rename to packages/Main/src/Provider/DataSourceProvider.js diff --git a/src/Provider/Fetcher.js b/packages/Main/src/Provider/Fetcher.js similarity index 100% rename from src/Provider/Fetcher.js rename to packages/Main/src/Provider/Fetcher.js diff --git a/src/Provider/PointCloudProvider.js b/packages/Main/src/Provider/PointCloudProvider.js similarity index 97% rename from src/Provider/PointCloudProvider.js rename to packages/Main/src/Provider/PointCloudProvider.js index 57e24bcbf5..d36d3fd5c0 100644 --- a/src/Provider/PointCloudProvider.js +++ b/packages/Main/src/Provider/PointCloudProvider.js @@ -1,5 +1,5 @@ import * as THREE from 'three'; -import Extent from 'Core/Geographic/Extent'; +import { Extent } from '@itowns/geographic'; let nextuuid = 1; function addPickingAttribute(points) { diff --git a/src/Provider/TileProvider.js b/packages/Main/src/Provider/TileProvider.js similarity index 100% rename from src/Provider/TileProvider.js rename to packages/Main/src/Provider/TileProvider.js diff --git a/src/Provider/URLBuilder.js b/packages/Main/src/Provider/URLBuilder.js similarity index 100% rename from src/Provider/URLBuilder.js rename to packages/Main/src/Provider/URLBuilder.js diff --git a/src/Renderer/Camera.js b/packages/Main/src/Renderer/Camera.js similarity index 99% rename from src/Renderer/Camera.js rename to packages/Main/src/Renderer/Camera.js index 99a29b9ee4..a9410fa6ad 100644 --- a/src/Renderer/Camera.js +++ b/packages/Main/src/Renderer/Camera.js @@ -1,5 +1,5 @@ import * as THREE from 'three'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; import DEMUtils from 'Utils/DEMUtils'; /** diff --git a/src/Renderer/Color.js b/packages/Main/src/Renderer/Color.js similarity index 100% rename from src/Renderer/Color.js rename to packages/Main/src/Renderer/Color.js diff --git a/src/Renderer/ColorLayersOrdering.js b/packages/Main/src/Renderer/ColorLayersOrdering.js similarity index 100% rename from src/Renderer/ColorLayersOrdering.js rename to packages/Main/src/Renderer/ColorLayersOrdering.js diff --git a/src/Renderer/CommonMaterial.js b/packages/Main/src/Renderer/CommonMaterial.js similarity index 100% rename from src/Renderer/CommonMaterial.js rename to packages/Main/src/Renderer/CommonMaterial.js diff --git a/src/Renderer/Label2DRenderer.js b/packages/Main/src/Renderer/Label2DRenderer.js similarity index 100% rename from src/Renderer/Label2DRenderer.js rename to packages/Main/src/Renderer/Label2DRenderer.js diff --git a/src/Renderer/LayeredMaterial.js b/packages/Main/src/Renderer/LayeredMaterial.js similarity index 98% rename from src/Renderer/LayeredMaterial.js rename to packages/Main/src/Renderer/LayeredMaterial.js index bf1d50c2bc..0e988591a1 100644 --- a/src/Renderer/LayeredMaterial.js +++ b/packages/Main/src/Renderer/LayeredMaterial.js @@ -1,10 +1,10 @@ import * as THREE from 'three'; -import TileVS from 'Renderer/Shader/TileVS.glsl'; -import TileFS from 'Renderer/Shader/TileFS.glsl'; import ShaderUtils from 'Renderer/Shader/ShaderUtils'; import Capabilities from 'Core/System/Capabilities'; import RenderMode from 'Renderer/RenderMode'; import CommonMaterial from 'Renderer/CommonMaterial'; +import TileVS from '../Renderer/Shader/TileVS.glsl'; +import TileFS from '../Renderer/Shader/TileFS.glsl'; const identityOffsetScale = new THREE.Vector4(0.0, 0.0, 1.0, 1.0); const defaultTex = new THREE.Texture(); diff --git a/src/Renderer/OBB.js b/packages/Main/src/Renderer/OBB.js similarity index 98% rename from src/Renderer/OBB.js rename to packages/Main/src/Renderer/OBB.js index 5b763b6b00..b42058dac6 100644 --- a/src/Renderer/OBB.js +++ b/packages/Main/src/Renderer/OBB.js @@ -1,8 +1,7 @@ import * as THREE from 'three'; -import * as CRS from 'Core/Geographic/Crs'; import { TileGeometry } from 'Core/TileGeometry'; import { GlobeTileBuilder } from 'Core/Prefab/Globe/GlobeTileBuilder'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { CRS, Coordinates } from '@itowns/geographic'; // get oriented bounding box of tile const builder = new GlobeTileBuilder({ uvCount: 1 }); diff --git a/src/Renderer/OrientedImageCamera.js b/packages/Main/src/Renderer/OrientedImageCamera.js similarity index 100% rename from src/Renderer/OrientedImageCamera.js rename to packages/Main/src/Renderer/OrientedImageCamera.js diff --git a/src/Renderer/OrientedImageMaterial.js b/packages/Main/src/Renderer/OrientedImageMaterial.js similarity index 98% rename from src/Renderer/OrientedImageMaterial.js rename to packages/Main/src/Renderer/OrientedImageMaterial.js index c22545acff..2ce6087b52 100644 --- a/src/Renderer/OrientedImageMaterial.js +++ b/packages/Main/src/Renderer/OrientedImageMaterial.js @@ -1,8 +1,8 @@ import * as THREE from 'three'; import Capabilities from 'Core/System/Capabilities'; -import textureVS from 'Renderer/Shader/ProjectiveTextureVS.glsl'; -import textureFS from 'Renderer/Shader/ProjectiveTextureFS.glsl'; import ShaderUtils from 'Renderer/Shader/ShaderUtils'; +import textureVS from './Shader/ProjectiveTextureVS.glsl'; +import textureFS from './Shader/ProjectiveTextureFS.glsl'; const ndcToTextureMatrix = new THREE.Matrix4( 1, 0, 0, 1, diff --git a/src/Renderer/PointsMaterial.js b/packages/Main/src/Renderer/PointsMaterial.js similarity index 100% rename from src/Renderer/PointsMaterial.js rename to packages/Main/src/Renderer/PointsMaterial.js diff --git a/src/Renderer/RasterTile.js b/packages/Main/src/Renderer/RasterTile.js similarity index 100% rename from src/Renderer/RasterTile.js rename to packages/Main/src/Renderer/RasterTile.js diff --git a/src/Renderer/RenderMode.js b/packages/Main/src/Renderer/RenderMode.js similarity index 100% rename from src/Renderer/RenderMode.js rename to packages/Main/src/Renderer/RenderMode.js diff --git a/src/Renderer/Shader/Chunk/color_layers_pars_fragment.glsl b/packages/Main/src/Renderer/Shader/Chunk/color_layers_pars_fragment.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/color_layers_pars_fragment.glsl rename to packages/Main/src/Renderer/Shader/Chunk/color_layers_pars_fragment.glsl diff --git a/src/Renderer/Shader/Chunk/elevation_pars_vertex.glsl b/packages/Main/src/Renderer/Shader/Chunk/elevation_pars_vertex.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/elevation_pars_vertex.glsl rename to packages/Main/src/Renderer/Shader/Chunk/elevation_pars_vertex.glsl diff --git a/src/Renderer/Shader/Chunk/elevation_vertex.glsl b/packages/Main/src/Renderer/Shader/Chunk/elevation_vertex.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/elevation_vertex.glsl rename to packages/Main/src/Renderer/Shader/Chunk/elevation_vertex.glsl diff --git a/src/Renderer/Shader/Chunk/fog_fragment.glsl b/packages/Main/src/Renderer/Shader/Chunk/fog_fragment.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/fog_fragment.glsl rename to packages/Main/src/Renderer/Shader/Chunk/fog_fragment.glsl diff --git a/src/Renderer/Shader/Chunk/fog_pars_fragment.glsl b/packages/Main/src/Renderer/Shader/Chunk/fog_pars_fragment.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/fog_pars_fragment.glsl rename to packages/Main/src/Renderer/Shader/Chunk/fog_pars_fragment.glsl diff --git a/src/Renderer/Shader/Chunk/geoid_vertex.glsl b/packages/Main/src/Renderer/Shader/Chunk/geoid_vertex.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/geoid_vertex.glsl rename to packages/Main/src/Renderer/Shader/Chunk/geoid_vertex.glsl diff --git a/src/Renderer/Shader/Chunk/lighting_fragment.glsl b/packages/Main/src/Renderer/Shader/Chunk/lighting_fragment.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/lighting_fragment.glsl rename to packages/Main/src/Renderer/Shader/Chunk/lighting_fragment.glsl diff --git a/src/Renderer/Shader/Chunk/lighting_pars_fragment.glsl b/packages/Main/src/Renderer/Shader/Chunk/lighting_pars_fragment.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/lighting_pars_fragment.glsl rename to packages/Main/src/Renderer/Shader/Chunk/lighting_pars_fragment.glsl diff --git a/src/Renderer/Shader/Chunk/mode_depth_fragment.glsl b/packages/Main/src/Renderer/Shader/Chunk/mode_depth_fragment.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/mode_depth_fragment.glsl rename to packages/Main/src/Renderer/Shader/Chunk/mode_depth_fragment.glsl diff --git a/src/Renderer/Shader/Chunk/mode_id_fragment.glsl b/packages/Main/src/Renderer/Shader/Chunk/mode_id_fragment.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/mode_id_fragment.glsl rename to packages/Main/src/Renderer/Shader/Chunk/mode_id_fragment.glsl diff --git a/src/Renderer/Shader/Chunk/mode_pars_fragment.glsl b/packages/Main/src/Renderer/Shader/Chunk/mode_pars_fragment.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/mode_pars_fragment.glsl rename to packages/Main/src/Renderer/Shader/Chunk/mode_pars_fragment.glsl diff --git a/src/Renderer/Shader/Chunk/overlay_fragment.glsl b/packages/Main/src/Renderer/Shader/Chunk/overlay_fragment.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/overlay_fragment.glsl rename to packages/Main/src/Renderer/Shader/Chunk/overlay_fragment.glsl diff --git a/src/Renderer/Shader/Chunk/overlay_pars_fragment.glsl b/packages/Main/src/Renderer/Shader/Chunk/overlay_pars_fragment.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/overlay_pars_fragment.glsl rename to packages/Main/src/Renderer/Shader/Chunk/overlay_pars_fragment.glsl diff --git a/src/Renderer/Shader/Chunk/pitUV.glsl b/packages/Main/src/Renderer/Shader/Chunk/pitUV.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/pitUV.glsl rename to packages/Main/src/Renderer/Shader/Chunk/pitUV.glsl diff --git a/src/Renderer/Shader/Chunk/precision_qualifier.glsl b/packages/Main/src/Renderer/Shader/Chunk/precision_qualifier.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/precision_qualifier.glsl rename to packages/Main/src/Renderer/Shader/Chunk/precision_qualifier.glsl diff --git a/src/Renderer/Shader/Chunk/projective_texturing_pars_fragment.glsl b/packages/Main/src/Renderer/Shader/Chunk/projective_texturing_pars_fragment.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/projective_texturing_pars_fragment.glsl rename to packages/Main/src/Renderer/Shader/Chunk/projective_texturing_pars_fragment.glsl diff --git a/src/Renderer/Shader/Chunk/projective_texturing_pars_vertex.glsl b/packages/Main/src/Renderer/Shader/Chunk/projective_texturing_pars_vertex.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/projective_texturing_pars_vertex.glsl rename to packages/Main/src/Renderer/Shader/Chunk/projective_texturing_pars_vertex.glsl diff --git a/src/Renderer/Shader/Chunk/projective_texturing_vertex.glsl b/packages/Main/src/Renderer/Shader/Chunk/projective_texturing_vertex.glsl similarity index 100% rename from src/Renderer/Shader/Chunk/projective_texturing_vertex.glsl rename to packages/Main/src/Renderer/Shader/Chunk/projective_texturing_vertex.glsl diff --git a/src/Renderer/Shader/PointsFS.glsl b/packages/Main/src/Renderer/Shader/PointsFS.glsl similarity index 100% rename from src/Renderer/Shader/PointsFS.glsl rename to packages/Main/src/Renderer/Shader/PointsFS.glsl diff --git a/src/Renderer/Shader/PointsVS.glsl b/packages/Main/src/Renderer/Shader/PointsVS.glsl similarity index 100% rename from src/Renderer/Shader/PointsVS.glsl rename to packages/Main/src/Renderer/Shader/PointsVS.glsl diff --git a/src/Renderer/Shader/ProjectiveTextureFS.glsl b/packages/Main/src/Renderer/Shader/ProjectiveTextureFS.glsl similarity index 100% rename from src/Renderer/Shader/ProjectiveTextureFS.glsl rename to packages/Main/src/Renderer/Shader/ProjectiveTextureFS.glsl diff --git a/src/Renderer/Shader/ProjectiveTextureVS.glsl b/packages/Main/src/Renderer/Shader/ProjectiveTextureVS.glsl similarity index 100% rename from src/Renderer/Shader/ProjectiveTextureVS.glsl rename to packages/Main/src/Renderer/Shader/ProjectiveTextureVS.glsl diff --git a/src/Renderer/Shader/SampleTestFS.glsl b/packages/Main/src/Renderer/Shader/SampleTestFS.glsl similarity index 100% rename from src/Renderer/Shader/SampleTestFS.glsl rename to packages/Main/src/Renderer/Shader/SampleTestFS.glsl diff --git a/src/Renderer/Shader/SampleTestVS.glsl b/packages/Main/src/Renderer/Shader/SampleTestVS.glsl similarity index 100% rename from src/Renderer/Shader/SampleTestVS.glsl rename to packages/Main/src/Renderer/Shader/SampleTestVS.glsl diff --git a/src/Renderer/Shader/ShaderChunk.js b/packages/Main/src/Renderer/Shader/ShaderChunk.js similarity index 100% rename from src/Renderer/Shader/ShaderChunk.js rename to packages/Main/src/Renderer/Shader/ShaderChunk.js diff --git a/src/Renderer/Shader/ShaderUtils.js b/packages/Main/src/Renderer/Shader/ShaderUtils.js similarity index 100% rename from src/Renderer/Shader/ShaderUtils.js rename to packages/Main/src/Renderer/Shader/ShaderUtils.js diff --git a/src/Renderer/Shader/TileFS.glsl b/packages/Main/src/Renderer/Shader/TileFS.glsl similarity index 100% rename from src/Renderer/Shader/TileFS.glsl rename to packages/Main/src/Renderer/Shader/TileFS.glsl diff --git a/src/Renderer/Shader/TileVS.glsl b/packages/Main/src/Renderer/Shader/TileVS.glsl similarity index 100% rename from src/Renderer/Shader/TileVS.glsl rename to packages/Main/src/Renderer/Shader/TileVS.glsl diff --git a/src/Renderer/SphereHelper.js b/packages/Main/src/Renderer/SphereHelper.js similarity index 100% rename from src/Renderer/SphereHelper.js rename to packages/Main/src/Renderer/SphereHelper.js diff --git a/src/Renderer/WebXR.js b/packages/Main/src/Renderer/WebXR.js similarity index 100% rename from src/Renderer/WebXR.js rename to packages/Main/src/Renderer/WebXR.js diff --git a/src/Renderer/c3DEngine.js b/packages/Main/src/Renderer/c3DEngine.js similarity index 100% rename from src/Renderer/c3DEngine.js rename to packages/Main/src/Renderer/c3DEngine.js index 240053e5ea..a6b99b0768 100644 --- a/src/Renderer/c3DEngine.js +++ b/packages/Main/src/Renderer/c3DEngine.js @@ -7,9 +7,9 @@ import * as THREE from 'three'; import Capabilities from 'Core/System/Capabilities'; import { unpack1K } from 'Renderer/LayeredMaterial'; -import WEBGL from 'ThreeExtended/capabilities/WebGL'; import Label2DRenderer from 'Renderer/Label2DRenderer'; import { deprecatedC3DEngineWebGLOptions } from 'Core/Deprecated/Undeprecator'; +import WEBGL from 'ThreeExtended/capabilities/WebGL'; const depthRGBA = new THREE.Vector4(); class c3DEngine { diff --git a/src/Source/C3DTilesGoogleSource.js b/packages/Main/src/Source/C3DTilesGoogleSource.js similarity index 100% rename from src/Source/C3DTilesGoogleSource.js rename to packages/Main/src/Source/C3DTilesGoogleSource.js diff --git a/src/Source/C3DTilesIonSource.js b/packages/Main/src/Source/C3DTilesIonSource.js similarity index 100% rename from src/Source/C3DTilesIonSource.js rename to packages/Main/src/Source/C3DTilesIonSource.js diff --git a/src/Source/C3DTilesSource.js b/packages/Main/src/Source/C3DTilesSource.js similarity index 100% rename from src/Source/C3DTilesSource.js rename to packages/Main/src/Source/C3DTilesSource.js diff --git a/src/Source/CopcSource.js b/packages/Main/src/Source/CopcSource.js similarity index 99% rename from src/Source/CopcSource.js rename to packages/Main/src/Source/CopcSource.js index 9f91f27f57..03a8f42bac 100644 --- a/src/Source/CopcSource.js +++ b/packages/Main/src/Source/CopcSource.js @@ -1,6 +1,6 @@ import proj4 from 'proj4'; import { Binary, Info, Las } from 'copc'; -import Extent from 'Core/Geographic/Extent'; +import { Extent } from '@itowns/geographic'; import Fetcher from 'Provider/Fetcher'; import LASParser from 'Parser/LASParser'; import Source from 'Source/Source'; diff --git a/src/Source/EntwinePointTileSource.js b/packages/Main/src/Source/EntwinePointTileSource.js similarity index 100% rename from src/Source/EntwinePointTileSource.js rename to packages/Main/src/Source/EntwinePointTileSource.js diff --git a/src/Source/FileSource.js b/packages/Main/src/Source/FileSource.js similarity index 100% rename from src/Source/FileSource.js rename to packages/Main/src/Source/FileSource.js diff --git a/src/Source/OGC3DTilesGoogleSource.js b/packages/Main/src/Source/OGC3DTilesGoogleSource.js similarity index 100% rename from src/Source/OGC3DTilesGoogleSource.js rename to packages/Main/src/Source/OGC3DTilesGoogleSource.js diff --git a/src/Source/OGC3DTilesIonSource.js b/packages/Main/src/Source/OGC3DTilesIonSource.js similarity index 100% rename from src/Source/OGC3DTilesIonSource.js rename to packages/Main/src/Source/OGC3DTilesIonSource.js diff --git a/src/Source/OGC3DTilesSource.js b/packages/Main/src/Source/OGC3DTilesSource.js similarity index 100% rename from src/Source/OGC3DTilesSource.js rename to packages/Main/src/Source/OGC3DTilesSource.js diff --git a/src/Source/OrientedImageSource.js b/packages/Main/src/Source/OrientedImageSource.js similarity index 100% rename from src/Source/OrientedImageSource.js rename to packages/Main/src/Source/OrientedImageSource.js diff --git a/src/Source/Potree2Source.js b/packages/Main/src/Source/Potree2Source.js similarity index 100% rename from src/Source/Potree2Source.js rename to packages/Main/src/Source/Potree2Source.js diff --git a/src/Source/PotreeSource.js b/packages/Main/src/Source/PotreeSource.js similarity index 100% rename from src/Source/PotreeSource.js rename to packages/Main/src/Source/PotreeSource.js diff --git a/src/Source/Source.js b/packages/Main/src/Source/Source.js similarity index 98% rename from src/Source/Source.js rename to packages/Main/src/Source/Source.js index 11c54b5f20..9352413cb0 100644 --- a/src/Source/Source.js +++ b/packages/Main/src/Source/Source.js @@ -1,5 +1,4 @@ -import * as CRS from 'Core/Geographic/Crs'; -import Extent from 'Core/Geographic/Extent'; +import { Extent, CRS } from '@itowns/geographic'; import GeoJsonParser from 'Parser/GeoJsonParser'; import KMLParser from 'Parser/KMLParser'; import GDFParser from 'Parser/GDFParser'; diff --git a/src/Source/TMSSource.js b/packages/Main/src/Source/TMSSource.js similarity index 99% rename from src/Source/TMSSource.js rename to packages/Main/src/Source/TMSSource.js index 6d669ceec3..318089bfac 100644 --- a/src/Source/TMSSource.js +++ b/packages/Main/src/Source/TMSSource.js @@ -1,8 +1,8 @@ import Source from 'Source/Source'; import URLBuilder from 'Provider/URLBuilder'; -import Extent from 'Core/Geographic/Extent'; -import Tile from 'Core/Tile/Tile'; +import { Extent } from '@itowns/geographic'; import { globalExtentTMS } from 'Core/Tile/TileGrid'; +import Tile from 'Core/Tile/Tile'; const _tile = new Tile('EPSG:4326', 0, 0, 0); diff --git a/src/Source/VectorTilesSource.js b/packages/Main/src/Source/VectorTilesSource.js similarity index 100% rename from src/Source/VectorTilesSource.js rename to packages/Main/src/Source/VectorTilesSource.js diff --git a/src/Source/WFSSource.js b/packages/Main/src/Source/WFSSource.js similarity index 99% rename from src/Source/WFSSource.js rename to packages/Main/src/Source/WFSSource.js index 5d2c771fa6..42688acc62 100644 --- a/src/Source/WFSSource.js +++ b/packages/Main/src/Source/WFSSource.js @@ -1,6 +1,6 @@ import Source from 'Source/Source'; import URLBuilder from 'Provider/URLBuilder'; -import Extent from 'Core/Geographic/Extent'; +import { Extent } from '@itowns/geographic'; const _extent = new Extent('EPSG:4326', [0, 0, 0, 0]); diff --git a/src/Source/WMSSource.js b/packages/Main/src/Source/WMSSource.js similarity index 98% rename from src/Source/WMSSource.js rename to packages/Main/src/Source/WMSSource.js index 41dab478b1..b86052ad3a 100644 --- a/src/Source/WMSSource.js +++ b/packages/Main/src/Source/WMSSource.js @@ -1,7 +1,6 @@ import Source from 'Source/Source'; import URLBuilder from 'Provider/URLBuilder'; -import Extent from 'Core/Geographic/Extent'; -import * as CRS from 'Core/Geographic/Crs'; +import { Extent, CRS } from '@itowns/geographic'; const _extent = new Extent('EPSG:4326', [0, 0, 0, 0]); diff --git a/src/Source/WMTSSource.js b/packages/Main/src/Source/WMTSSource.js similarity index 100% rename from src/Source/WMTSSource.js rename to packages/Main/src/Source/WMTSSource.js diff --git a/src/Utils/CameraUtils.js b/packages/Main/src/Utils/CameraUtils.js similarity index 99% rename from src/Utils/CameraUtils.js rename to packages/Main/src/Utils/CameraUtils.js index a586a242e0..efc61659c2 100644 --- a/src/Utils/CameraUtils.js +++ b/packages/Main/src/Utils/CameraUtils.js @@ -2,8 +2,7 @@ import * as THREE from 'three'; import TWEEN from '@tweenjs/tween.js'; import DEMUtils from 'Utils/DEMUtils'; import { MAIN_LOOP_EVENTS } from 'Core/MainLoop'; -import Coordinates from 'Core/Geographic/Coordinates'; -import Ellipsoid from 'Core/Math/Ellipsoid'; +import { Coordinates, Ellipsoid } from '@itowns/geographic'; import OBB from 'Renderer/OBB'; import { VIEW_EVENTS } from 'Core/View'; diff --git a/src/Utils/DEMUtils.js b/packages/Main/src/Utils/DEMUtils.js similarity index 99% rename from src/Utils/DEMUtils.js rename to packages/Main/src/Utils/DEMUtils.js index d4ad018c7a..5bb8bfa077 100644 --- a/src/Utils/DEMUtils.js +++ b/packages/Main/src/Utils/DEMUtils.js @@ -1,5 +1,5 @@ import * as THREE from 'three'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; import placeObjectOnGround from 'Utils/placeObjectOnGround'; const FAST_READ_Z = 0; diff --git a/src/Utils/FeaturesUtils.js b/packages/Main/src/Utils/FeaturesUtils.js similarity index 99% rename from src/Utils/FeaturesUtils.js rename to packages/Main/src/Utils/FeaturesUtils.js index 005efe5c5c..d5928a94ac 100644 --- a/src/Utils/FeaturesUtils.js +++ b/packages/Main/src/Utils/FeaturesUtils.js @@ -1,5 +1,5 @@ import { FEATURE_TYPES } from 'Core/Feature'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; function pointIsOverLine(point, linePoints, epsilon, offset, count, size) { const x0 = point.x; diff --git a/src/Utils/Gradients.js b/packages/Main/src/Utils/Gradients.js similarity index 100% rename from src/Utils/Gradients.js rename to packages/Main/src/Utils/Gradients.js diff --git a/src/Utils/ThreeUtils.js b/packages/Main/src/Utils/ThreeUtils.js similarity index 100% rename from src/Utils/ThreeUtils.js rename to packages/Main/src/Utils/ThreeUtils.js diff --git a/src/Utils/placeObjectOnGround.js b/packages/Main/src/Utils/placeObjectOnGround.js similarity index 99% rename from src/Utils/placeObjectOnGround.js rename to packages/Main/src/Utils/placeObjectOnGround.js index e6e9e5ede8..fb79f07608 100644 --- a/src/Utils/placeObjectOnGround.js +++ b/packages/Main/src/Utils/placeObjectOnGround.js @@ -1,6 +1,6 @@ import * as THREE from 'three'; +import { Coordinates } from '@itowns/geographic'; import DEMUtils from 'Utils/DEMUtils'; -import Coordinates from 'Core/Geographic/Coordinates'; const temp = { v: new THREE.Vector3(), diff --git a/src/Worker/LASLoaderWorker.js b/packages/Main/src/Worker/LASLoaderWorker.js similarity index 100% rename from src/Worker/LASLoaderWorker.js rename to packages/Main/src/Worker/LASLoaderWorker.js diff --git a/src/Worker/Potree2Worker.js b/packages/Main/src/Worker/Potree2Worker.js similarity index 100% rename from src/Worker/Potree2Worker.js rename to packages/Main/src/Worker/Potree2Worker.js diff --git a/packages/Main/test/.eslintrc.cjs b/packages/Main/test/.eslintrc.cjs new file mode 100644 index 0000000000..28b3eb003d --- /dev/null +++ b/packages/Main/test/.eslintrc.cjs @@ -0,0 +1,9 @@ +module.exports = { + rules: { + 'func-names': 'off', + 'prefer-arrow-callback': 'off', + }, + env: { + mocha: true, + }, +}; diff --git a/test/data/EGM2008_simplified.gdf b/packages/Main/test/data/EGM2008_simplified.gdf similarity index 100% rename from test/data/EGM2008_simplified.gdf rename to packages/Main/test/data/EGM2008_simplified.gdf diff --git a/test/data/OrientedImage/cameraCalibration.json b/packages/Main/test/data/OrientedImage/cameraCalibration.json similarity index 100% rename from test/data/OrientedImage/cameraCalibration.json rename to packages/Main/test/data/OrientedImage/cameraCalibration.json diff --git a/test/data/OrientedImage/panoramicsMetaDataParis.geojson b/packages/Main/test/data/OrientedImage/panoramicsMetaDataParis.geojson similarity index 100% rename from test/data/OrientedImage/panoramicsMetaDataParis.geojson rename to packages/Main/test/data/OrientedImage/panoramicsMetaDataParis.geojson diff --git a/test/data/entwine/ept-hierarchy/0-0-0-0.json b/packages/Main/test/data/entwine/ept-hierarchy/0-0-0-0.json similarity index 100% rename from test/data/entwine/ept-hierarchy/0-0-0-0.json rename to packages/Main/test/data/entwine/ept-hierarchy/0-0-0-0.json diff --git a/test/data/entwine/ept.json b/packages/Main/test/data/entwine/ept.json similarity index 100% rename from test/data/entwine/ept.json rename to packages/Main/test/data/entwine/ept.json diff --git a/test/data/filesource/featCollec_Polygone.geojson b/packages/Main/test/data/filesource/featCollec_Polygone.geojson similarity index 100% rename from test/data/filesource/featCollec_Polygone.geojson rename to packages/Main/test/data/filesource/featCollec_Polygone.geojson diff --git a/test/data/filesource/feat_Polygone.geojson b/packages/Main/test/data/filesource/feat_Polygone.geojson similarity index 100% rename from test/data/filesource/feat_Polygone.geojson rename to packages/Main/test/data/filesource/feat_Polygone.geojson diff --git a/test/data/geojson/gpx.geojson b/packages/Main/test/data/geojson/gpx.geojson similarity index 100% rename from test/data/geojson/gpx.geojson rename to packages/Main/test/data/geojson/gpx.geojson diff --git a/test/data/geojson/holes.geojson b/packages/Main/test/data/geojson/holes.geojson similarity index 100% rename from test/data/geojson/holes.geojson rename to packages/Main/test/data/geojson/holes.geojson diff --git a/test/data/geojson/holesPoints.geojson b/packages/Main/test/data/geojson/holesPoints.geojson similarity index 100% rename from test/data/geojson/holesPoints.geojson rename to packages/Main/test/data/geojson/holesPoints.geojson diff --git a/test/data/geojson/map.geojson b/packages/Main/test/data/geojson/map.geojson similarity index 100% rename from test/data/geojson/map.geojson rename to packages/Main/test/data/geojson/map.geojson diff --git a/test/data/geojson/map_big.geojson b/packages/Main/test/data/geojson/map_big.geojson similarity index 100% rename from test/data/geojson/map_big.geojson rename to packages/Main/test/data/geojson/map_big.geojson diff --git a/test/data/geojson/map_small.geojson b/packages/Main/test/data/geojson/map_small.geojson similarity index 100% rename from test/data/geojson/map_small.geojson rename to packages/Main/test/data/geojson/map_small.geojson diff --git a/test/data/geojson/points.geojson b/packages/Main/test/data/geojson/points.geojson similarity index 100% rename from test/data/geojson/points.geojson rename to packages/Main/test/data/geojson/points.geojson diff --git a/test/data/geojson/simple.geojson b/packages/Main/test/data/geojson/simple.geojson similarity index 100% rename from test/data/geojson/simple.geojson rename to packages/Main/test/data/geojson/simple.geojson diff --git a/test/data/gltf/box.glb b/packages/Main/test/data/gltf/box.glb similarity index 100% rename from test/data/gltf/box.glb rename to packages/Main/test/data/gltf/box.glb diff --git a/test/data/mapboxMulti.json b/packages/Main/test/data/mapboxMulti.json similarity index 100% rename from test/data/mapboxMulti.json rename to packages/Main/test/data/mapboxMulti.json diff --git a/test/data/pbf/multipolygon.pbf b/packages/Main/test/data/pbf/multipolygon.pbf similarity index 100% rename from test/data/pbf/multipolygon.pbf rename to packages/Main/test/data/pbf/multipolygon.pbf diff --git a/test/data/raf09_simplified.isg b/packages/Main/test/data/raf09_simplified.isg similarity index 100% rename from test/data/raf09_simplified.isg rename to packages/Main/test/data/raf09_simplified.isg diff --git a/test/data/vectortiles/sprite.json b/packages/Main/test/data/vectortiles/sprite.json similarity index 100% rename from test/data/vectortiles/sprite.json rename to packages/Main/test/data/vectortiles/sprite.json diff --git a/test/data/vectortiles/style.json b/packages/Main/test/data/vectortiles/style.json similarity index 100% rename from test/data/vectortiles/style.json rename to packages/Main/test/data/vectortiles/style.json diff --git a/test/data/vectortiles/tilejson.json b/packages/Main/test/data/vectortiles/tilejson.json similarity index 100% rename from test/data/vectortiles/tilejson.json rename to packages/Main/test/data/vectortiles/tilejson.json diff --git a/test/unit/3dtiles.js b/packages/Main/test/unit/3dtiles.js similarity index 97% rename from test/unit/3dtiles.js rename to packages/Main/test/unit/3dtiles.js index c5ac00d76a..a741af167d 100644 --- a/test/unit/3dtiles.js +++ b/packages/Main/test/unit/3dtiles.js @@ -1,8 +1,7 @@ -import proj4 from 'proj4'; import assert from 'assert'; import { Matrix4, Object3D, Sphere } from 'three'; import Camera from 'Renderer/Camera'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates, CRS } from '@itowns/geographic'; import { computeNodeSSE } from 'Process/3dTilesProcessing'; import { configureTile } from 'Provider/3dTilesProvider'; import C3DTileset from '../../src/Core/3DTiles/C3DTileset'; @@ -93,7 +92,7 @@ describe('Distance computation for boundingVolume region', function () { }); describe('Distance computation for boundingVolume box', function () { - proj4.defs('EPSG:3946', + CRS.defs('EPSG:3946', '+proj=lcc +lat_1=45.25 +lat_2=46.75 +lat_0=46 +lon_0=3 +x_0=1700000 +y_0=5200000 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs'); const camera = new Camera('EPSG:3946', 100, 100); @@ -131,7 +130,7 @@ describe('Distance computation for boundingVolume box', function () { }); describe('Distance computation for boundingVolume sphere', function () { - proj4.defs('EPSG:3946', + CRS.defs('EPSG:3946', '+proj=lcc +lat_1=45.25 +lat_2=46.75 +lat_0=46 +lon_0=3 +x_0=1700000 +y_0=5200000 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs'); const camera = new Camera('EPSG:3946', 100, 100); diff --git a/test/unit/3dtilesbatchtable.js b/packages/Main/test/unit/3dtilesbatchtable.js similarity index 100% rename from test/unit/3dtilesbatchtable.js rename to packages/Main/test/unit/3dtilesbatchtable.js diff --git a/test/unit/3dtilesbatchtablehierarchy.js b/packages/Main/test/unit/3dtilesbatchtablehierarchy.js similarity index 100% rename from test/unit/3dtilesbatchtablehierarchy.js rename to packages/Main/test/unit/3dtilesbatchtablehierarchy.js diff --git a/test/unit/3dtilesbinarypropertyaccessor.js b/packages/Main/test/unit/3dtilesbinarypropertyaccessor.js similarity index 100% rename from test/unit/3dtilesbinarypropertyaccessor.js rename to packages/Main/test/unit/3dtilesbinarypropertyaccessor.js diff --git a/test/unit/3dtilesfeature.js b/packages/Main/test/unit/3dtilesfeature.js similarity index 100% rename from test/unit/3dtilesfeature.js rename to packages/Main/test/unit/3dtilesfeature.js diff --git a/test/unit/3dtilesgetchildren.js b/packages/Main/test/unit/3dtilesgetchildren.js similarity index 100% rename from test/unit/3dtilesgetchildren.js rename to packages/Main/test/unit/3dtilesgetchildren.js diff --git a/test/unit/3dtileslayerprocess.js b/packages/Main/test/unit/3dtileslayerprocess.js similarity index 98% rename from test/unit/3dtileslayerprocess.js rename to packages/Main/test/unit/3dtileslayerprocess.js index df5d1b583a..dd478672bc 100644 --- a/test/unit/3dtileslayerprocess.js +++ b/packages/Main/test/unit/3dtileslayerprocess.js @@ -4,7 +4,7 @@ import C3DTilesLayer from 'Layer/C3DTilesLayer'; import C3DTilesSource from 'Source/C3DTilesSource'; import View from 'Core/View'; import GlobeView from 'Core/Prefab/GlobeView'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; import sinon from 'sinon'; import Fetcher from 'Provider/Fetcher'; import Renderer from './bootstrap'; diff --git a/test/unit/3dtileslayerprocessbatchtable.js b/packages/Main/test/unit/3dtileslayerprocessbatchtable.js similarity index 98% rename from test/unit/3dtileslayerprocessbatchtable.js rename to packages/Main/test/unit/3dtileslayerprocessbatchtable.js index abc074784b..fc132127fd 100644 --- a/test/unit/3dtileslayerprocessbatchtable.js +++ b/packages/Main/test/unit/3dtileslayerprocessbatchtable.js @@ -7,7 +7,7 @@ import C3DTExtensions from 'Core/3DTiles/C3DTExtensions'; import { C3DTilesTypes } from 'Core/3DTiles/C3DTilesEnums'; import View from 'Core/View'; import GlobeView from 'Core/Prefab/GlobeView'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; import Fetcher from 'Provider/Fetcher'; import sinon from 'sinon'; import Renderer from './bootstrap'; diff --git a/test/unit/3dtileslayerstyle.js b/packages/Main/test/unit/3dtileslayerstyle.js similarity index 94% rename from test/unit/3dtileslayerstyle.js rename to packages/Main/test/unit/3dtileslayerstyle.js index 4c78899983..327fd14daa 100644 --- a/test/unit/3dtileslayerstyle.js +++ b/packages/Main/test/unit/3dtileslayerstyle.js @@ -1,7 +1,6 @@ import assert from 'assert'; -import proj4 from 'proj4'; import * as THREE from 'three'; -import Extent from 'Core/Geographic/Extent'; +import { Extent, CRS } from '@itowns/geographic'; import PlanarView from 'Core/Prefab/PlanarView'; import C3DTBatchTable from 'Core/3DTiles/C3DTBatchTable'; import C3DTilesSource from 'Source/C3DTilesSource'; @@ -48,7 +47,7 @@ describe('3DTilesLayer Style', () => { .callsFake(() => Promise.resolve(tileset)); // Define crs - proj4.defs('EPSG:3946', '+proj=lcc +lat_1=45.25 +lat_2=46.75 +lat_0=46 +lon_0=3 +x_0=1700000 +y_0=5200000 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs'); + CRS.defs('EPSG:3946', '+proj=lcc +lat_1=45.25 +lat_2=46.75 +lat_0=46 +lon_0=3 +x_0=1700000 +y_0=5200000 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs'); // Define geographic extent: CRS, min/max X, min/max Y const extent = new Extent('EPSG:3946', diff --git a/test/unit/bootstrap.js b/packages/Main/test/unit/bootstrap.js similarity index 100% rename from test/unit/bootstrap.js rename to packages/Main/test/unit/bootstrap.js diff --git a/test/unit/cache.js b/packages/Main/test/unit/cache.js similarity index 100% rename from test/unit/cache.js rename to packages/Main/test/unit/cache.js diff --git a/test/unit/camera.js b/packages/Main/test/unit/camera.js similarity index 97% rename from test/unit/camera.js rename to packages/Main/test/unit/camera.js index a2738ee4fe..ed7c8c5efd 100644 --- a/test/unit/camera.js +++ b/packages/Main/test/unit/camera.js @@ -1,6 +1,6 @@ import assert from 'assert'; import Camera, { CAMERA_TYPE } from 'Renderer/Camera'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; import { compareWithEpsilon } from './utils'; describe('camera', function () { diff --git a/test/unit/cameraUtils.js b/packages/Main/test/unit/cameraUtils.js similarity index 95% rename from test/unit/cameraUtils.js rename to packages/Main/test/unit/cameraUtils.js index a8e57c059c..704edf3d5f 100644 --- a/test/unit/cameraUtils.js +++ b/packages/Main/test/unit/cameraUtils.js @@ -1,14 +1,11 @@ import * as THREE from 'three'; import assert from 'assert'; -import Coordinates from 'Core/Geographic/Coordinates'; -import Ellipsoid from 'Core/Math/Ellipsoid'; +import { Coordinates, Ellipsoid, Extent, CRS } from '@itowns/geographic'; import CameraUtils from 'Utils/CameraUtils'; import DEMUtils from 'Utils/DEMUtils'; import Camera, { CAMERA_TYPE } from 'Renderer/Camera'; -import Extent from 'Core/Geographic/Extent'; -import proj4 from 'proj4'; -proj4.defs('EPSG:2154', '+proj=lcc +lat_1=49 +lat_2=44 +lat_0=46.5 +lon_0=3 +x_0=700000 +y_0=6600000 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs'); +CRS.defs('EPSG:2154', '+proj=lcc +lat_1=49 +lat_2=44 +lat_0=46.5 +lon_0=3 +x_0=700000 +y_0=6600000 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs'); function equalToFixed(value1, value2, toFixed) { return value1.toFixed(toFixed) === value2.toFixed(toFixed); diff --git a/test/unit/copc.js b/packages/Main/test/unit/copc.js similarity index 100% rename from test/unit/copc.js rename to packages/Main/test/unit/copc.js diff --git a/test/unit/dataSourceProvider.js b/packages/Main/test/unit/dataSourceProvider.js similarity index 99% rename from test/unit/dataSourceProvider.js rename to packages/Main/test/unit/dataSourceProvider.js index 6bbbbb52fa..0a4c93d3a2 100644 --- a/test/unit/dataSourceProvider.js +++ b/packages/Main/test/unit/dataSourceProvider.js @@ -3,7 +3,7 @@ import assert from 'assert'; import { updateLayeredMaterialNodeImagery, updateLayeredMaterialNodeElevation } from 'Process/LayeredMaterialNodeProcessing'; import FeatureProcessing from 'Process/FeatureProcessing'; import TileMesh from 'Core/TileMesh'; -import Extent from 'Core/Geographic/Extent'; +import { Extent } from '@itowns/geographic'; import { globalExtentTMS } from 'Core/Tile/TileGrid'; import OBB from 'Renderer/OBB'; import DataSourceProvider from 'Provider/DataSourceProvider'; diff --git a/test/unit/demutils.js b/packages/Main/test/unit/demutils.js similarity index 97% rename from test/unit/demutils.js rename to packages/Main/test/unit/demutils.js index d48e36187a..78397470e5 100644 --- a/test/unit/demutils.js +++ b/packages/Main/test/unit/demutils.js @@ -4,8 +4,7 @@ import WMTSSource from 'Source/WMTSSource'; import Fetcher from 'Provider/Fetcher'; import assert from 'assert'; import GlobeView from 'Core/Prefab/GlobeView'; -import Coordinates from 'Core/Geographic/Coordinates'; -import Extent from 'Core/Geographic/Extent'; +import { Coordinates, Extent } from '@itowns/geographic'; import { updateLayeredMaterialNodeElevation } from 'Process/LayeredMaterialNodeProcessing'; import TileMesh from 'Core/TileMesh'; import OBB from 'Renderer/OBB'; diff --git a/test/unit/entwine.js b/packages/Main/test/unit/entwine.js similarity index 98% rename from test/unit/entwine.js rename to packages/Main/test/unit/entwine.js index 43fc24237e..e257348fde 100644 --- a/test/unit/entwine.js +++ b/packages/Main/test/unit/entwine.js @@ -1,7 +1,7 @@ import assert from 'assert'; import View from 'Core/View'; import GlobeView from 'Core/Prefab/GlobeView'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; import EntwinePointTileSource from 'Source/EntwinePointTileSource'; import EntwinePointTileLayer from 'Layer/EntwinePointTileLayer'; import EntwinePointTileNode from 'Core/EntwinePointTileNode'; @@ -41,7 +41,7 @@ describe('Entwine Point Tile', function () { .callsFake(() => Promise.resolve(new ArrayBuffer())); // currently no test on data fetched... - LASParser.enableLazPerf('./examples/libs/laz-perf'); + LASParser.enableLazPerf('../../examples/libs/laz-perf'); }); after(async function () { diff --git a/test/unit/feature.js b/packages/Main/test/unit/feature.js similarity index 98% rename from test/unit/feature.js rename to packages/Main/test/unit/feature.js index 093897b116..cb082bb1da 100644 --- a/test/unit/feature.js +++ b/packages/Main/test/unit/feature.js @@ -1,6 +1,6 @@ import assert from 'assert'; import Feature, { FeatureCollection, FEATURE_TYPES } from 'Core/Feature'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; describe('Feature', function () { const options_A = { diff --git a/test/unit/feature2mesh.js b/packages/Main/test/unit/feature2mesh.js similarity index 98% rename from test/unit/feature2mesh.js rename to packages/Main/test/unit/feature2mesh.js index 5fb209a512..ed6dbbb680 100644 --- a/test/unit/feature2mesh.js +++ b/packages/Main/test/unit/feature2mesh.js @@ -1,5 +1,5 @@ import * as THREE from 'three'; -import proj4 from 'proj4'; +import { CRS } from '@itowns/geographic'; import assert from 'assert'; import GeoJsonParser from 'Parser/GeoJsonParser'; import Feature2Mesh from 'Converter/Feature2Mesh'; @@ -8,7 +8,7 @@ import geojson from '../data/geojson/holes.geojson'; import geojson2 from '../data/geojson/simple.geojson'; import geojson3 from '../data/geojson/points.geojson'; -proj4.defs('EPSG:3946', +CRS.defs('EPSG:3946', '+proj=lcc +lat_1=45.25 +lat_2=46.75 +lat_0=46 +lon_0=3 +x_0=1700000 +y_0=5200000 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs'); function computeAreaOfMesh(mesh) { diff --git a/test/unit/featureUtils.js b/packages/Main/test/unit/featureUtils.js similarity index 98% rename from test/unit/featureUtils.js rename to packages/Main/test/unit/featureUtils.js index df2d11f475..6bfb5cc458 100644 --- a/test/unit/featureUtils.js +++ b/packages/Main/test/unit/featureUtils.js @@ -1,7 +1,7 @@ import assert from 'assert'; import GeoJsonParser from 'Parser/GeoJsonParser'; import FeaturesUtils from 'Utils/FeaturesUtils'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; import { FEATURE_TYPES } from 'Core/Feature'; import geojson from '../data/geojson/simple.geojson'; diff --git a/test/unit/featuregeometrylayer.js b/packages/Main/test/unit/featuregeometrylayer.js similarity index 97% rename from test/unit/featuregeometrylayer.js rename to packages/Main/test/unit/featuregeometrylayer.js index 84e23dd8e4..a27360c1cf 100644 --- a/test/unit/featuregeometrylayer.js +++ b/packages/Main/test/unit/featuregeometrylayer.js @@ -4,8 +4,7 @@ import GlobeView from 'Core/Prefab/GlobeView'; import FeatureGeometryLayer from 'Layer/FeatureGeometryLayer'; import FileSource from 'Source/FileSource'; import Fetcher from 'Provider/Fetcher'; -import Extent from 'Core/Geographic/Extent'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates, Extent } from '@itowns/geographic'; import OBB from 'Renderer/OBB'; import TileMesh from 'Core/TileMesh'; import sinon from 'sinon'; diff --git a/test/unit/featuregeometrylayererror.js b/packages/Main/test/unit/featuregeometrylayererror.js similarity index 97% rename from test/unit/featuregeometrylayererror.js rename to packages/Main/test/unit/featuregeometrylayererror.js index 09d696d370..bf6ff18060 100644 --- a/test/unit/featuregeometrylayererror.js +++ b/packages/Main/test/unit/featuregeometrylayererror.js @@ -3,8 +3,7 @@ import assert from 'assert'; import GlobeView from 'Core/Prefab/GlobeView'; import FeatureGeometryLayer from 'Layer/FeatureGeometryLayer'; import FileSource from 'Source/FileSource'; -import Extent from 'Core/Geographic/Extent'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Extent, Coordinates } from '@itowns/geographic'; import OBB from 'Renderer/OBB'; import TileMesh from 'Core/TileMesh'; import Renderer from './bootstrap'; diff --git a/test/unit/fetcher.js b/packages/Main/test/unit/fetcher.js similarity index 100% rename from test/unit/fetcher.js rename to packages/Main/test/unit/fetcher.js diff --git a/test/unit/gdfparser.js b/packages/Main/test/unit/gdfparser.js similarity index 100% rename from test/unit/gdfparser.js rename to packages/Main/test/unit/gdfparser.js diff --git a/test/unit/geoidgrid.js b/packages/Main/test/unit/geoidgrid.js similarity index 90% rename from test/unit/geoidgrid.js rename to packages/Main/test/unit/geoidgrid.js index 64a058b0c1..7492d5ffb7 100644 --- a/test/unit/geoidgrid.js +++ b/packages/Main/test/unit/geoidgrid.js @@ -1,8 +1,6 @@ import assert from 'assert'; -import Extent from 'Core/Geographic/Extent'; +import { Coordinates, Extent } from '@itowns/geographic'; import GeoidGrid from 'Core/Geographic/GeoidGrid'; -import Coordinates from 'Core/Geographic/Coordinates'; - describe('GeoidGrid', function () { let geoidGrid; diff --git a/test/unit/geoidlayer.js b/packages/Main/test/unit/geoidlayer.js similarity index 96% rename from test/unit/geoidlayer.js rename to packages/Main/test/unit/geoidlayer.js index 687a8553b5..e704996079 100644 --- a/test/unit/geoidlayer.js +++ b/packages/Main/test/unit/geoidlayer.js @@ -4,9 +4,8 @@ import assert from 'assert'; import GeoidLayer from 'Layer/GeoidLayer'; import FileSource from 'Source/FileSource'; import Fetcher from 'Provider/Fetcher'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates, Extent } from '@itowns/geographic'; import GlobeView from 'Core/Prefab/GlobeView'; -import Extent from 'Core/Geographic/Extent'; import OBB from 'Renderer/OBB'; import TileMesh from 'Core/TileMesh'; import sinon from 'sinon'; diff --git a/test/unit/geojson.js b/packages/Main/test/unit/geojson.js similarity index 97% rename from test/unit/geojson.js rename to packages/Main/test/unit/geojson.js index 2116eebade..9a40508e58 100644 --- a/test/unit/geojson.js +++ b/packages/Main/test/unit/geojson.js @@ -1,13 +1,12 @@ -import proj4 from 'proj4'; import assert from 'assert'; import GeoJsonParser from 'Parser/GeoJsonParser'; -import Extent from 'Core/Geographic/Extent'; +import { Extent, CRS } from '@itowns/geographic'; import holes from '../data/geojson/holes.geojson'; import gpx from '../data/geojson/gpx.geojson'; import points from '../data/geojson/points.geojson'; -proj4.defs('EPSG:3946', +CRS.defs('EPSG:3946', '+proj=lcc +lat_1=45.25 +lat_2=46.75 +lat_0=46 +lon_0=3 +x_0=1700000 +y_0=5200000 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs'); function parse(geojson) { diff --git a/test/unit/geometrylayer.js b/packages/Main/test/unit/geometrylayer.js similarity index 100% rename from test/unit/geometrylayer.js rename to packages/Main/test/unit/geometrylayer.js diff --git a/test/unit/globecontrol.js b/packages/Main/test/unit/globecontrol.js similarity index 99% rename from test/unit/globecontrol.js rename to packages/Main/test/unit/globecontrol.js index e9eb805e3a..be59ce6664 100644 --- a/test/unit/globecontrol.js +++ b/packages/Main/test/unit/globecontrol.js @@ -1,7 +1,7 @@ import { MOUSE } from 'three'; import assert from 'assert'; import GlobeView from 'Core/Prefab/GlobeView'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; import { getLookAtFromMath, getRig } from 'Utils/CameraUtils'; import StateControl from 'Controls/StateControl'; import Renderer from './bootstrap'; diff --git a/test/unit/globeview.js b/packages/Main/test/unit/globeview.js similarity index 97% rename from test/unit/globeview.js rename to packages/Main/test/unit/globeview.js index 0d5cf8278b..846e48f942 100644 --- a/test/unit/globeview.js +++ b/packages/Main/test/unit/globeview.js @@ -2,8 +2,7 @@ import * as THREE from 'three'; import assert from 'assert'; import GlobeView from 'Core/Prefab/GlobeView'; import ObjectRemovalHelper from 'Process/ObjectRemovalHelper'; -import Coordinates from 'Core/Geographic/Coordinates'; -import Extent from 'Core/Geographic/Extent'; +import { Coordinates, Extent } from '@itowns/geographic'; import Renderer from './bootstrap'; import CameraUtils from '../../src/Utils/CameraUtils'; import OBB from '../../src/Renderer/OBB'; diff --git a/test/unit/gtxparser.js b/packages/Main/test/unit/gtxparser.js similarity index 100% rename from test/unit/gtxparser.js rename to packages/Main/test/unit/gtxparser.js diff --git a/test/unit/igltfloader.js b/packages/Main/test/unit/igltfloader.js similarity index 100% rename from test/unit/igltfloader.js rename to packages/Main/test/unit/igltfloader.js diff --git a/test/unit/isgparser.js b/packages/Main/test/unit/isgparser.js similarity index 100% rename from test/unit/isgparser.js rename to packages/Main/test/unit/isgparser.js diff --git a/test/unit/label.js b/packages/Main/test/unit/label.js similarity index 98% rename from test/unit/label.js rename to packages/Main/test/unit/label.js index b0fb2a4f61..62e3708621 100644 --- a/test/unit/label.js +++ b/packages/Main/test/unit/label.js @@ -3,8 +3,7 @@ import * as THREE from 'three'; import Label from 'Core/Label'; import Style from 'Core/Style'; import { FeatureCollection, FEATURE_TYPES } from 'Core/Feature'; -import Coordinates from 'Core/Geographic/Coordinates'; -import Extent from 'Core/Geographic/Extent'; +import { Coordinates, Extent } from '@itowns/geographic'; import LabelLayer from 'Layer/LabelLayer'; import GlobeView from 'Core/Prefab/GlobeView'; import ColorLayer from 'Layer/ColorLayer'; diff --git a/test/unit/lasparser.js b/packages/Main/test/unit/lasparser.js similarity index 98% rename from test/unit/lasparser.js rename to packages/Main/test/unit/lasparser.js index 3c91d8b5ed..0c7361c3ed 100644 --- a/test/unit/lasparser.js +++ b/packages/Main/test/unit/lasparser.js @@ -31,7 +31,7 @@ describe('LASParser', function () { describe('unit tests', function _describe() { const epsilon = 0.1; - LASParser.enableLazPerf('./examples/libs/laz-perf'); + LASParser.enableLazPerf('../../examples/libs/laz-perf'); it('parses a las file to a THREE.BufferGeometry', async function () { if (!lasData) { this.skip(); } diff --git a/test/unit/layer.js b/packages/Main/test/unit/layer.js similarity index 100% rename from test/unit/layer.js rename to packages/Main/test/unit/layer.js diff --git a/test/unit/layeredmaterial.js b/packages/Main/test/unit/layeredmaterial.js similarity index 98% rename from test/unit/layeredmaterial.js rename to packages/Main/test/unit/layeredmaterial.js index 89f171abf0..0dc2003dbb 100644 --- a/test/unit/layeredmaterial.js +++ b/packages/Main/test/unit/layeredmaterial.js @@ -3,7 +3,7 @@ import ColorLayer from 'Layer/ColorLayer'; import TMSSource from 'Source/TMSSource'; import { updateLayeredMaterialNodeImagery } from 'Process/LayeredMaterialNodeProcessing'; import GlobeView from 'Core/Prefab/GlobeView'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; import TileMesh from 'Core/TileMesh'; import * as THREE from 'three'; import Tile from 'Core/Tile/Tile'; diff --git a/test/unit/layeredmaterialnodeprocessing.js b/packages/Main/test/unit/layeredmaterialnodeprocessing.js similarity index 99% rename from test/unit/layeredmaterialnodeprocessing.js rename to packages/Main/test/unit/layeredmaterialnodeprocessing.js index 38c7daf92d..21fadedeb0 100644 --- a/test/unit/layeredmaterialnodeprocessing.js +++ b/packages/Main/test/unit/layeredmaterialnodeprocessing.js @@ -2,7 +2,7 @@ import * as THREE from 'three'; import assert from 'assert'; import { updateLayeredMaterialNodeImagery } from 'Process/LayeredMaterialNodeProcessing'; import TileMesh from 'Core/TileMesh'; -import Extent from 'Core/Geographic/Extent'; +import { Extent } from '@itowns/geographic'; import OBB from 'Renderer/OBB'; import Layer from 'Layer/Layer'; import Source from 'Source/Source'; diff --git a/test/unit/layerupdatestrategy.js b/packages/Main/test/unit/layerupdatestrategy.js similarity index 99% rename from test/unit/layerupdatestrategy.js rename to packages/Main/test/unit/layerupdatestrategy.js index dc57ef9b99..cdafd3f66a 100644 --- a/test/unit/layerupdatestrategy.js +++ b/packages/Main/test/unit/layerupdatestrategy.js @@ -1,7 +1,7 @@ import * as THREE from 'three'; import assert from 'assert'; import TileMesh from 'Core/TileMesh'; -import Extent from 'Core/Geographic/Extent'; +import { Extent } from '@itowns/geographic'; import OBB from 'Renderer/OBB'; import Layer from 'Layer/Layer'; import Source from 'Source/Source'; diff --git a/test/unit/obb.js b/packages/Main/test/unit/obb.js similarity index 93% rename from test/unit/obb.js rename to packages/Main/test/unit/obb.js index 706e0929c9..212e0f240f 100644 --- a/test/unit/obb.js +++ b/packages/Main/test/unit/obb.js @@ -1,7 +1,6 @@ import * as THREE from 'three'; -import proj4 from 'proj4'; import assert from 'assert'; -import Extent from 'Core/Geographic/Extent'; +import { Extent, CRS } from '@itowns/geographic'; import { PlanarTileBuilder } from 'Core/Prefab/Planar/PlanarTileBuilder'; import { GlobeTileBuilder } from 'Core/Prefab/Globe/GlobeTileBuilder'; import { newTileGeometry } from 'Core/Prefab/TileBuilder'; @@ -45,7 +44,7 @@ describe('OBB', function () { // Define crs projection that we will use (taken from https://epsg.io/3946, Proj4js section) -proj4.defs('EPSG:3946', '+proj=lcc +lat_1=45.25 +lat_2=46.75 +lat_0=46 +lon_0=3 +x_0=1700000 +y_0=5200000 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs'); +CRS.defs('EPSG:3946', '+proj=lcc +lat_1=45.25 +lat_2=46.75 +lat_0=46 +lon_0=3 +x_0=1700000 +y_0=5200000 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs'); function assertVerticesAreInOBB(builder, extent) { const params = { extent, diff --git a/test/unit/ogc3dtileslayer.js b/packages/Main/test/unit/ogc3dtileslayer.js similarity index 100% rename from test/unit/ogc3dtileslayer.js rename to packages/Main/test/unit/ogc3dtileslayer.js diff --git a/test/unit/orientedImageCamera.js b/packages/Main/test/unit/orientedImageCamera.js similarity index 100% rename from test/unit/orientedImageCamera.js rename to packages/Main/test/unit/orientedImageCamera.js diff --git a/test/unit/orientedimagelayer.js b/packages/Main/test/unit/orientedimagelayer.js similarity index 93% rename from test/unit/orientedimagelayer.js rename to packages/Main/test/unit/orientedimagelayer.js index 27b81656f5..0724a5a56b 100644 --- a/test/unit/orientedimagelayer.js +++ b/packages/Main/test/unit/orientedimagelayer.js @@ -1,8 +1,7 @@ -import proj4 from 'proj4'; import assert from 'assert'; import OrientedImageLayer from 'Layer/OrientedImageLayer'; import OrientedImageSource from 'Source/OrientedImageSource'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates, CRS } from '@itowns/geographic'; import GlobeView from 'Core/Prefab/GlobeView'; import sinon from 'sinon'; import Fetcher from 'Provider/Fetcher'; @@ -28,7 +27,7 @@ describe('Oriented Image Layer', function () { before(function () { stubFetcherJson = sinon.stub(Fetcher, 'json') .callsFake(url => Promise.resolve(JSON.parse(resources[url]))); - proj4.defs('EPSG:2154', '+proj=lcc +lat_1=49 +lat_2=44 +lat_0=46.5 +lon_0=3 +x_0=700000 +y_0=6600000 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs'); + CRS.defs('EPSG:2154', '+proj=lcc +lat_1=49 +lat_2=44 +lat_0=46.5 +lon_0=3 +x_0=700000 +y_0=6600000 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=m +no_defs'); const renderer = new Renderer(); const p = { diff --git a/test/unit/planarControls.js b/packages/Main/test/unit/planarControls.js similarity index 99% rename from test/unit/planarControls.js rename to packages/Main/test/unit/planarControls.js index 3d5e7604ca..23c52b74ad 100644 --- a/test/unit/planarControls.js +++ b/packages/Main/test/unit/planarControls.js @@ -2,7 +2,7 @@ import assert from 'assert'; import * as THREE from 'three'; import PlanarView from 'Core/Prefab/PlanarView'; import { CAMERA_TYPE } from 'Renderer/Camera'; -import Extent from 'Core/Geographic/Extent'; +import { Extent } from '@itowns/geographic'; import { keys, STATE } from 'Controls/PlanarControls'; import Renderer from './bootstrap'; diff --git a/test/unit/planarView.js b/packages/Main/test/unit/planarView.js similarity index 92% rename from test/unit/planarView.js rename to packages/Main/test/unit/planarView.js index c079c081a0..daa8c05693 100644 --- a/test/unit/planarView.js +++ b/packages/Main/test/unit/planarView.js @@ -1,5 +1,5 @@ import assert from 'assert'; -import Extent from 'Core/Geographic/Extent'; +import { Extent } from '@itowns/geographic'; import PlanarView from 'Core/Prefab/PlanarView'; import Renderer from './bootstrap'; diff --git a/test/unit/pnts_parser.js b/packages/Main/test/unit/pnts_parser.js similarity index 100% rename from test/unit/pnts_parser.js rename to packages/Main/test/unit/pnts_parser.js diff --git a/test/unit/pointsmaterial.js b/packages/Main/test/unit/pointsmaterial.js similarity index 100% rename from test/unit/pointsmaterial.js rename to packages/Main/test/unit/pointsmaterial.js diff --git a/test/unit/potree.js b/packages/Main/test/unit/potree.js similarity index 99% rename from test/unit/potree.js rename to packages/Main/test/unit/potree.js index b744b603a7..b5d6b296fb 100644 --- a/test/unit/potree.js +++ b/packages/Main/test/unit/potree.js @@ -4,7 +4,7 @@ import PotreeLayer from 'Layer/PotreeLayer'; import PotreeSource from 'Source/PotreeSource'; import View from 'Core/View'; import GlobeView from 'Core/Prefab/GlobeView'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; import PotreeNode from 'Core/PotreeNode'; import sinon from 'sinon'; import Fetcher from 'Provider/Fetcher'; diff --git a/test/unit/potree2.js b/packages/Main/test/unit/potree2.js similarity index 100% rename from test/unit/potree2.js rename to packages/Main/test/unit/potree2.js diff --git a/test/unit/potree2BinParser.js b/packages/Main/test/unit/potree2BinParser.js similarity index 100% rename from test/unit/potree2BinParser.js rename to packages/Main/test/unit/potree2BinParser.js diff --git a/test/unit/potree2layerparsing.js b/packages/Main/test/unit/potree2layerparsing.js similarity index 99% rename from test/unit/potree2layerparsing.js rename to packages/Main/test/unit/potree2layerparsing.js index 9f1dc423fc..09e60ec916 100644 --- a/test/unit/potree2layerparsing.js +++ b/packages/Main/test/unit/potree2layerparsing.js @@ -1,7 +1,7 @@ import assert from 'assert'; import Potree2Layer from 'Layer/Potree2Layer'; import Potree2Source from 'Source/Potree2Source'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; import GlobeView from 'Core/Prefab/GlobeView'; import View from 'Core/View'; import { HttpsProxyAgent } from 'https-proxy-agent'; diff --git a/test/unit/potree2layerprocessing.js b/packages/Main/test/unit/potree2layerprocessing.js similarity index 100% rename from test/unit/potree2layerprocessing.js rename to packages/Main/test/unit/potree2layerprocessing.js diff --git a/test/unit/potreeBinParser.js b/packages/Main/test/unit/potreeBinParser.js similarity index 100% rename from test/unit/potreeBinParser.js rename to packages/Main/test/unit/potreeBinParser.js diff --git a/test/unit/potreelayerparsing.js b/packages/Main/test/unit/potreelayerparsing.js similarity index 99% rename from test/unit/potreelayerparsing.js rename to packages/Main/test/unit/potreelayerparsing.js index 0f1207edb2..ab91c33325 100644 --- a/test/unit/potreelayerparsing.js +++ b/packages/Main/test/unit/potreelayerparsing.js @@ -2,7 +2,7 @@ import assert from 'assert'; import { HttpsProxyAgent } from 'https-proxy-agent'; import PotreeLayer from 'Layer/PotreeLayer'; import PotreeSource from 'Source/PotreeSource'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; import GlobeView from 'Core/Prefab/GlobeView'; import View from 'Core/View'; import sinon from 'sinon'; diff --git a/test/unit/potreelayerprocessing.js b/packages/Main/test/unit/potreelayerprocessing.js similarity index 100% rename from test/unit/potreelayerprocessing.js rename to packages/Main/test/unit/potreelayerprocessing.js diff --git a/test/unit/provider_url.js b/packages/Main/test/unit/provider_url.js similarity index 98% rename from test/unit/provider_url.js rename to packages/Main/test/unit/provider_url.js index 28a714e95f..be74950d42 100644 --- a/test/unit/provider_url.js +++ b/packages/Main/test/unit/provider_url.js @@ -1,7 +1,7 @@ /* eslint-disable no-template-curly-in-string */ import assert from 'assert'; import URLBuilder from 'Provider/URLBuilder'; -import Extent from 'Core/Geographic/Extent'; +import { Extent } from '@itowns/geographic'; import Tile from 'Core/Tile/Tile'; describe('URL creations', function () { diff --git a/test/unit/scheduler.js b/packages/Main/test/unit/scheduler.js similarity index 100% rename from test/unit/scheduler.js rename to packages/Main/test/unit/scheduler.js diff --git a/test/unit/shaderchunk.js b/packages/Main/test/unit/shaderchunk.js similarity index 100% rename from test/unit/shaderchunk.js rename to packages/Main/test/unit/shaderchunk.js diff --git a/test/unit/source.js b/packages/Main/test/unit/source.js similarity index 99% rename from test/unit/source.js rename to packages/Main/test/unit/source.js index 9e9d5a9b22..f9457a54ad 100644 --- a/test/unit/source.js +++ b/packages/Main/test/unit/source.js @@ -10,7 +10,7 @@ import FileSource from 'Source/FileSource'; import OrientedImageSource from 'Source/OrientedImageSource'; import C3DTilesSource from 'Source/C3DTilesSource'; import C3DTilesIonSource from 'Source/C3DTilesIonSource'; -import Extent from 'Core/Geographic/Extent'; +import { Extent } from '@itowns/geographic'; import Tile from 'Core/Tile/Tile'; import sinon from 'sinon'; import Fetcher from 'Provider/Fetcher'; diff --git a/test/unit/statecontrol.js b/packages/Main/test/unit/statecontrol.js similarity index 99% rename from test/unit/statecontrol.js rename to packages/Main/test/unit/statecontrol.js index 2420611388..c3ddab893d 100644 --- a/test/unit/statecontrol.js +++ b/packages/Main/test/unit/statecontrol.js @@ -1,6 +1,6 @@ import { MOUSE } from 'three'; import assert from 'assert'; -import Coordinates from 'Core/Geographic/Coordinates'; +import { Coordinates } from '@itowns/geographic'; import GlobeView from 'Core/Prefab/GlobeView'; import Renderer from './bootstrap'; diff --git a/test/unit/style.js b/packages/Main/test/unit/style.js similarity index 100% rename from test/unit/style.js rename to packages/Main/test/unit/style.js diff --git a/test/unit/threeutils.js b/packages/Main/test/unit/threeutils.js similarity index 100% rename from test/unit/threeutils.js rename to packages/Main/test/unit/threeutils.js diff --git a/test/unit/tile.js b/packages/Main/test/unit/tile.js similarity index 100% rename from test/unit/tile.js rename to packages/Main/test/unit/tile.js diff --git a/test/unit/tiledGeometryLayer.js b/packages/Main/test/unit/tiledGeometryLayer.js similarity index 94% rename from test/unit/tiledGeometryLayer.js rename to packages/Main/test/unit/tiledGeometryLayer.js index e10cf12332..562c74515e 100644 --- a/test/unit/tiledGeometryLayer.js +++ b/packages/Main/test/unit/tiledGeometryLayer.js @@ -1,9 +1,8 @@ import assert from 'assert'; -import Extent from 'Core/Geographic/Extent'; +import { Extent, Coordinates } from '@itowns/geographic'; import PlanarView from 'Core/Prefab/PlanarView'; import { CAMERA_TYPE } from 'Renderer/Camera'; import GlobeView from 'Core/Prefab/GlobeView'; -import Coordinates from 'Core/Geographic/Coordinates'; import Renderer from './bootstrap'; diff --git a/test/unit/tilemesh.js b/packages/Main/test/unit/tilemesh.js similarity index 100% rename from test/unit/tilemesh.js rename to packages/Main/test/unit/tilemesh.js diff --git a/test/unit/utils.js b/packages/Main/test/unit/utils.js similarity index 100% rename from test/unit/utils.js rename to packages/Main/test/unit/utils.js diff --git a/test/unit/vectortiles.js b/packages/Main/test/unit/vectortiles.js similarity index 100% rename from test/unit/vectortiles.js rename to packages/Main/test/unit/vectortiles.js diff --git a/test/unit/view.js b/packages/Main/test/unit/view.js similarity index 100% rename from test/unit/view.js rename to packages/Main/test/unit/view.js diff --git a/test/unit/webxr.js b/packages/Main/test/unit/webxr.js similarity index 100% rename from test/unit/webxr.js rename to packages/Main/test/unit/webxr.js diff --git a/packages/Main/tsconfig.json b/packages/Main/tsconfig.json new file mode 100644 index 0000000000..8c6936f80e --- /dev/null +++ b/packages/Main/tsconfig.json @@ -0,0 +1,10 @@ +{ + "extends": "../../tsconfig.json", + "include": [ "src/Main.js" ], + "exclude": [ "node_modules", "lib" ], + "compilerOptions": { + "paths": { + "*": [ "src/*" ] + }, + } +} diff --git a/packages/Widgets/.babelrc b/packages/Widgets/.babelrc new file mode 100644 index 0000000000..c4d2b6df97 --- /dev/null +++ b/packages/Widgets/.babelrc @@ -0,0 +1,24 @@ +{ + "presets": [ + ["@babel/preset-typescript"], + ["@babel/preset-env", { + "targets": { + "browsers": "defaults and supports webgl2" + }, + "modules": false + }] + ], + "plugins": [ + ["module-resolver", { + "cwd": "packagejson", + "root": ["./src"], + "extensions": [".js", ".ts", ".tsx"] + }], + ["module-extension-resolver", { + "srcExtensions": [".ts", ".js"] + }], + ["@babel/plugin-transform-runtime", { + "regenerator": false + }] + ] +} diff --git a/packages/Widgets/.eslintrc.cjs b/packages/Widgets/.eslintrc.cjs new file mode 100644 index 0000000000..9e9e3440e3 --- /dev/null +++ b/packages/Widgets/.eslintrc.cjs @@ -0,0 +1,7 @@ + +module.exports = { + extends: [ + '../../.eslintrc.cjs', + ], +}; + diff --git a/packages/Widgets/README.md b/packages/Widgets/README.md new file mode 100644 index 0000000000..9bb234ebba --- /dev/null +++ b/packages/Widgets/README.md @@ -0,0 +1,26 @@ +## @itowns/widget (private, for the moment) + +Graphic user interface for itowns + +## Getting started + +For the moment, The widget features are exposed in `itowns` module. + +```bash +npm install --save itowns +``` + +```js +import { Navigation } from 'itowns/widgets'; + +const viewerDiv = document.getElementById('viewerDiv'); + +// Create a GlobeView +const view = new itowns.GlobeView(viewerDiv); + +// Add navigation widget +const navigation = new Navigation(view, { + position: 'bottom-right', + translate: { y: -40 }, +}); +``` \ No newline at end of file diff --git a/packages/Widgets/package.json b/packages/Widgets/package.json new file mode 100644 index 0000000000..694a8554ba --- /dev/null +++ b/packages/Widgets/package.json @@ -0,0 +1,36 @@ +{ + "private": true, + "version": "2.44.2", + "description": "Widgets", + "type": "module", + "main": "lib/Main.js", + "exports": { + ".": "./lib/Main.js" + }, + "scripts": { + "lint": "eslint \"src/**/*.{js,ts,tsx}\"", + "copy_transpile": "npx copyfiles -u 1 \"./lib/**/*\" ../Main/lib/Utils/gui/", + "transpileOnly": "cross-env BABEL_DISABLE_CACHE=1 babel src --out-dir lib --extensions .js,.ts", + "transpile": "npm run transpileOnly && npm run copy_transpile", + "watch": "npm run transpileOnly -- --watch", + "publish-next": "npm version prerelease --preid next" + }, + "files": [ + "*.md", + "src", + "lib" + ], + "repository": { + "type": "git", + "url": "git+https://github.com/iTowns/itowns.git" + }, + "license": "(CECILL-B OR MIT)", + "bugs": { + "url": "https://github.com/itowns/itowns/issues" + }, + "dependencies": { + "@itowns/geographic": "^2.44.2", + "itowns": "^2.44.2" + }, + "homepage": "https://itowns.github.io/" +} diff --git a/src/Utils/gui/C3DTilesStyle.js b/packages/Widgets/src/C3DTilesStyle.js similarity index 99% rename from src/Utils/gui/C3DTilesStyle.js rename to packages/Widgets/src/C3DTilesStyle.js index 6fabf4f72a..620f581fb3 100644 --- a/src/Utils/gui/C3DTilesStyle.js +++ b/packages/Widgets/src/C3DTilesStyle.js @@ -1,4 +1,4 @@ -import { C3DTILES_LAYER_EVENTS } from 'Layer/C3DTilesLayer'; +import { C3DTILES_LAYER_EVENTS } from 'itowns'; import Widget from './Widget'; const DEFAULT_OPTIONS = { diff --git a/src/Utils/gui/Main.js b/packages/Widgets/src/Main.js similarity index 100% rename from src/Utils/gui/Main.js rename to packages/Widgets/src/Main.js diff --git a/src/Utils/gui/Minimap.js b/packages/Widgets/src/Minimap.js similarity index 97% rename from src/Utils/gui/Minimap.js rename to packages/Widgets/src/Minimap.js index a88c6b3572..461ab94c2d 100644 --- a/src/Utils/gui/Minimap.js +++ b/packages/Widgets/src/Minimap.js @@ -1,7 +1,5 @@ -import Coordinates from 'Core/Geographic/Coordinates'; -import { MAIN_LOOP_EVENTS } from 'Core/MainLoop'; -import PlanarView from 'Core/Prefab/PlanarView'; -import { CAMERA_TYPE } from 'Renderer/Camera'; +import { Coordinates } from '@itowns/geographic'; +import { MAIN_LOOP_EVENTS, PlanarView, CAMERA_TYPE } from 'itowns'; import Widget from './Widget'; diff --git a/src/Utils/gui/Navigation.js b/packages/Widgets/src/Navigation.js similarity index 99% rename from src/Utils/gui/Navigation.js rename to packages/Widgets/src/Navigation.js index 424528234f..3a83ef7770 100644 --- a/src/Utils/gui/Navigation.js +++ b/packages/Widgets/src/Navigation.js @@ -1,4 +1,4 @@ -import { VIEW_EVENTS } from 'Core/View'; +import { VIEW_EVENTS } from 'itowns'; import Widget from './Widget'; diff --git a/src/Utils/gui/Scale.js b/packages/Widgets/src/Scale.js similarity index 96% rename from src/Utils/gui/Scale.js rename to packages/Widgets/src/Scale.js index 37179296b1..8a987576df 100644 --- a/src/Utils/gui/Scale.js +++ b/packages/Widgets/src/Scale.js @@ -1,7 +1,4 @@ -import { CONTROL_EVENTS } from 'Controls/GlobeControls'; -import { GLOBE_VIEW_EVENTS } from 'Core/Prefab/GlobeView'; -import { PLANAR_CONTROL_EVENT } from 'Controls/PlanarControls'; -import { VIEW_EVENTS } from 'Core/View'; +import { CONTROL_EVENTS, GLOBE_VIEW_EVENTS, PLANAR_CONTROL_EVENT, VIEW_EVENTS } from 'itowns'; import Widget from './Widget'; diff --git a/src/Utils/gui/Searchbar.js b/packages/Widgets/src/Searchbar.js similarity index 99% rename from src/Utils/gui/Searchbar.js rename to packages/Widgets/src/Searchbar.js index 391e5cb804..79bc89f870 100644 --- a/src/Utils/gui/Searchbar.js +++ b/packages/Widgets/src/Searchbar.js @@ -1,4 +1,4 @@ -import Fetcher from 'Provider/Fetcher'; +import { Fetcher } from 'itowns'; import Widget from './Widget'; diff --git a/src/Utils/gui/Widget.js b/packages/Widgets/src/Widget.js similarity index 100% rename from src/Utils/gui/Widget.js rename to packages/Widgets/src/Widget.js diff --git a/packages/Widgets/tsconfig.json b/packages/Widgets/tsconfig.json new file mode 100644 index 0000000000..8c6936f80e --- /dev/null +++ b/packages/Widgets/tsconfig.json @@ -0,0 +1,10 @@ +{ + "extends": "../../tsconfig.json", + "include": [ "src/Main.js" ], + "exclude": [ "node_modules", "lib" ], + "compilerOptions": { + "paths": { + "*": [ "src/*" ] + }, + } +} diff --git a/tsconfig.json b/tsconfig.json index 63841f2d26..afff4f5d4f 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -1,14 +1,9 @@ { - "include": [ "src/Main.js" ], - "exclude": [ "node_modules", "lib", "dist" ], "compilerOptions": { /* Type Checking */ "strict": true, /* Modules */ "baseUrl": ".", - "paths": { - "*": [ "src/*" ] - }, "module": "ESNext", /* Emit */ "declaration": true, diff --git a/utils/debug/Main.js b/utils/debug/Main.js deleted file mode 100644 index 5279127956..0000000000 --- a/utils/debug/Main.js +++ /dev/null @@ -1,6 +0,0 @@ -export { default as Debug } from './Debug'; -export { default as PointCloudDebug } from './PointCloudDebug'; -export { default as createTileDebugUI } from './TileDebug'; -export { default as create3dTilesDebugUI } from './3dTilesDebug'; -export { default as createOGC3DTilesDebugUI } from './OGC3DTilesDebug'; -export { default as GeometryDebug } from './GeometryDebug'; diff --git a/webpack.config.cjs b/webpack.config.cjs index d954fb78c0..0b1617e4d2 100644 --- a/webpack.config.cjs +++ b/webpack.config.cjs @@ -23,8 +23,10 @@ const babelConf = { }; const include = [ - path.resolve(__dirname, 'src'), - path.resolve(__dirname, 'utils'), + path.resolve(__dirname, 'packages/Geographic/src'), + path.resolve(__dirname, 'packages/Main/src'), + path.resolve(__dirname, 'packages/Debug/src'), + path.resolve(__dirname, 'packages/Widgets/src'), ]; const exclude = [ @@ -50,25 +52,29 @@ module.exports = () => { extensionAlias: { '.js': ['.ts', '.js'], }, + alias: { + itowns: path.resolve(__dirname, 'packages/Main/src/Main.js'), + '@itowns/geographic': path.resolve(__dirname, 'packages/Geographic/src/Main.js'), + }, }, entry: { itowns: [ 'core-js', - './src/MainBundle.js', + './packages/Main/src/MainBundle.js', ], debug: { - import: './utils/debug/Main.js', + import: './packages/Debug/src/Main.js', dependOn: 'itowns', }, itowns_widgets: { - import: './src/Utils/gui/Main.js', + import: './packages/Widgets/src/Main.js', dependOn: 'itowns', }, itowns_potree2worker: { - import: './src/Worker/Potree2Worker.js', + import: './packages/Main/src/Worker/Potree2Worker.js', }, itowns_lasworker: { - import: './src/Worker/LASLoaderWorker.js', + import: './packages/Main/src/Worker/LASLoaderWorker.js', }, }, devtool: 'source-map',