esri-gl 0.9.0-alpha.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/LICENSE ADDED
@@ -0,0 +1,227 @@
1
+ -------------------------------------------------------------------------------
2
+
3
+ MIT License
4
+
5
+ Copyright (c) 2025 esri-gl
6
+
7
+ Permission is hereby granted, free of charge, to any person obtaining a copy
8
+ of this software and associated documentation files (the "Software"), to deal
9
+ in the Software without restriction, including without limitation the rights
10
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11
+ copies of the Software, and to permit persons to whom the Software is
12
+ furnished to do so, subject to the following conditions:
13
+
14
+ The above copyright notice and this permission notice shall be included in all
15
+ copies or substantial portions of the Software.
16
+
17
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
23
+ SOFTWARE.
24
+
25
+
26
+
27
+ Apache License
28
+ Version 2.0, January 2004
29
+ http://www.apache.org/licenses/
30
+
31
+ TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
32
+
33
+ 1. Definitions.
34
+
35
+ "License" shall mean the terms and conditions for use, reproduction,
36
+ and distribution as defined by Sections 1 through 9 of this document.
37
+
38
+ "Licensor" shall mean the copyright owner or entity authorized by
39
+ the copyright owner that is granting the License.
40
+
41
+ "Legal Entity" shall mean the union of the acting entity and all
42
+ other entities that control, are controlled by, or are under common
43
+ control with that entity. For the purposes of this definition,
44
+ "control" means (i) the power, direct or indirect, to cause the
45
+ direction or management of such entity, whether by contract or
46
+ otherwise, or (ii) ownership of fifty percent (50%) or more of the
47
+ outstanding shares, or (iii) beneficial ownership of such entity.
48
+
49
+ "You" (or "Your") shall mean an individual or Legal Entity
50
+ exercising permissions granted by this License.
51
+
52
+ "Source" form shall mean the preferred form for making modifications,
53
+ including but not limited to software source code, documentation
54
+ source, and configuration files.
55
+
56
+ "Object" form shall mean any form resulting from mechanical
57
+ transformation or translation of a Source form, including but
58
+ not limited to compiled object code, generated documentation,
59
+ and conversions to other media types.
60
+
61
+ "Work" shall mean the work of authorship, whether in Source or
62
+ Object form, made available under the License, as indicated by a
63
+ copyright notice that is included in or attached to the work
64
+ (an example is provided in the Appendix below).
65
+
66
+ "Derivative Works" shall mean any work, whether in Source or Object
67
+ form, that is based on (or derived from) the Work and for which the
68
+ editorial revisions, annotations, elaborations, or other modifications
69
+ represent, as a whole, an original work of authorship. For the purposes
70
+ of this License, Derivative Works shall not include works that remain
71
+ separable from, or merely link (or bind by name) to the interfaces of,
72
+ the Work and Derivative Works thereof.
73
+
74
+ "Contribution" shall mean any work of authorship, including
75
+ the original version of the Work and any modifications or additions
76
+ to that Work or Derivative Works thereof, that is intentionally
77
+ submitted to Licensor for inclusion in the Work by the copyright owner
78
+ or by an individual or Legal Entity authorized to submit on behalf of
79
+ the copyright owner. For the purposes of this definition, "submitted"
80
+ means any form of electronic, verbal, or written communication sent
81
+ to the Licensor or its representatives, including but not limited to
82
+ communication on electronic mailing lists, source code control systems,
83
+ and issue tracking systems that are managed by, or on behalf of, the
84
+ Licensor for the purpose of discussing and improving the Work, but
85
+ excluding communication that is conspicuously marked or otherwise
86
+ designated in writing by the copyright owner as "Not a Contribution."
87
+
88
+ "Contributor" shall mean Licensor and any individual or Legal Entity
89
+ on behalf of whom a Contribution has been received by Licensor and
90
+ subsequently incorporated within the Work.
91
+
92
+ 2. Grant of Copyright License. Subject to the terms and conditions of
93
+ this License, each Contributor hereby grants to You a perpetual,
94
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
95
+ copyright license to reproduce, prepare Derivative Works of,
96
+ publicly display, publicly perform, sublicense, and distribute the
97
+ Work and such Derivative Works in Source or Object form.
98
+
99
+ 3. Grant of Patent License. Subject to the terms and conditions of
100
+ this License, each Contributor hereby grants to You a perpetual,
101
+ worldwide, non-exclusive, no-charge, royalty-free, irrevocable
102
+ (except as stated in this section) patent license to make, have made,
103
+ use, offer to sell, sell, import, and otherwise transfer the Work,
104
+ where such license applies only to those patent claims licensable
105
+ by such Contributor that are necessarily infringed by their
106
+ Contribution(s) alone or by combination of their Contribution(s)
107
+ with the Work to which such Contribution(s) was submitted. If You
108
+ institute patent litigation against any entity (including a
109
+ cross-claim or counterclaim in a lawsuit) alleging that the Work
110
+ or a Contribution incorporated within the Work constitutes direct
111
+ or contributory patent infringement, then any patent licenses
112
+ granted to You under this License for that Work shall terminate
113
+ as of the date such litigation is filed.
114
+
115
+ 4. Redistribution. You may reproduce and distribute copies of the
116
+ Work or Derivative Works thereof in any medium, with or without
117
+ modifications, and in Source or Object form, provided that You
118
+ meet the following conditions:
119
+
120
+ (a) You must give any other recipients of the Work or
121
+ Derivative Works a copy of this License; and
122
+
123
+ (b) You must cause any modified files to carry prominent notices
124
+ stating that You changed the files; and
125
+
126
+ (c) You must retain, in the Source form of any Derivative Works
127
+ that You distribute, all copyright, patent, trademark, and
128
+ attribution notices from the Source form of the Work,
129
+ excluding those notices that do not pertain to any part of
130
+ the Derivative Works; and
131
+
132
+ (d) If the Work includes a "NOTICE" text file as part of its
133
+ distribution, then any Derivative Works that You distribute must
134
+ include a readable copy of the attribution notices contained
135
+ within such NOTICE file, excluding those notices that do not
136
+ pertain to any part of the Derivative Works, in at least one
137
+ of the following places: within a NOTICE text file distributed
138
+ as part of the Derivative Works; within the Source form or
139
+ documentation, if provided along with the Derivative Works; or,
140
+ within a display generated by the Derivative Works, if and
141
+ wherever such third-party notices normally appear. The contents
142
+ of the NOTICE file are for informational purposes only and
143
+ do not modify the License. You may add Your own attribution
144
+ notices within Derivative Works that You distribute, alongside
145
+ or as an addendum to the NOTICE text from the Work, provided
146
+ that such additional attribution notices cannot be construed
147
+ as modifying the License.
148
+
149
+ You may add Your own copyright statement to Your modifications and
150
+ may provide additional or different license terms and conditions
151
+ for use, reproduction, or distribution of Your modifications, or
152
+ for any such Derivative Works as a whole, provided Your use,
153
+ reproduction, and distribution of the Work otherwise complies with
154
+ the conditions stated in this License.
155
+
156
+ 5. Submission of Contributions. Unless You explicitly state otherwise,
157
+ any Contribution intentionally submitted for inclusion in the Work
158
+ by You to the Licensor shall be under the terms and conditions of
159
+ this License, without any additional terms or conditions.
160
+ Notwithstanding the above, nothing herein shall supersede or modify
161
+ the terms of any separate license agreement you may have executed
162
+ with Licensor regarding such Contributions.
163
+
164
+ 6. Trademarks. This License does not grant permission to use the trade
165
+ names, trademarks, service marks, or product names of the Licensor,
166
+ except as required for reasonable and customary use in describing the
167
+ origin of the Work and reproducing the content of the NOTICE file.
168
+
169
+ 7. Disclaimer of Warranty. Unless required by applicable law or
170
+ agreed to in writing, Licensor provides the Work (and each
171
+ Contributor provides its Contributions) on an "AS IS" BASIS,
172
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
173
+ implied, including, without limitation, any warranties or conditions
174
+ of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A
175
+ PARTICULAR PURPOSE. You are solely responsible for determining the
176
+ appropriateness of using or redistributing the Work and assume any
177
+ risks associated with Your exercise of permissions under this License.
178
+
179
+ 8. Limitation of Liability. In no event and under no legal theory,
180
+ whether in tort (including negligence), contract, or otherwise,
181
+ unless required by applicable law (such as deliberate and grossly
182
+ negligent acts) or agreed to in writing, shall any Contributor be
183
+ liable to You for damages, including any direct, indirect, special,
184
+ incidental, or consequential damages of any character arising as a
185
+ result of this License or out of the use or inability to use the
186
+ Work (including but not limited to damages for loss of goodwill,
187
+ work stoppage, computer failure or malfunction, or any and all
188
+ other commercial damages or losses), even if such Contributor
189
+ has been advised of the possibility of such damages.
190
+
191
+ 9. Accepting Warranty or Additional Liability. While redistributing
192
+ the Work or Derivative Works thereof, You may choose to offer,
193
+ and charge a fee for, acceptance of support, warranty, indemnity,
194
+ or other liability obligations and/or rights consistent with this
195
+ License. However, in accepting such obligations, You may act only
196
+ on Your own behalf and on Your sole responsibility, not on behalf
197
+ of any other Contributor, and only if You agree to indemnify,
198
+ defend, and hold each Contributor harmless for any liability
199
+ incurred by, or claims asserted against, such Contributor by reason
200
+ of your accepting any such warranty or additional liability.
201
+
202
+ END OF TERMS AND CONDITIONS
203
+
204
+ APPENDIX: How to apply the Apache License to your work.
205
+
206
+ To apply the Apache License to your work, attach the following
207
+ boilerplate notice, with the fields enclosed by brackets "[]"
208
+ replaced with your own identifying information. (Don't include
209
+ the brackets!) The text should be enclosed in the appropriate
210
+ comment syntax for the file format. We also recommend that a
211
+ file or class name and description of purpose be included on the
212
+ same "printed page" as the copyright notice for easier
213
+ identification within third-party archives.
214
+
215
+ Copyright 2020-2025 - FrontierSI
216
+
217
+ Licensed under the Apache License, Version 2.0 (the "License");
218
+ you may not use this file except in compliance with the License.
219
+ You may obtain a copy of the License at
220
+
221
+ http://www.apache.org/licenses/LICENSE-2.0
222
+
223
+ Unless required by applicable law or agreed to in writing, software
224
+ distributed under the License is distributed on an "AS IS" BASIS,
225
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
226
+ See the License for the specific language governing permissions and
227
+ limitations under the License.
package/README.md ADDED
@@ -0,0 +1,455 @@
1
+ # esri-gl
2
+
3
+ A TypeScript library that bridges Esri ArcGIS REST services with MapLibre GL JS and Mapbox GL JS. It replicates Esri Leaflet's architecture patterns while being compatible with modern WebGL mapping libraries.
4
+
5
+ > **🚧 Development Notice**
6
+ >
7
+ > This project is currently under active development. APIs may change between releases and some features may not be fully stable. Please use with caution in production environments and check the [changelog](CHANGES.md) for breaking changes between versions.
8
+
9
+ [![npm version](https://badge.fury.io/js/esri-gl.svg)](https://badge.fury.io/js/esri-gl)
10
+ [![TypeScript](https://img.shields.io/badge/%3C%2F%3E-TypeScript-%230074c1.svg)](http://www.typescriptlang.org/)
11
+ [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
12
+
13
+ ## 🔗 Links
14
+
15
+ - **📚 [Documentation](https://esri-gl.netlify.app/)** - Complete API reference and guides
16
+ - **🎮 [Live Demos](https://esri-gl-demo.netlify.app/)** - Interactive examples and code samples
17
+
18
+ **Note**: This library is compatible with both **MapLibre GL JS** and **Mapbox GL JS**.
19
+
20
+ ## Features
21
+
22
+ ### Supported Services
23
+
24
+ - **Dynamic Map Services** - Server-rendered raster tiles from ArcGIS Map Services
25
+ - **Tiled Map Services** - Pre-cached tile services for optimal performance
26
+ - **Image Services** - Analytical raster data with server-side processing
27
+ - **Vector Tile Services** - Client-rendered vector tiles for fast styling
28
+ - **Vector Basemap Styles** - Esri's vector basemap styles with custom styling
29
+ - **Feature Services** - Vector data with smart vector tile detection and GeoJSON fallback
30
+
31
+ ### Advanced Features
32
+
33
+ - **Smart Vector Tile Detection** - Automatically detects vector tile endpoints with GeoJSON fallback
34
+ - **Dynamic Layer Management** - Add/remove layers dynamically with proper cleanup
35
+ - **Identify Tasks** - Query features and raster data at specific locations
36
+ - **Bounding Box Filtering** - Optimize performance with viewport-based data loading
37
+ - **Layer Definitions** - Filter data server-side using SQL-like expressions
38
+ - **Time-aware Services** - Support for temporal data visualization
39
+ - **Attribution Management** - Automatic service attribution handling
40
+ - **TypeScript Support** - Full type safety with comprehensive interfaces
41
+
42
+ ## Installation
43
+
44
+ ### Stable Release
45
+ ```bash
46
+ npm install esri-gl
47
+ ```
48
+
49
+ ### Alpha/Beta Releases
50
+ ```bash
51
+ # Latest alpha release (current: v0.1.0-alpha.2)
52
+ npm install esri-gl@alpha
53
+
54
+ # Specific alpha version
55
+ npm install esri-gl@0.1.0-alpha.2
56
+
57
+ # Latest beta release
58
+ npm install esri-gl@beta
59
+ ```
60
+
61
+ ### GitHub Packages (Alternative Registry)
62
+ ```bash
63
+ # Configure npm to use GitHub Packages for @muimsd scope
64
+ npm config set @muimsd:registry https://npm.pkg.github.com/
65
+
66
+ # Install from GitHub Packages
67
+ npm install @muimsd/esri-gl
68
+
69
+ # Or use the setup script
70
+ ./scripts/github-packages.sh configure
71
+ ./scripts/github-packages.sh install
72
+ ```
73
+
74
+ ## Quick Start
75
+
76
+ ### Basic Usage with MapLibre GL JS
77
+
78
+ ```typescript
79
+ import { Map } from 'maplibre-gl';
80
+ import { DynamicMapService, VectorTileService, FeatureService } from 'esri-gl';
81
+
82
+ const map = new Map({
83
+ container: 'map',
84
+ style: 'https://demotiles.maplibre.org/style.json',
85
+ center: [-95, 37],
86
+ zoom: 4
87
+ });
88
+
89
+ map.on('load', () => {
90
+ // Add a dynamic map service
91
+ const dynamicService = new DynamicMapService('census-source', map, {
92
+ url: 'https://sampleserver6.arcgisonline.com/arcgis/rest/services/Census/MapServer'
93
+ });
94
+
95
+ map.addLayer({
96
+ id: 'census-layer',
97
+ type: 'raster',
98
+ source: 'census-source'
99
+ });
100
+
101
+ // Add a feature service with smart vector tile detection
102
+ const featureService = new FeatureService('parcels-source', map, {
103
+ url: 'https://services.arcgis.com/.../FeatureServer/0',
104
+ useVectorTiles: true, // Automatically detects and falls back to GeoJSON if needed
105
+ useBoundingBox: true, // Optimize with viewport filtering
106
+ where: "STATUS = 'Active'", // Server-side filtering
107
+ outFields: '*'
108
+ });
109
+
110
+ map.addLayer({
111
+ id: 'parcels-layer',
112
+ type: 'fill',
113
+ source: 'parcels-source',
114
+ paint: {
115
+ 'fill-color': '#007cbf',
116
+ 'fill-opacity': 0.5
117
+ }
118
+ });
119
+ });
120
+ ```
121
+
122
+ ### Using with Mapbox GL JS
123
+
124
+ ```typescript
125
+ import mapboxgl from 'mapbox-gl';
126
+ import { VectorBasemapStyle, ImageService } from 'esri-gl';
127
+
128
+ mapboxgl.accessToken = 'your-mapbox-token';
129
+
130
+ const map = new mapboxgl.Map({
131
+ container: 'map',
132
+ center: [-95, 37],
133
+ zoom: 4
134
+ });
135
+
136
+ map.on('load', () => {
137
+ // Add Esri vector basemap style
138
+ const basemapService = new VectorBasemapStyle('basemap-source', map, {
139
+ style: 'arcgis/streets'
140
+ });
141
+
142
+ // Add image service for analytical raster data
143
+ const imageService = new ImageService('elevation-source', map, {
144
+ url: 'https://sampleserver6.arcgisonline.com/arcgis/rest/services/Elevation/ImageServer',
145
+ renderingRule: {
146
+ rasterFunction: 'Hillshade'
147
+ }
148
+ });
149
+
150
+ map.addLayer({
151
+ id: 'elevation-layer',
152
+ type: 'raster',
153
+ source: 'elevation-source'
154
+ });
155
+ });
156
+ ```
157
+
158
+ ## Service Classes
159
+
160
+ ### DynamicMapService
161
+ Server-rendered raster tiles from ArcGIS Map Services.
162
+
163
+ ```typescript
164
+ const service = new DynamicMapService('source-id', map, {
165
+ url: 'https://example.com/arcgis/rest/services/MyService/MapServer',
166
+ layers: [0, 1, 2], // Specific layers to display
167
+ layerDefs: {
168
+ 0: "POP2000 > 100000", // Filter layer 0
169
+ 1: "STATE_NAME = 'California'" // Filter layer 1
170
+ },
171
+ transparent: true,
172
+ format: 'png32'
173
+ });
174
+ ```
175
+
176
+ ### TiledMapService
177
+ Pre-cached tile services for optimal performance.
178
+
179
+ ```typescript
180
+ const service = new TiledMapService('source-id', map, {
181
+ url: 'https://example.com/arcgis/rest/services/MyTiledService/MapServer'
182
+ });
183
+ ```
184
+
185
+ ### FeatureService
186
+ Vector data with intelligent vector tile detection and automatic GeoJSON fallback.
187
+
188
+ ```typescript
189
+ const service = new FeatureService('source-id', map, {
190
+ url: 'https://example.com/arcgis/rest/services/MyService/FeatureServer/0',
191
+ useVectorTiles: true, // Smart detection with fallback
192
+ useBoundingBox: true, // Viewport-based loading
193
+ where: '1=1',
194
+ outFields: '*',
195
+ maxRecordCount: 2000
196
+ });
197
+ ```
198
+
199
+ ### VectorTileService
200
+ Client-rendered vector tiles for fast styling and interaction.
201
+
202
+ ```typescript
203
+ const service = new VectorTileService('source-id', map, {
204
+ url: 'https://example.com/arcgis/rest/services/MyService/VectorTileServer'
205
+ });
206
+ ```
207
+
208
+ ### ImageService
209
+ Analytical raster data with server-side processing capabilities.
210
+
211
+ ```typescript
212
+ const service = new ImageService('source-id', map, {
213
+ url: 'https://example.com/arcgis/rest/services/MyImageService/ImageServer',
214
+ renderingRule: {
215
+ rasterFunction: 'Stretch',
216
+ rasterFunctionArguments: {
217
+ StretchType: 6,
218
+ NumberOfStandardDeviations: 2
219
+ }
220
+ },
221
+ mosaicRule: {
222
+ mosaicMethod: 'esriMosaicLockRaster',
223
+ lockRasterIds: [1, 2, 3]
224
+ }
225
+ });
226
+ ```
227
+
228
+ ### VectorBasemapStyle
229
+ Esri's vector basemap styles with customization options.
230
+
231
+ ```typescript
232
+ const service = new VectorBasemapStyle('source-id', map, {
233
+ style: 'arcgis/streets', // or 'arcgis/navigation', 'arcgis/topographic', etc.
234
+ language: 'en',
235
+ worldview: 'USA'
236
+ });
237
+ ```
238
+
239
+ ## Task-Based Operations
240
+
241
+ Modeled after Esri Leaflet's chainable task pattern for querying and identifying features.
242
+
243
+ ### IdentifyFeatures
244
+ Query vector features at specific locations.
245
+
246
+ ```typescript
247
+ import { IdentifyFeatures } from 'esri-gl';
248
+
249
+ const identifyService = new IdentifyFeatures({
250
+ url: 'https://example.com/arcgis/rest/services/MyService/MapServer'
251
+ });
252
+
253
+ // Identify features at a point
254
+ const results = await identifyService
255
+ .at({ lng: -95, lat: 37 })
256
+ .tolerance(5)
257
+ .layers('all')
258
+ .returnGeometry(true)
259
+ .run(map);
260
+
261
+ console.log('Identified features:', results);
262
+ ```
263
+
264
+ ### IdentifyImage
265
+ Query raster values from image services.
266
+
267
+ ```typescript
268
+ import { identifyImage } from 'esri-gl';
269
+
270
+ const results = await identifyImage({
271
+ url: 'https://example.com/arcgis/rest/services/Elevation/ImageServer'
272
+ }).at({ lng: -120, lat: 40 });
273
+
274
+ console.log('Elevation value:', results.value);
275
+ ```
276
+
277
+ ### Query
278
+ Advanced feature querying with spatial and attribute filters.
279
+
280
+ ```typescript
281
+ import { query } from 'esri-gl';
282
+
283
+ const results = await query({
284
+ url: 'https://example.com/arcgis/rest/services/MyService/FeatureServer/0'
285
+ })
286
+ .where("STATE_NAME = 'California'")
287
+ .intersects({
288
+ type: 'Point',
289
+ coordinates: [-118, 34]
290
+ })
291
+ .run();
292
+ ```
293
+
294
+ ## Advanced Features
295
+
296
+ ### Dynamic Layer Management
297
+
298
+ ```typescript
299
+ // Add layers dynamically
300
+ const service = new DynamicMapService('census-source', map, {
301
+ url: 'https://example.com/MapServer'
302
+ });
303
+
304
+ // Update visible layers
305
+ service.setLayers([0, 2, 5]);
306
+
307
+ // Update layer definitions
308
+ service.setLayerDefs({
309
+ 0: "POP2000 > 50000",
310
+ 2: "STATE_NAME IN ('California', 'Nevada')"
311
+ });
312
+
313
+ // Clean up
314
+ service.remove();
315
+ ```
316
+
317
+ ### Smart Vector Tile Detection
318
+
319
+ The `FeatureService` automatically detects vector tile availability:
320
+
321
+ ```typescript
322
+ const service = new FeatureService('smart-source', map, {
323
+ url: 'https://example.com/FeatureServer/0',
324
+ useVectorTiles: true // Will automatically:
325
+ // 1. Check for VectorTileServer endpoint
326
+ // 2. Test various URL patterns
327
+ // 3. Fall back to GeoJSON if vector tiles unavailable
328
+ // 4. Log the decision process to console
329
+ });
330
+ ```
331
+
332
+ ### Performance Optimization
333
+
334
+ ```typescript
335
+ const service = new FeatureService('optimized-source', map, {
336
+ url: 'https://example.com/FeatureServer/0',
337
+ useBoundingBox: true, // Only load features in current viewport
338
+ maxRecordCount: 1000, // Limit records per request
339
+ where: 'STATUS = "Active"', // Server-side filtering
340
+ outFields: ['OBJECTID', 'NAME', 'STATUS'] // Limit fields
341
+ });
342
+ ```
343
+
344
+ ## Development
345
+
346
+ ### Build System
347
+ - **Library Build**: Rollup with `@rollup/plugin-typescript` (UMD + ESM outputs)
348
+ - **Type Declarations**: Consolidated in `dist/types/` directory
349
+ - **Demo Development**: Vite dev server
350
+ - **Documentation**: Docusaurus build system
351
+ - **Test Coverage**: 92.94% with 651 focused test cases
352
+
353
+ ### Development Commands
354
+
355
+ ```bash
356
+ # Start demo development server
357
+ npm run dev
358
+
359
+ # Build library (both UMD and ESM)
360
+ npm run build
361
+
362
+ # Watch mode for library development
363
+ npm run build:watch
364
+
365
+ # Type checking
366
+ npm run type-check
367
+
368
+ # Linting and formatting
369
+ npm run lint
370
+ npm run format
371
+
372
+ # Run tests
373
+ npm run test
374
+ npm run test:watch
375
+ npm run test:coverage
376
+
377
+ # Build documentation
378
+ npm run build-docs
379
+ npm run dev:docs
380
+ ```
381
+
382
+ ### Project Structure
383
+
384
+ ```
385
+ src/
386
+ ├── Services/ # Core service classes
387
+ │ ├── DynamicMapService.ts
388
+ │ ├── FeatureService.ts
389
+ │ ├── ImageService.ts
390
+ │ ├── TiledMapService.ts
391
+ │ ├── VectorTileService.ts
392
+ │ └── VectorBasemapStyle.ts
393
+ ├── Tasks/ # Task-based operations
394
+ │ ├── Find.ts
395
+ │ ├── IdentifyFeatures.ts
396
+ │ ├── IdentifyImage.ts
397
+ │ └── Query.ts
398
+ ├── demo/ # Demo React components
399
+ ├── tests/ # Comprehensive test suite (92.94% coverage)
400
+ └── types.ts # TypeScript interfaces
401
+
402
+ dist/
403
+ ├── types/ # Consolidated TypeScript declarations
404
+ ├── esri-gl.js # UMD build
405
+ ├── esri-gl.esm.js # ESM build
406
+ └── esri-gl.min.js # Minified UMD build
407
+ ```
408
+
409
+ ## Browser Support
410
+
411
+ - **Modern Browsers**: Chrome, Firefox, Safari, Edge (ES2018+)
412
+ - **MapLibre GL JS**: v2.0+ (recommended), v1.15+
413
+ - **Mapbox GL JS**: v2.0+ (recommended), v1.13+
414
+
415
+ ## TypeScript Support
416
+
417
+ esri-gl is written in TypeScript and provides full type definitions consolidated in a single directory:
418
+
419
+ ```typescript
420
+ import type {
421
+ DynamicMapServiceOptions,
422
+ FeatureServiceOptions,
423
+ IdentifyResult,
424
+ EsriGeoJSONFeatureCollection
425
+ } from 'esri-gl';
426
+
427
+ const options: FeatureServiceOptions = {
428
+ url: 'https://example.com/FeatureServer/0',
429
+ useVectorTiles: true,
430
+ where: '1=1'
431
+ };
432
+ ```
433
+
434
+ All type declarations are available in the `dist/types/` directory after building.
435
+
436
+ ## Contributing
437
+
438
+ 1. Fork the repository
439
+ 2. Create a feature branch: `git checkout -b feature/my-feature`
440
+ 3. Make changes and add tests
441
+ 4. Run validation: `npm run validate`
442
+ 5. Commit changes: `git commit -m 'Add new feature'`
443
+ 6. Push to branch: `git push origin feature/my-feature`
444
+ 7. Submit a pull request
445
+
446
+ ## License
447
+
448
+ MIT License - see [LICENSE](LICENSE) file for details.
449
+
450
+ ## Acknowledgements
451
+
452
+ - **Esri Leaflet** - Inspiration for API design and architectural patterns
453
+ - **MapLibre GL JS** & **Mapbox GL JS** - Incredible WebGL mapping libraries
454
+ - **Esri ArcGIS Platform** - Comprehensive GIS services and APIs
455
+ - **[mapbox-gl-esri-sources](https://github.com/frontiersi/mapbox-gl-esri-sources/)** - Reference implementation for Esri service integration patterns