When I make a custom style on mapbox, and try to use it with dash, I often times run into a bug where the map loads as only the background color of the map until I press home on the map, and zoom out.
For instance, it will happen if I try to customize the ‘light’ style of mapbox, and just take away the POI layer. You can try with this style as an example:
I have the same problem-- my map style won’t show up until I reset the view, and then it doesn’t fully load-- what’s weird is that it’s only one layer on top of the standard “light.” I tried making the style public-- perhaps that will push it to the mapbox CDN and make the tiles more readily available?
So my use case for the map style was leveraging a base Mapbox tileset that I adjusted with some additional geojson to choropleth a few specific areas. I then wanted to layer a quick px.scattermapbox over those polygons and didn’t want the hassle of updating the fig.layout with additional layers. Because of the issue above, I did indeed end up splitting the geojson into separate sets of polygons, giving each of them their own color, and adding them below the topmost mapbox style layer-- which was state-label-sm or something like that. This added at least 10mb of data to the eventual deliverable, which is not great.
I am left wondering whether the incompatibility between the mapbox style and the plotly library is one that will be resolved in future updates to plotly.js (or whether this has already happened based on recent mapbox integration improvements) which will filter down to plotly.py and friends.
I haven’t looked into the exact issues with custom mapbox account layers, but for geojson choropleth use cases, note that the latest version of dash has a new chart type called choroplethmapbox that allows you to provide geojson and color the shapes by values. Examples in the docs are getting published this evening.